Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

CMMotionManager and the Gyroscope on iPhone 4

I am trying to simply NSLog the output of the new iPhone 4 Gyroscope. But after reading the documentation and following their sample code I am getting this error.

ERROR,Time,300635803.946,Function,"CLLoggingSetFile",could not open locations log /var/mobile/Library/Caches/CoreMotion/CoreMotion.log

Even if I just setup my motionManager object with [[CMMotionManager alloc] init]; on its own and no other code, I still get the error.

Here is my .h file.

#import <UIKit/UIKit.h>
#import <CoreMotion/CoreMotion.h>

@interface GyroTest0ViewController : UIViewController {
    CMMotionManager *motionManager;
    NSOperationQueue *opQ;
}

@end

And here my .m file.

- (void)viewDidLoad {
    [super viewDidLoad];

    // the error occurs even just with this line on its own
    motionManager = [[CMMotionManager alloc] init]; 

    if (motionManager.gyroAvailable) {
        motionManager.gyroUpdateInterval = 1.0/60.0;
        [motionManager startGyroUpdates];
        opQ = [[NSOperationQueue currentQueue] retain];
        CMGyroHandler gyroHandler = ^ (CMGyroData *gyroData, NSError *error) {
            CMRotationRate rotate = gyroData.rotationRate;
            NSLog(@"rotation rate = [%f, %f, %f]", rotate.x, rotate.y, rotate.z);
        };
    } else {
        NSLog(@"No gyroscope on device.");
        [motionManager release];
    }
}

Any help and/or source code to simply log the iPhone 4 gyroscope data would be much appreciated. Many thanks!

like image 961
James Beith Avatar asked Jul 12 '10 14:07

James Beith


2 Answers

Try this,

    motionManager.gyroUpdateInterval = 1.0/60.0;
    [motionManager startGyroUpdatesToQueue:[NSOperationQueue currentQueue]
                               withHandler: ^(CMGyroData *gyroData, NSError *error)
                                            {
                                                CMRotationRate rotate = gyroData.rotationRate;
                                                NSLog(@"rotation rate = [%f, %f, %f]", rotate.x, rotate.y, rotate.z);
                                            }];
like image 131
Joshua Weinberg Avatar answered Sep 17 '22 13:09

Joshua Weinberg


For the WWDC sample code:

  • Log in to ADC
  • Click on WWDC 2010 session videos
  • View in iTunes
  • There you find the link to sample code (230 MB)
like image 21
Kay Avatar answered Sep 20 '22 13:09

Kay