Нахавандипур Вандад
Шрифт:
Иными словами, блок должен принимать два параметра. Первый параметр должен относиться к типу CMAccelerometerData, второй — к типу NSError. Так мы и сделали в приведенном примере кода.
См. также
Раздел 18.1.
18.4. Обнаружение встряхивания устройства с iOS
Постановка задачи
Необходимо узнавать, когда пользователь встряхивает устройство с iOS.
Решение
Пользуйтесь методом motionEnded: withEvent:. Он может относиться к любому объекту вашего приложения, если этот объект принадлежит к типу UIResponder. Так, это могут быть контроллеры видов и даже объект основного окна.
Обсуждение
Метод motionEnded: withEvent: окна вашего приложения вызывается всякий раз, когда операционная система iOS фиксирует движение. Простейшая реализация этого метода такова:
Как видите, параметр motion относится к типу UIEventSubtype. Тип UIEventSubtype имеет, в частности, значение UIEventSubtypeMotionShake, которое нас и интересует. Зарегистрировав такое событие, мы можем быть уверены в том, что пользователь встряхнул устройство.
Далее переходим к реализации контроллера вида и обрабатываем метод motionEnded: withEvent::
Если теперь встряхнуть устройство или имитировать такое движение в эмуляторе iOS (см. введение к этой главе), в окне консоли мы увидим текст Detected a shake (Обнаружено встряхивание).
18.5. Получение данных гироскопа
Постановка задачи
Требуется получать информацию о движении устройства от гироскопа, установленного в устройстве с iOS.
Решение
Выполните следующие шаги.
1. Выясните, имеется ли в данном устройстве гироскоп. О том, как это делается, рассказано в разделе 18.2.
2. Если гироскоп в устройстве есть, проверьте, не посылает ли он уже уведомления. О том, как это делается, рассказано в разделе 18.2.
3. Воспользуйтесь методом экземпляра setGyroUpdateInterval:, относящимся к классу CMMotionManager, чтобы указать, сколько обновлений вы хотите получать в секунду. Например, если вы желаете получать 20 обновлений в секунду, задайте здесь значение 1.0/20.0.
4. Активизируйте метод экземпляра startGyroUpdatesToQueue: withHandler:, относящийся к классу CMMotionManager. Объект очереди может просто представлять собой главную операционную очередь (как мы увидим позже), а блок обработчика должен соответствовать формату CMGyroHandler.
Эти шаги реализуются в следующем коде: