Update ooo320-m1
[ooovba.git] / apple_remote / inc / RemoteControl.h
blobc73677568cd38bfc750ec2a1d374b4413e34e9c3
1 /*****************************************************************************
2 * RemoteControl.h
3 * RemoteControlWrapper
5 * Created by Martin Kahr on 11.03.06 under a MIT-style license.
6 * Copyright (c) 2006 martinkahr.com. All rights reserved.
8 * Code modified and adapted to OpenOffice.org
9 * by Eric Bachard on 11.08.2008 under the same License
11 * Permission is hereby granted, free of charge, to any person obtaining a
12 * copy of this software and associated documentation files (the "Software"),
13 * to deal in the Software without restriction, including without limitation
14 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
15 * and/or sell copies of the Software, and to permit persons to whom the
16 * Software is furnished to do so, subject to the following conditions:
18 * The above copyright notice and this permission notice shall be included
19 * in all copies or substantial portions of the Software.
21 * THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
24 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
26 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
27 * THE SOFTWARE.
29 *****************************************************************************/
31 #import <Cocoa/Cocoa.h>
33 // notifaction names that are being used to signal that an application wants to
34 // have access to the remote control device or if the application has finished
35 // using the remote control device
36 extern NSString* REQUEST_FOR_REMOTE_CONTROL_NOTIFCATION;
37 extern NSString* FINISHED_USING_REMOTE_CONTROL_NOTIFICATION;
39 // keys used in user objects for distributed notifications
40 extern NSString* kRemoteControlDeviceName;
41 extern NSString* kApplicationIdentifier;
42 extern NSString* kTargetApplicationIdentifier;
44 // we have a 6 bit offset to make a hold event out of a normal event
45 #define EVENT_TO_HOLD_EVENT_OFFSET 6
47 @class RemoteControl;
49 typedef enum _RemoteControlEventIdentifier {
50 // normal events
51 kRemoteButtonPlus =1<<1,
52 kRemoteButtonMinus =1<<2,
53 kRemoteButtonMenu =1<<3,
54 kRemoteButtonPlay =1<<4,
55 kRemoteButtonRight =1<<5,
56 kRemoteButtonLeft =1<<6,
58 // hold events
59 kRemoteButtonPlus_Hold =1<<7,
60 kRemoteButtonMinus_Hold =1<<8,
61 kRemoteButtonMenu_Hold =1<<9,
62 kRemoteButtonPlay_Hold =1<<10,
63 kRemoteButtonRight_Hold =1<<11,
64 kRemoteButtonLeft_Hold =1<<12,
66 // special events (not supported by all devices)
67 kRemoteControl_Switched =1<<13,
68 } RemoteControlEventIdentifier;
70 @interface NSObject(RemoteControlDelegate)
72 - (void) sendRemoteButtonEvent: (RemoteControlEventIdentifier) event pressedDown: (BOOL) pressedDown remoteControl: (RemoteControl*) remoteControl;
74 @end
77 Base Interface for Remote Control devices
79 @interface RemoteControl : NSObject {
80 id delegate;
83 // returns nil if the remote control device is not available
84 - (id) initWithDelegate: (id) remoteControlDelegate;
86 - (void) setListeningToRemote: (BOOL) value;
87 - (BOOL) isListeningToRemote;
89 - (BOOL) isOpenInExclusiveMode;
90 - (void) setOpenInExclusiveMode: (BOOL) value;
92 - (void) startListening: (id) sender;
93 - (void) stopListening: (id) sender;
95 // is this remote control sending the given event?
96 - (BOOL) sendsEventForButtonIdentifier: (RemoteControlEventIdentifier) identifier;
98 // sending of notifications between applications
99 + (void) sendFinishedNotifcationForAppIdentifier: (NSString*) identifier;
100 + (void) sendRequestForRemoteControlNotification;
102 // name of the device
103 + (const char*) remoteControlDeviceName;
105 @end