1、关于iOS设备上的摄像头
实现在摄像头上获取图像的方法:使用UIImagePickerController。这个视图控制器不使用storyboard生成,因此需要使用alloc、init方法手动建立。显示这个ViewController的方法需要调用presentViewController::animated:completion。执行步骤:①建立视图控制器实例,并设置代理;②配置(数据源、媒体类型、是否可编辑);③显示视图控制器;④完成获取图像后有代理的方法响应。
具体实现例子:
UIImagePickerControllerSourceType sourceType = UIImagePickerControllerSourceTypeCamera; //表示希望通过摄像头拍摄图像
if(![UIImagePickerController isSourceTypeAvailable:sourceType])//检测当前设备是否支持获取指定媒体类型的数据
{
sourceType = UIImagePickerControllerSourceTypePhotoLibrary;
}
UIImagePickerController *imagePickerController = [[UIImagePickerController alloc] init];//新建UIIPC实例
imagePickerController.delegate = self; // 设置委托为当前类
imagePickerController.sourceType = sourceType;//指定媒体类型
imagePickerController.allowsEditing = YES;//设置为可以编辑
[self presentViewController:imagePickerController animated:YES completion:nil]; //需要以模态的形式展示
[imagePickerController release];
拍摄(或读取)图像完成后,还需调用delegate方法执行后续操作:
#pragma mark -
#pragma mark UIImagePickerController Method
//完成拍照
-(void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info
{
[picker dismissViewControllerAnimated:YES completion:^{}];
UIImage *image = [info objectForKey:UIImagePickerControllerEditedImage];
if (image == nil)
image = [info objectForKey:UIImagePickerControllerOriginalImage];
[self performSelector:@selector(saveImage:) withObject:image];
}
//用户取消拍照
-(void)imagePickerControllerDidCancel:(UIImagePickerController *)picker
{
[picker dismissViewControllerAnimated:YES completion:nil];
}
//将照片保存到disk上
-(void)saveImage:(UIImage *)image
{
NSData *imageData = UIImagePNGRepresentation(image);
if(imageData == nil)
{
imageData = UIImageJPEGRepresentation(image, 1.0);
}
NSDate *date = [NSDate date];
NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
[formatter setDateFormat:@"yyyyMMddHHmmss"];
_fileName = [[[formatter stringFromDate:date] stringByAppendingPathExtension:@"png"] retain];
NSURL *saveURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:_fileName];
[imageData writeToURL:saveURL atomically:YES];
}
2、Core Motion简介
Core Motion代表了iOS设备中的陀螺仪等模块,其提供的API可以调用设备的动作传感器,检测当前设备的动作状态。实现该功能的类为CMMotionManager,该类同样适用alloc、init创建,但是一个app中只能有一个该类的实例。该对象可认为是一个全局资源。
适用方法:①检测硬件是否支持;②启动传感器获取数据;③检测是否正在获取数据;④停止传感器;
(1)加速度
//获取三维加速度
CMAccelerometerData *newestAccel = motionManager.accelerometerData;
double accelerationX = newestAccel.acceleration.x;
double accelerationY = newestAccel.acceleration.y;
double accelerationZ = newestAccel.acceleration.z;
(2)各个方向的重力以及设备倾斜角
double gravityX = motionManager.deviceMotion.gravity.x;
double gravityY = motionManager.deviceMotion.gravity.y;
double gravityZ = motionManager.deviceMotion.gravity.z;
double zTheta = atan2(gravityZ,sqrtf(gravityX*gravityX+gravityY*gravityY))/M_PI*180.0;//与水平面的角度
double xyTheta = atan2(gravityX,gravityY)/M_PI*180.0;//设备自身旋转的角度
(3)陀螺仪数据
角速度:
CMRotationRate rotationRate = motionManager.deviceMotion.rotationRate;
double rotationX = rotationRate.x;
double rotationY = rotationRate.y;
double rotationZ = rotationRate.z;
空间位置的欧拉角 double roll = motionManager.deviceMotion.attitude.roll;
double pitch = motionManager.deviceMotion.attitude.pitch;
double yaw = motionManager.deviceMotion.attitude.yaw;
空间位置的四元数
double w = motionManager.deviceMotion.attitude.quaternion.w;
double wx = motionManager.deviceMotion.attitude.quaternion.x;
double wy = motionManager.deviceMotion.attitude.quaternion.y;
double wz = motionManager.deviceMotion.attitude.quaternion.z;
3、应用的状态
当应用UI开始/停止接收消息时,应用的代理会分别调用以下方法:
- (void)applicationDidBecomeActive:(UIApplication *)sender;
- (void)applicationWillResignActive:(UIApplication *)sender;
同时将会发送两条广播消息:UIApplicationDidBecomeActiveNotification和UIApplicationWillResignActiveNotification。可以使用这两个消息用于暂停和重启应用。
当应用进入后台时/从后台重启时,会调用:
- (void)applicationDidEnterBackground:(UIApplication *)sender;
- (void)applicationWillEnterForgound:(UIApplication *)sender;
并发送UIApplicationDidEnterBackgroundNotification和UIApplicationWillEnterForgroundNotification。除此之外还有其他代理方法,如本地消息、UI恢复状态、数据保护、打开URL等。