Форум АНТИЧАТ

Форум АНТИЧАТ (https://forum.antichat.xyz/index.php)
-   Apple: Mac, OS X, iOS (https://forum.antichat.xyz/forumdisplay.php?f=177)
-   -   Создание программ для Mac OS X. Часть 2 (https://forum.antichat.xyz/showthread.php?t=1755641)

Markus Lang 11.02.2009 04:40

В этой части я расскажу вам о средствах разработки приложений под Mac OS X Leopard. Скажу сразу, что буду рассматривать только те, которые предоставляются самой Apple. Другие IDE существуют, но они обычно кроссплатформенные (например Code::Blocks), так что рассказывать о них лучше не в этой статье.

Так вот, на диске с Лео идет инструментарий разработчика Mac OS X - набор необходимых программ и фреймворков для создания приложений. Устанавливается все это дело(приложения, документация, куча примеров, разные полезные утилиты, etc.) в папку /Developer.

После установки имеет 4 основных приложения для разработки:
1. XCode - основная IDE
2. Interface Builder - программа для создания интерфейсов прораммы, хотя ее возможности куда шире
3. Instruments - средство для слежения за программой
4. Dashcode - программа для создания виджетов для Dashboard

А теперь про эти приложения подробнее:

Xcode

http://img524.imageshack.us/img524/9...nwindowqg1.png

Xcode - основная среда разработки, есть все, что и положено для IDE. Расписывать все функции нет особого смысла, т.к. она не сильно отличается от Visual Studio или KDevelop. А вот про нововведения в версии 3.0 упомянуть стоит:

1.подсветка блоков кода:

http://habrahabr.ru/pictures/00/00/0.../picture_4.png

2. сворачивание(folding) блоков кода(наконец-то)
3. улучшеный(в сторону скорости работы) редактор кода
4. рефракторинг кода

http://img518.imageshack.us/img518/5...ctoringfx0.png

5. поддержка Objective-C 2.0
6. Research Assistant - помощник, который исходя из выделенного текста пытается найти подходящую статью в Help и выводит в своем окне

http://img182.imageshack.us/img182/6...sassistox6.png

7. показ ошибок, предупреждений, etc прямо в коде:

http://habrahabr.ru/pictures/00/00/0.../picture_6.png

8. снимки проекта. Очень удобная вещь, по нажатию клавиш Ctrl+Command+S текущий проэк сохраняется в отдельное место, и потом можно будет к нему вернутся, если что-нибудь намудрил, причем для каждого файла показывается разница между тем что было и что стало:

http://img504.imageshack.us/img504/9...apshotsmw5.png

9. Органайзер. Насколько я понял, это инструмент для управления множества проектов, также позволяет использовать Xcode для написания программ на неизвестных языках для него. Сам еще не разбирался что это, но нашел статью, в которой рассказывается про органайзер подробнее.

Interface Builder

http://img174.imageshack.us/img174/2...nwindowgy7.png

Скрывать не буду и скажу сразу, что IB - самый лучший инструмент для создания интерфейсов из мною опробованных. И не только потому, что простые и понятные интерфейсы в нем легко создавать, а потому, что IB это нечто большее чем редактор интерфейсов, с его помощью можно избавится от написания многих частей кода, связанных с интрефейсной частью. Звучит конечно непонятно, но на примере будет намного яснее(примеры будут в конце).

Для чего же используется IB в процессе создания программы? Только для раскидывания кнопочек по форме - нет. Одна из основных задач IB - связывать объекты друг с другом, с переменными в классе, с разными событиями и т.п.

Instruments

http://img211.imageshack.us/img211/5...nwindowhv9.png

Instruments - средство для слежения за приложениями. Построен на порте под Mac OS X "DTrace tracing framework" из OpenSolaris. Само слежение проходит с помощью отдельных инструментов, которые хранятся в библиотеке и при необходимости перетаскиваются в главное окно. Изначально уже есть много инструментов, например инструмент для слежения за сетевой активностью, загрузкой процессора, чтения-записи на диск. Если нужного инструмента не хватает, то можно его создать самому:

http://img442.imageshack.us/img442/8...strumenys6.png

Dashcode

Я думаю из названия понятно для чего предназначена эта программа, а именно - создания виджетов для Dashboard. Баловался програмкой не долго, процесс создания виджета напомнил работу в Macromedia Flash. Вот сделал виджет для чтения rss хабра за секунд 10:

http://img504.imageshack.us/img504/2...habrrsspo1.png

Создание простого приложения средствами Xcode и Interface Builder

Как я и обещал, сейчас мы создадим простое приложение. Что оно будет делать? После ввода текста в поле редактирования и нажатия Enter выводить введенный текст на поле надписи(label). Предупрежу, что не буду подробно рассказывать почему что-то надо сделать именно так, мат.часть пойдет потом, сейчас - простое создание приложения без лишних вопросов.

Итак начнем:
открываем Xcode и выбираем в меню File => New Project, в появившемся окне отмечаем "Cocoa Application" и нажимаем Next:

http://img127.imageshack.us/img127/4945/xc1zg6.png

Далее зададим имя проекта - habr_1 и где он будет хранится(у меня ~/xcode/habr_1/

http://img152.imageshack.us/img152/217/xc2fe7.png

после этого нажмем Finish и получим проект. Теперь нам нужно добавить класс, который будет реализовать то, что нам нужно. Для этого идем в меню File => New File... и выбираем Objective-C class и жмем Next. В следующем окне нас попросят задаять имя файла, так что пишем "controller":

http://img232.imageshack.us/img232/8240/xc3ne0.png

Теперь в окне проекта слева в папке Classes появились два файла: controller.h и controller.m. Откроем controller.h и напишем тоже, что и на картинке:

http://img135.imageshack.us/img135/3900/xc4td2.png

Теперь два раза кликнем по файлу MainMenu.nib, откроется Interface Builder и станет активным. Что мы видим: заготовку под окно, главное меню и окно, обозначающее что мы открыли MainMenu.nib. Нажмем в меню Tools => Library чтобы открыть библиотеку с объектами и Tools => Inspector чтобы видеть свойства этих самых объектов. Теперь нам надо добавить в MainMenu.nib объект, который будет представлять созданный нами класс "controller", так что в библиотеке находим объект NSObject(синий полупрозрачный кубик) и перетаскиваем его в окно с надписью MainMenu.nib:

http://img507.imageshack.us/img507/1741/xcib1gd2.png

Переименуем "Object" в "controller" для ясности. Теперь нужно объяснить этому кубику, что он представляет нужный нам класс. Для этого оставляя его активным переходим на вкладку "Identity"(вторя справа) в инспекторе и в выпадающем списке напротив надписи "Class" выбираем наш "controller":

http://img222.imageshack.us/img222/889/xcib2wx0.png

Теперь добавим на форму из Библиотеки поле редактирования и метку. Для поля редактирования в на вкладке "Attributes"(первая слева) в выпадающем списке напротив надписи "action" выберем "Sent On Enter Only". Должно получится примерно такое:

http://habrahabr.ru/pictures/00/00/0...picture_20.png

А теперь начинается самое интересное, мы должны связать переменную "label" из класса с меткой и задать "setText:" в качестве сообщения, которое посылает текстовое поле при окончании редактирования. Свяжем метку с переменной label: сделаем активным наш объект "controller", зажмем Ctrl и левую кнопку мыши над синим кубиком и перенесем курсор на нашу метку, увиди следующюю картину:

http://img232.imageshack.us/img232/4466/xcib4rv4.png

после отпускания лкм появляется вот такое окно(в нем будут все классовые переменные, которые по типу совпадают с тем, к чему мы пытаемся связать

http://habrahabr.ru/pictures/00/00/0...picture_22.png

выбираем в нем единственную запись label. Все, теперь мы связали класовую переменную label и нашу метку на форме. Связывание полz редактирования с посылаемым ей сообщением проходит также, только перетягивать надо не с кубика на поле, а наоборот - с поля редактирования на объект controller.

Все, сохраняем MainMenu.nib(File => Save) и возвращаемся в Xcode.

В Xcode открываем файл controller.m и описываем реализацию сообщения:

http://img85.imageshack.us/img85/8748/xcib6jc7.png

Сохраняем проект, нажимаем Build and Go и получаем готовое приложение:

http://habrahabr.ru/pictures/00/00/0...picture_24.png

Введем что-нибудь в поле редактирования и нажмем Enter, вот результат:

http://habrahabr.ru/pictures/00/00/0...picture_25.png

Мощь Interface Builder

А сейчас я покажу вам как IB может упростить жизнь и количество кода. Создадим почти приложение(почти потому, что откомпилировать в полноценное приложение). Что оно будет делать? Выводить состояние слайдера в поле редактирования и иметь кнопку для закрытия.

Итак начнем. Откроем Interface Builder, File => New, выбираем "Window" и клацаем "Choose", получаем окно "Untitled", обозначающее наше окно и заготовку окна, кидаем на нее горизонтальный слайдер, поле редактирования и кнопку, причем в свойствах обзываем ее "Close":

http://habrahabr.ru/pictures/00/00/0...picture_26.png

Теперь проводим связь _от слайдера_к_полю_редактиров ния_, после отпускания лкм в выпадающем списке выбираем "takeDoubleValueFrom:":

http://habrahabr.ru/pictures/00/00/0...picture_27.png

Аналогично свяжем кнопку с событием terminate: объекта "First Responder" из окна "Untitled"(красненький кубик с единичкой).

Теперь File => Simulate Interface, получаем прототип работоспособного приложения: при изменении положения слайдера изменяется число в поле редактирования, при нажатии на Close приложение закрывается.

Вот так просто можно избавить себя от написания многих строк кода.


Время: 06:15