James Beith
James Beith

Reputation: 5761

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!

Upvotes: 8

Views: 22864

Answers (3)

Kay
Kay

Reputation: 13146

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)

Upvotes: 3

Kay
Kay

Reputation: 13146

Any results regarding this issue? I get the same error even when I use WWDC teapot demo code. I filed a bug report (8382659).

By the way I get the same error when I use the push method described by Joshua Weinberg.

Update: Apple confirmed the bug but referred to a duplicate issue 8173937 that I can't find. Well let's hope that it will be fixed in the next release.

Upvotes: 2

Joshua Weinberg
Joshua Weinberg

Reputation: 28688

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);
                                            }];

Upvotes: 8

Related Questions