mirror of https://github.com/axmolengine/axmol.git
commit
ab470ad76d
|
@ -49,11 +49,6 @@ class CC_DLL CCAccelerometerDelegate
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual void didAccelerate(CCAcceleration* pAccelerationValue) {CC_UNUSED_PARAM(pAccelerationValue);}
|
virtual void didAccelerate(CCAcceleration* pAccelerationValue) {CC_UNUSED_PARAM(pAccelerationValue);}
|
||||||
|
|
||||||
//! call the release() in child layer
|
|
||||||
virtual void AccelerometerDestroy(void) {}
|
|
||||||
//! call the retain() in child layer
|
|
||||||
virtual void AccelerometerKeep(void) {}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} //namespace cocos2d
|
} //namespace cocos2d
|
||||||
|
|
|
@ -67,8 +67,6 @@ public:
|
||||||
virtual void keep(void);
|
virtual void keep(void);
|
||||||
|
|
||||||
virtual void didAccelerate(CCAcceleration* pAccelerationValue) {CC_UNUSED_PARAM(pAccelerationValue);}
|
virtual void didAccelerate(CCAcceleration* pAccelerationValue) {CC_UNUSED_PARAM(pAccelerationValue);}
|
||||||
virtual void AccelerometerDestroy(void);
|
|
||||||
virtual void AccelerometerKeep(void);
|
|
||||||
|
|
||||||
virtual void KeypadDestroy();
|
virtual void KeypadDestroy();
|
||||||
virtual void KeypadKeep();
|
virtual void KeypadKeep();
|
||||||
|
|
|
@ -96,16 +96,6 @@ void CCLayer::keep(void)
|
||||||
this->retain();
|
this->retain();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CCLayer::AccelerometerDestroy(void)
|
|
||||||
{
|
|
||||||
this->release();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CCLayer::AccelerometerKeep(void)
|
|
||||||
{
|
|
||||||
this->retain();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CCLayer::KeypadDestroy()
|
void CCLayer::KeypadDestroy()
|
||||||
{
|
{
|
||||||
this->release();
|
this->release();
|
||||||
|
|
|
@ -34,18 +34,17 @@ namespace cocos2d
|
||||||
{
|
{
|
||||||
CCAccelerometer* CCAccelerometer::m_spCCAccelerometer = NULL;
|
CCAccelerometer* CCAccelerometer::m_spCCAccelerometer = NULL;
|
||||||
|
|
||||||
CCAccelerometer::CCAccelerometer() {
|
CCAccelerometer::CCAccelerometer() : m_pAccelDelegate(NULL)
|
||||||
m_pAccelDelegates = new std::list<CCAccelerometerDelegate*>();
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
CCAccelerometer::~CCAccelerometer() {
|
CCAccelerometer::~CCAccelerometer()
|
||||||
if ( m_pAccelDelegates ) {
|
{
|
||||||
delete m_pAccelDelegates;
|
m_spCCAccelerometer = NULL;
|
||||||
m_pAccelDelegates = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CCAccelerometer* CCAccelerometer::sharedAccelerometer() {
|
CCAccelerometer* CCAccelerometer::sharedAccelerometer()
|
||||||
|
{
|
||||||
|
|
||||||
if (m_spCCAccelerometer == NULL)
|
if (m_spCCAccelerometer == NULL)
|
||||||
{
|
{
|
||||||
|
@ -55,34 +54,25 @@ namespace cocos2d
|
||||||
return m_spCCAccelerometer;
|
return m_spCCAccelerometer;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CCAccelerometer::removeDelegate(CCAccelerometerDelegate* pDelegate) {
|
void CCAccelerometer::removeDelegate(CCAccelerometerDelegate* pDelegate)
|
||||||
m_pAccelDelegates->remove(pDelegate);
|
{
|
||||||
|
disableAccelerometerJNI();
|
||||||
if ( 0 == m_pAccelDelegates->size() ) {
|
|
||||||
disableAccelerometerJNI();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CCAccelerometer::addDelegate(CCAccelerometerDelegate* pDelegate) {
|
void CCAccelerometer::addDelegate(CCAccelerometerDelegate* pDelegate)
|
||||||
if ( 0 == m_pAccelDelegates->size() ) {
|
{
|
||||||
enableAccelerometerJNI();
|
m_pAccelDelegate = pDelegate;
|
||||||
}
|
enableAccelerometerJNI();
|
||||||
|
|
||||||
m_pAccelDelegates->push_front(pDelegate);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CCAccelerometer::update(float x, float y, float z, long sensorTimeStamp) {
|
void CCAccelerometer::update(float x, float y, float z, long sensorTimeStamp)
|
||||||
if ( m_pAccelDelegates != NULL && !m_pAccelDelegates->empty() ) {
|
{
|
||||||
m_obAccelerationValue.x = -((double)x / TG3_GRAVITY_EARTH);
|
m_obAccelerationValue.x = -((double)x / TG3_GRAVITY_EARTH);
|
||||||
m_obAccelerationValue.y = -((double)y / TG3_GRAVITY_EARTH);
|
m_obAccelerationValue.y = -((double)y / TG3_GRAVITY_EARTH);
|
||||||
m_obAccelerationValue.z = -((double)z / TG3_GRAVITY_EARTH);
|
m_obAccelerationValue.z = -((double)z / TG3_GRAVITY_EARTH);
|
||||||
m_obAccelerationValue.timestamp = (double)sensorTimeStamp;
|
m_obAccelerationValue.timestamp = (double)sensorTimeStamp;
|
||||||
|
|
||||||
for(std::list<CCAccelerometerDelegate*>::const_iterator it = m_pAccelDelegates->begin(); it != m_pAccelDelegates->end(); ++it)
|
m_pAccelDelegate->didAccelerate(&m_obAccelerationValue);
|
||||||
{
|
|
||||||
(*it)->didAccelerate(&m_obAccelerationValue);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} // end of namespace cococs2d
|
} // end of namespace cococs2d
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,6 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "CCCommon.h"
|
#include "CCCommon.h"
|
||||||
#include "CCAccelerometerDelegate.h"
|
#include "CCAccelerometerDelegate.h"
|
||||||
#include <list>
|
|
||||||
|
|
||||||
namespace cocos2d {
|
namespace cocos2d {
|
||||||
|
|
||||||
|
@ -45,7 +44,7 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static CCAccelerometer* m_spCCAccelerometer;
|
static CCAccelerometer* m_spCCAccelerometer;
|
||||||
std::list<CCAccelerometerDelegate*>* m_pAccelDelegates;
|
CCAccelerometerDelegate* m_pAccelDelegate;
|
||||||
CCAcceleration m_obAccelerationValue;
|
CCAcceleration m_obAccelerationValue;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -28,10 +28,12 @@
|
||||||
|
|
||||||
@interface AccelerometerDispatcher : NSObject<UIAccelerometerDelegate>
|
@interface AccelerometerDispatcher : NSObject<UIAccelerometerDelegate>
|
||||||
{
|
{
|
||||||
NSMutableArray *delegateWrappers;
|
cocos2d::CCAccelerometerDelegate *delegate_;
|
||||||
|
cocos2d::CCAcceleration *acceleration_;
|
||||||
}
|
}
|
||||||
|
|
||||||
@property(readwrite, retain) NSMutableArray* delegateWrappers;
|
@property(readwrite) cocos2d::CCAccelerometerDelegate *delegate_;
|
||||||
|
@property(readwrite) cocos2d::CCAcceleration *acceleration_;
|
||||||
|
|
||||||
+ (id) sharedAccelerometerDispather;
|
+ (id) sharedAccelerometerDispather;
|
||||||
- (id) init;
|
- (id) init;
|
||||||
|
@ -39,16 +41,3 @@
|
||||||
- (void) removeDelegate: (cocos2d::CCAccelerometerDelegate *) delegate;
|
- (void) removeDelegate: (cocos2d::CCAccelerometerDelegate *) delegate;
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
|
||||||
@interface AccelerometerDelegateWrapper : NSObject {
|
|
||||||
cocos2d::CCAccelerometerDelegate *delegate_;
|
|
||||||
}
|
|
||||||
|
|
||||||
@property(readwrite) cocos2d::CCAccelerometerDelegate *delegate_;
|
|
||||||
|
|
||||||
+ (id) delegateWrapperWithDelegate:(cocos2d::CCAccelerometerDelegate *)delegate;
|
|
||||||
- (id) initWithDelegate: (cocos2d::CCAccelerometerDelegate *)delegate;
|
|
||||||
- (void) didAccelerate: (cocos2d::CCAcceleration *)acceleration;
|
|
||||||
|
|
||||||
@end
|
|
||||||
|
|
|
@ -28,7 +28,8 @@
|
||||||
|
|
||||||
static AccelerometerDispatcher* s_pAccelerometerDispatcher;
|
static AccelerometerDispatcher* s_pAccelerometerDispatcher;
|
||||||
|
|
||||||
@synthesize delegateWrappers;
|
@synthesize delegate_;
|
||||||
|
@synthesize acceleration_;
|
||||||
|
|
||||||
+ (id) sharedAccelerometerDispather
|
+ (id) sharedAccelerometerDispather
|
||||||
{
|
{
|
||||||
|
@ -41,107 +42,62 @@ static AccelerometerDispatcher* s_pAccelerometerDispatcher;
|
||||||
|
|
||||||
- (id) init
|
- (id) init
|
||||||
{
|
{
|
||||||
self.delegateWrappers = [NSMutableArray arrayWithCapacity:4];
|
acceleration_ = new cocos2d::CCAcceleration();
|
||||||
[[UIAccelerometer sharedAccelerometer] setDelegate: self];
|
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void) dealloc
|
- (void) dealloc
|
||||||
{
|
{
|
||||||
[[UIAccelerometer sharedAccelerometer] setDelegate: nil];
|
s_pAccelerometerDispatcher = 0;
|
||||||
[delegateWrappers release];
|
delegate_ = 0;
|
||||||
|
delete acceleration_;
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (id) findDelegateWrapperByDelegate: (cocos2d::CCAccelerometerDelegate *) delegate
|
|
||||||
{
|
|
||||||
for (AccelerometerDelegateWrapper *wrapper in delegateWrappers) {
|
|
||||||
if (wrapper.delegate_ == delegate) {
|
|
||||||
return wrapper;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void) addDelegate: (cocos2d::CCAccelerometerDelegate *) delegate
|
- (void) addDelegate: (cocos2d::CCAccelerometerDelegate *) delegate
|
||||||
{
|
{
|
||||||
[delegateWrappers addObject: [AccelerometerDelegateWrapper delegateWrapperWithDelegate:delegate]];
|
[[UIAccelerometer sharedAccelerometer] setDelegate:self];
|
||||||
|
delegate_ = delegate;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void) removeDelegate: (cocos2d::CCAccelerometerDelegate *) delegate
|
- (void) removeDelegate: (cocos2d::CCAccelerometerDelegate *) delegate
|
||||||
{
|
{
|
||||||
[delegateWrappers removeObject:[self findDelegateWrapperByDelegate:delegate]];
|
[[UIAccelerometer sharedAccelerometer] setDelegate:nil];
|
||||||
|
delegate_ = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)accelerometer:(UIAccelerometer *)accelerometer didAccelerate:(UIAcceleration *)acceleration
|
- (void)accelerometer:(UIAccelerometer *)accelerometer didAccelerate:(UIAcceleration *)acceleration
|
||||||
{
|
{
|
||||||
cocos2d::CCAcceleration accelerationCpp;
|
acceleration_->x = acceleration.x;
|
||||||
|
acceleration_->y = acceleration.y;
|
||||||
|
acceleration_->z = acceleration.z;
|
||||||
|
acceleration_->timestamp = acceleration.timestamp;
|
||||||
|
|
||||||
accelerationCpp.x = acceleration.x;
|
double tmp = acceleration_->x;
|
||||||
accelerationCpp.y = acceleration.y;
|
|
||||||
accelerationCpp.z = acceleration.z;
|
|
||||||
accelerationCpp.timestamp = acceleration.timestamp;
|
|
||||||
|
|
||||||
double tmp = accelerationCpp.x;
|
|
||||||
|
|
||||||
switch ([[UIApplication sharedApplication] statusBarOrientation])
|
switch ([[UIApplication sharedApplication] statusBarOrientation])
|
||||||
{
|
{
|
||||||
case UIInterfaceOrientationLandscapeRight:
|
case UIInterfaceOrientationLandscapeRight:
|
||||||
accelerationCpp.x = -acceleration.y;
|
acceleration_->x = -acceleration_->y;
|
||||||
accelerationCpp.y = tmp;
|
acceleration_->y = tmp;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case UIInterfaceOrientationLandscapeLeft:
|
case UIInterfaceOrientationLandscapeLeft:
|
||||||
accelerationCpp.x = acceleration.y;
|
acceleration_->x = acceleration_->y;
|
||||||
accelerationCpp.y = -tmp;
|
acceleration_->y = -tmp;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case UIInterfaceOrientationPortraitUpsideDown:
|
case UIInterfaceOrientationPortraitUpsideDown:
|
||||||
accelerationCpp.x = -accelerationCpp.y;
|
acceleration_->x = -acceleration_->y;
|
||||||
accelerationCpp.y = -tmp;
|
acceleration_->y = -tmp;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case UIInterfaceOrientationPortrait:
|
case UIInterfaceOrientationPortrait:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (AccelerometerDelegateWrapper *wrapper in delegateWrappers) {
|
delegate_->didAccelerate(acceleration_);
|
||||||
[wrapper didAccelerate: &accelerationCpp];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
|
||||||
@implementation AccelerometerDelegateWrapper
|
|
||||||
|
|
||||||
@synthesize delegate_;
|
|
||||||
|
|
||||||
+ (id)delegateWrapperWithDelegate:(cocos2d::CCAccelerometerDelegate *)delegate
|
|
||||||
{
|
|
||||||
return [[self alloc] initWithDelegate: delegate];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (id) initWithDelegate: (cocos2d::CCAccelerometerDelegate *)delegate
|
|
||||||
{
|
|
||||||
delegate->AccelerometerKeep();
|
|
||||||
self.delegate_ = delegate;
|
|
||||||
|
|
||||||
return self;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void) didAccelerate: (cocos2d::CCAcceleration *)acceleration
|
|
||||||
{
|
|
||||||
self.delegate_->didAccelerate(acceleration);
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void) dealloc
|
|
||||||
{
|
|
||||||
self.delegate_->AccelerometerDestroy();
|
|
||||||
|
|
||||||
[super dealloc];
|
|
||||||
}
|
|
||||||
|
|
||||||
@end
|
|
||||||
|
|
|
@ -27,72 +27,13 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "TCOM_Generic_Method_IIDs.h"
|
#include "TCOM_Generic_Method_IIDs.h"
|
||||||
|
|
||||||
//Ö»ÄÜ°üº¬Ò»´Î
|
// Can only include once
|
||||||
#include "TCOM_Sensors_IIDs.h"
|
#include "TCOM_Sensors_IIDs.h"
|
||||||
|
|
||||||
namespace cocos2d {
|
namespace cocos2d {
|
||||||
|
|
||||||
static CCAccelerometer s_Accelerometer;
|
static CCAccelerometer s_Accelerometer;
|
||||||
|
|
||||||
//------------------------------------------------------------------
|
|
||||||
//
|
|
||||||
// CCAccelerometerHandler
|
|
||||||
//
|
|
||||||
//------------------------------------------------------------------
|
|
||||||
CCAccelerometerDelegate* CCAccelerometerHandler::getDelegate()
|
|
||||||
{
|
|
||||||
return m_pDelegate;
|
|
||||||
}
|
|
||||||
|
|
||||||
CCAccelerometerHandler::~CCAccelerometerHandler()
|
|
||||||
{
|
|
||||||
m_pDelegate->AccelerometerDestroy();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CCAccelerometerHandler::setDelegate(CCAccelerometerDelegate *pDelegate)
|
|
||||||
{
|
|
||||||
if (pDelegate)
|
|
||||||
{
|
|
||||||
pDelegate->AccelerometerKeep();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_pDelegate)
|
|
||||||
{
|
|
||||||
m_pDelegate->AccelerometerDestroy();
|
|
||||||
}
|
|
||||||
m_pDelegate = pDelegate;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool CCAccelerometerHandler::initWithDelegate(CCAccelerometerDelegate *pDelegate)
|
|
||||||
{
|
|
||||||
assert(pDelegate != NULL);
|
|
||||||
|
|
||||||
m_pDelegate = pDelegate;
|
|
||||||
pDelegate->AccelerometerKeep();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
CCAccelerometerHandler* CCAccelerometerHandler::handlerWithDelegate(CCAccelerometerDelegate *pDelegate)
|
|
||||||
{
|
|
||||||
CCAccelerometerHandler* pHandler = new CCAccelerometerHandler;
|
|
||||||
|
|
||||||
if (pHandler)
|
|
||||||
{
|
|
||||||
if (pHandler->initWithDelegate(pDelegate))
|
|
||||||
{
|
|
||||||
pHandler->autorelease();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
CC_SAFE_RELEASE_NULL(pHandler);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return pHandler;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
// CCAccelerometer
|
// CCAccelerometer
|
||||||
|
@ -100,19 +41,19 @@ CCAccelerometerHandler* CCAccelerometerHandler::handlerWithDelegate(CCAccelerome
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
CCAccelerometer::CCAccelerometer()
|
CCAccelerometer::CCAccelerometer()
|
||||||
: m_pSensor(NULL)
|
: m_pSensor(NULL)
|
||||||
|
, m_pDelegate(NULL)
|
||||||
{
|
{
|
||||||
m_pDelegates = new AccDelegateArray;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CCAccelerometer::~CCAccelerometer()
|
CCAccelerometer::~CCAccelerometer()
|
||||||
{
|
{
|
||||||
m_pDelegates->release();
|
|
||||||
|
|
||||||
if (m_pSensor)
|
if (m_pSensor)
|
||||||
{
|
{
|
||||||
m_pSensor->Release();
|
m_pSensor->Release();
|
||||||
m_pSensor = NULL;
|
m_pSensor = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_pDelegate = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
CCAccelerometer* CCAccelerometer::sharedAccelerometer()
|
CCAccelerometer* CCAccelerometer::sharedAccelerometer()
|
||||||
|
@ -122,90 +63,37 @@ CCAccelerometer* CCAccelerometer::sharedAccelerometer()
|
||||||
|
|
||||||
void CCAccelerometer::removeDelegate(CCAccelerometerDelegate* pDelegate)
|
void CCAccelerometer::removeDelegate(CCAccelerometerDelegate* pDelegate)
|
||||||
{
|
{
|
||||||
CCAccelerometerHandler *pHandler;
|
m_pDelegate = NULL;
|
||||||
CCMutableArray<CCAccelerometerHandler*>::CCMutableArrayIterator iter;
|
|
||||||
|
|
||||||
if (pDelegate)
|
m_pSensor->Release();
|
||||||
{
|
m_pSensor = NULL;
|
||||||
for (iter = m_pDelegates->begin(); iter != m_pDelegates->end(); ++iter)
|
|
||||||
{
|
|
||||||
pHandler = *iter;
|
|
||||||
if (pHandler && pHandler->getDelegate() == pDelegate)
|
|
||||||
{
|
|
||||||
m_pDelegates->removeObject(pHandler);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (0 == m_pDelegates->count())
|
|
||||||
{
|
|
||||||
m_pSensor->Release();
|
|
||||||
m_pSensor = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CCAccelerometer::addDelegate(CCAccelerometerDelegate* pDelegate)
|
void CCAccelerometer::addDelegate(CCAccelerometerDelegate* pDelegate)
|
||||||
{
|
{
|
||||||
CCAccelerometerHandler *pHandlerIter;
|
m_pDelegate = pDelegate;
|
||||||
CCMutableArray<CCAccelerometerHandler*>::CCMutableArrayIterator iter;
|
|
||||||
|
|
||||||
if (pDelegate)
|
m_pSensor = TCOM_Sensors_DataType_Client::GetInstance();
|
||||||
{
|
|
||||||
for (iter = m_pDelegates->begin(); iter != m_pDelegates->end(); ++iter)
|
|
||||||
{
|
|
||||||
pHandlerIter = *iter;
|
|
||||||
if (pHandlerIter && pHandlerIter->getDelegate() == pDelegate)
|
|
||||||
{
|
|
||||||
// this delegate have existed
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
CCAccelerometerHandler* pHandler = CCAccelerometerHandler::handlerWithDelegate(pDelegate);
|
if (m_pSensor)
|
||||||
|
{
|
||||||
|
m_pSensor->StartUp();
|
||||||
|
m_pSensor->SetDelay(TG3_SENSOR_DELAY_FASTEST);
|
||||||
|
|
||||||
if (pHandler)
|
TApplication* pApp = TApplication::GetCurrentApplication();
|
||||||
{
|
TWindow* pWnd = pApp->GetActiveWindow();
|
||||||
m_pDelegates->addObject(pHandler);
|
m_pSensor->SetWindowCtrlId(pWnd->GetWindowHwndId(), 0);
|
||||||
|
m_pSensor->Activate(TG3_SENSOR_TYPE_ACCELEROMETER, TRUE);
|
||||||
if (!m_pSensor)
|
}
|
||||||
{
|
else
|
||||||
m_pSensor = TCOM_Sensors_DataType_Client::GetInstance();
|
{
|
||||||
|
CCLOG("cocos2d: The Accelerometer Sensor Open failed");
|
||||||
if (m_pSensor)
|
}
|
||||||
{
|
|
||||||
m_pSensor->StartUp();
|
|
||||||
m_pSensor->SetDelay(TG3_SENSOR_DELAY_FASTEST);
|
|
||||||
|
|
||||||
TApplication* pApp = TApplication::GetCurrentApplication();
|
|
||||||
TWindow* pWnd = pApp->GetActiveWindow();
|
|
||||||
m_pSensor->SetWindowCtrlId(pWnd->GetWindowHwndId(), 0);
|
|
||||||
m_pSensor->Activate(TG3_SENSOR_TYPE_ACCELEROMETER, TRUE);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
CCLOG("cocos2d: The Accelerometer Sensor Open failed");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CCAccelerometer::didAccelerate(CCAcceleration* pAccelerationValue)
|
void CCAccelerometer::didAccelerate(CCAcceleration* pAccelerationValue)
|
||||||
{
|
{
|
||||||
CCAccelerometerHandler *pHandler;
|
m_pDelegate->didAccelerate(pAccelerationValue);
|
||||||
CCAccelerometerDelegate *pDelegate;
|
|
||||||
CCMutableArray<CCAccelerometerHandler*>::CCMutableArrayIterator iter;
|
|
||||||
|
|
||||||
if (m_pDelegates->count() > 0)
|
|
||||||
{
|
|
||||||
for (iter = m_pDelegates->begin(); iter != m_pDelegates->end(); ++iter)
|
|
||||||
{
|
|
||||||
pHandler = *iter;
|
|
||||||
pDelegate = pHandler->getDelegate();
|
|
||||||
pDelegate->didAccelerate(pAccelerationValue);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}//namespace cocos2d
|
}//namespace cocos2d
|
||||||
|
|
|
@ -27,37 +27,11 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "CCAccelerometerDelegate.h"
|
#include "CCAccelerometerDelegate.h"
|
||||||
#include "TG3.h"
|
#include "TG3.h"
|
||||||
#include "CCMutableArray.h"
|
|
||||||
#include "CCCommon.h"
|
#include "CCCommon.h"
|
||||||
#include "TCOM_Sensors_Interface.h"
|
#include "TCOM_Sensors_Interface.h"
|
||||||
|
|
||||||
namespace cocos2d {
|
namespace cocos2d {
|
||||||
|
|
||||||
/**
|
|
||||||
@brief
|
|
||||||
CCAccelerometerHandler
|
|
||||||
Object than contains the CCAccelerometerDelegate.
|
|
||||||
*/
|
|
||||||
class CC_DLL CCAccelerometerHandler : public CCObject
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
virtual ~CCAccelerometerHandler(void);
|
|
||||||
|
|
||||||
/** delegate */
|
|
||||||
CCAccelerometerDelegate* getDelegate();
|
|
||||||
void setDelegate(CCAccelerometerDelegate *pDelegate);
|
|
||||||
|
|
||||||
/** initializes a CCAccelerometerHandler with a delegate */
|
|
||||||
virtual bool initWithDelegate(CCAccelerometerDelegate *pDelegate);
|
|
||||||
|
|
||||||
public:
|
|
||||||
/** allocates a AccelerometerHandler with a delegate */
|
|
||||||
static CCAccelerometerHandler* handlerWithDelegate(CCAccelerometerDelegate *pDelegate);
|
|
||||||
|
|
||||||
protected:
|
|
||||||
CCAccelerometerDelegate* m_pDelegate;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@brief
|
@brief
|
||||||
The CCAccelerometer class lets you register to receive
|
The CCAccelerometer class lets you register to receive
|
||||||
|
@ -90,9 +64,7 @@ public:
|
||||||
void didAccelerate(CCAcceleration* pAccelerationValue);
|
void didAccelerate(CCAcceleration* pAccelerationValue);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
typedef CCMutableArray<CCAccelerometerHandler*> AccDelegateArray;
|
CCAccelerometerDelegate* m_pDelegate;
|
||||||
|
|
||||||
AccDelegateArray* m_pDelegates;
|
|
||||||
TCOM_Sensors_DataType_Client* m_pSensor;
|
TCOM_Sensors_DataType_Client* m_pSensor;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue