最新做的一个功能涉及到了视频的录制、压缩及上传。根据网上诸多大神的经验,终于算是调通了,但也发现了一些问题,所以把我的经验分享一下。

首先,肯定是调用一下系统的相机或相册

代码很基本:

//选择本地视频 
- (void)choosevideo 
{ 
 UIImagePickerController *ipc = [[UIImagePickerController alloc] init]; 
 ipc.sourceType = UIImagePickerControllerSourceTypePhotoLibrary;//sourcetype有三种分别是camera,photoLibrary和photoAlbum 
 NSArray *availableMedia = [UIImagePickerController availableMediaTypesForSourceType:UIImagePickerControllerSourceTypeCamera];//Camera所支持的Media格式都有哪些,共有两个分别是@"public.image",@"public.movie" 
 ipc.mediaTypes = [NSArray arrayWithObject:availableMedia[1]];//设置媒体类型为public.movie 
 [self presentViewController:ipc animated:YES completion:nil]; 
 ipc.delegate = self;//设置委托 
} 
//录制视频 
- (void)startvideo 
{ 
 UIImagePickerController *ipc = [[UIImagePickerController alloc] init]; 
 ipc.sourceType = UIImagePickerControllerSourceTypeCamera;//sourcetype有三种分别是camera,photoLibrary和photoAlbum 
 NSArray *availableMedia = [UIImagePickerController availableMediaTypesForSourceType:UIImagePickerControllerSourceTypeCamera];//Camera所支持的Media格式都有哪些,共有两个分别是@"public.image",@"public.movie" 
 ipc.mediaTypes = [NSArray arrayWithObject:availableMedia[1]];//设置媒体类型为public.movie 
 [self presentViewController:ipc animated:YES completion:nil]; 
 ipc.videoMaximumDuration = 30.0f;//30秒 
 ipc.delegate = self;//设置委托 
} 

iOS录制的视频格式是mov的,在Android和Pc上都不太好支持,所以要转换为MP4格式的,而且压缩一下,毕竟我们上传的都是小视频,不用特别清楚

为了反馈的清楚,先放两个小代码来获取视频的时长和大小,也是在网上找的,稍微改了一下。

- (CGFloat) getFileSize:(NSString *)path 
{ 
 NSLog(@"%@",path); 
 NSFileManager *fileManager = [NSFileManager defaultManager]; 
 float filesize = -1.0; 
 if ([fileManager fileExistsAtPath:path]) { 
  NSDictionary *fileDic = [fileManager attributesOfItemAtPath:path error:nil];//获取文件的属性 
  unsigned long long size = [[fileDic objectForKey:NSFileSize] longLongValue]; 
  filesize = 1.0*size/1024; 
 }else{ 
  NSLog(@"找不到文件"); 
 } 
 return filesize; 
}//此方法可以获取文件的大小,返回的是单位是KB。 
- (CGFloat) getVideoLength:(NSURL *)URL 
{ 
 AVURLAsset *avUrl = [AVURLAsset assetWithURL:URL]; 
 CMTime time = [avUrl duration]; 
 int second = ceil(time.value/time.timescale); 
 return second; 
}//此方法可以获取视频文件的时长。

 接收并压缩

//完成视频录制,并压缩后显示大小、时长 
- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info 
{ 
 NSURL *sourceURL = [info objectForKey:UIImagePickerControllerMediaURL]; 
 NSLog(@"%@",[NSString stringWithFormat:@"%f s", [self getVideoLength:sourceURL]]); 
 NSLog(@"%@", [NSString stringWithFormat:@"%.2f kb", [self getFileSize:[sourceURL path]]]); 
 NSURL *newVideoUrl ; //一般.mp4 
 NSDateFormatter *formater = [[NSDateFormatter alloc] init];//用时间给文件全名,以免重复,在测试的时候其实可以判断文件是否存在若存在,则删除,重新生成文件即可 
 [formater setDateFormat:@"yyyy-MM-dd-HH:mm:ss"]; 
 newVideoUrl = [NSURL fileURLWithPath:[NSHomeDirectory() stringByAppendingFormat:@"/Documents/output-%@.mp4", [formater stringFromDate:[NSDate date]]]] ;//这个是保存在app自己的沙盒路径里,后面可以选择是否在上传后删除掉。我建议删除掉,免得占空间。 
 [picker dismissViewControllerAnimated:YES completion:nil]; 
 [self convertVideoQuailtyWithInputURL:sourceURL outputURL:newVideoUrl completeHandler:nil]; 
} 
- (void) convertVideoQuailtyWithInputURL:(NSURL*)inputURL 
        outputURL:(NSURL*)outputURL 
       completeHandler:(void (^)(AVAssetExportSession*))handler 
{ 
 AVURLAsset *avAsset = [AVURLAsset URLAssetWithURL:inputURL options:nil]; 
  AVAssetExportSession *exportSession = [[AVAssetExportSession alloc] initWithAsset:avAsset presetName:AVAssetExportPresetMediumQuality]; 
  // NSLog(resultPath); 
  exportSession.outputURL = outputURL; 
  exportSession.outputFileType = AVFileTypeMPEG4; 
  exportSession.shouldOptimizeForNetworkUse= YES; 
  [exportSession exportAsynchronouslyWithCompletionHandler:^(void) 
   { 
    switch (exportSession.status) { 
     case AVAssetExportSessionStatusCancelled: 
      NSLog(@"AVAssetExportSessionStatusCancelled"); 
      break; 
     case AVAssetExportSessionStatusUnknown: 
      NSLog(@"AVAssetExportSessionStatusUnknown"); 
      break; 
     case AVAssetExportSessionStatusWaiting: 
      NSLog(@"AVAssetExportSessionStatusWaiting"); 
      break; 
     case AVAssetExportSessionStatusExporting: 
      NSLog(@"AVAssetExportSessionStatusExporting"); 
      break; 
     case AVAssetExportSessionStatusCompleted: 
      NSLog(@"AVAssetExportSessionStatusCompleted"); 
      NSLog(@"%@",[NSString stringWithFormat:@"%f s", [self getVideoLength:outputURL]]); 
      NSLog(@"%@", [NSString stringWithFormat:@"%.2f kb", [self getFileSize:[outputURL path]]]); 
      //UISaveVideoAtPathToSavedPhotosAlbum([outputURL path], self, nil, NULL);//这个是保存到手机相册 
      [self alertUploadVideo:outputURL]; 
      break; 
     case AVAssetExportSessionStatusFailed: 
      NSLog(@"AVAssetExportSessionStatusFailed"); 
      break; 
    } 
   }]; 
} 

我这里用了一个提醒,因为我的服务器比较弱,不能传太大的文件

-(void)alertUploadVideo:(NSURL*)URL{ 
 CGFloat size = [self getFileSize:[URL path]]; 
 NSString *message; 
 NSString *sizeString; 
 CGFloat sizemb= size/1024; 
 if(size<=1024){ 
  sizeString = [NSString stringWithFormat:@"%.2fKB",size]; 
 }else{ 
  sizeString = [NSString stringWithFormat:@"%.2fMB",sizemb]; 
 } 
 if(sizemb<2){ 
  [self uploadVideo:URL]; 
 } 
 else if(sizemb<=5){ 
  message = [NSString stringWithFormat:@"视频%@,大于2MB会有点慢,确定上传吗?", sizeString]; 
  UIAlertController * alertController = [UIAlertController alertControllerWithTitle: nil 
                     message: message 
                   preferredStyle:UIAlertControllerStyleAlert]; 
  [alertController addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) { 
   [[NSNotificationCenter defaultCenter] postNotificationName:@"refreshwebpages" object:nil userInfo:nil]; 
   [[NSFileManager defaultManager] removeItemAtPath:[URL path] error:nil];//取消之后就删除,以免占用手机硬盘空间(沙盒) 
  }]]; 
  [alertController addAction:[UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) { 
   [self uploadVideo:URL]; 
  }]]; 
  [self presentViewController:alertController animated:YES completion:nil]; 
 }else if(sizemb>5){ 
  message = [NSString stringWithFormat:@"视频%@,超过5MB,不能上传,抱歉。", sizeString]; 
  UIAlertController * alertController = [UIAlertController alertControllerWithTitle: nil 
                     message: message 
                   preferredStyle:UIAlertControllerStyleAlert]; 
  [alertController addAction:[UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) { 
   [[NSNotificationCenter defaultCenter] postNotificationName:@"refreshwebpages" object:nil userInfo:nil]; 
   [[NSFileManager defaultManager] removeItemAtPath:[URL path] error:nil];//取消之后就删除,以免占用手机硬盘空间 
  }]]; 
  [self presentViewController:alertController animated:YES completion:nil]; 
 } 
} 

最后上上传的代码,这个是根据服务器来的,而且还是用的MKNetworking,据说已经过时了,放上来大家参考一下吧,AFNet也差不多,就是把NSData传上去。

-(void)uploadVideo:(NSURL*)URL{ 
 //[MyTools showTipsWithNoDisappear:nil message:@"正在上传..."]; 
 NSData *data = [NSData dataWithContentsOfURL:URL]; 
 MKNetworkEngine *engine = [[MKNetworkEngine alloc] initWithHostName:@"www.ylhuakai.com" customHeaderFields:nil]; 
 NSMutableDictionary *dic = [[NSMutableDictionary alloc] init]; 
 NSString *updateURL; 
 updateURL = @"/alflower/Data/sendupdate"; 
 [dic setValue:[NSString stringWithFormat:@"%@",User_id] forKey:@"openid"]; 
 [dic setValue:[NSString stringWithFormat:@"%@",[self.web objectForKey:@"web_id"]] forKey:@"web_id"]; 
 [dic setValue:[NSString stringWithFormat:@"%i",insertnumber] forKey:@"number"]; 
 [dic setValue:[NSString stringWithFormat:@"%i",insertType] forKey:@"type"]; 
 MKNetworkOperation *op = [engine operationWithPath:updateURL params:dic httpMethod:@"POST"]; 
 [op addData:data forKey:@"video" mimeType:@"video/mpeg" fileName:@"aa.mp4"]; 
 [op addCompletionHandler:^(MKNetworkOperation *operation) { 
  NSLog(@"[operation responseData]-->>%@", [operation responseString]); 
  NSData *data = [operation responseData]; 
  NSDictionary *resweiboDict = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingAllowFragments error:nil]; 
  NSString *status = [[resweiboDict objectForKey:@"status"]stringValue]; 
  NSLog(@"addfriendlist status is %@", status); 
  NSString *info = [resweiboDict objectForKey:@"info"]; 
  NSLog(@"addfriendlist info is %@", info); 
  // [MyTools showTipsWithView:nil message:info]; 
  // [SVProgressHUD showErrorWithStatus:info]; 
  if ([status isEqualToString:@"1"]) 
  { 
   [[NSNotificationCenter defaultCenter] postNotificationName:@"refreshwebpages" object:nil userInfo:nil]; 
   [[NSFileManager defaultManager] removeItemAtPath:[URL path] error:nil];//上传之后就删除,以免占用手机硬盘空间; 
  }else 
  { 
   //[SVProgressHUD showErrorWithStatus:dic[@"info"]]; 
  } 
  // [[NSNotificationCenter defaultCenter] postNotificationName:@"StoryData" object:nil userInfo:nil]; 
 }errorHandler:^(MKNetworkOperation *errorOp, NSError* err) { 
  NSLog(@"MKNetwork request error : %@", [err localizedDescription]); 
 }]; 
 [engine enqueueOperation:op]; 
} 

以上所述是小编给大家介绍的iOS视频录制(或选择)压缩及上传功能(整理),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对Devmax网站的支持!

iOS视频录制(或选择)压缩及上传功能(整理)的更多相关文章

  1. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  2. HTML5在微信内置浏览器下右上角菜单的调整字体导致页面显示错乱的问题

    HTML5在微信内置浏览器下,在右上角菜单的调整字体导致页面显示错乱的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

  3. iOS实现拖拽View跟随手指浮动效果

    这篇文章主要为大家详细介绍了iOS实现拖拽View跟随手指浮动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  4. ios – containerURLForSecurityApplicationGroupIdentifier:在iPhone和Watch模拟器上给出不同的结果

    我使用默认的XCode模板创建了一个WatchKit应用程序.我向iOSTarget,WatchkitAppTarget和WatchkitAppExtensionTarget添加了应用程序组权利.(这是应用程序组名称:group.com.lombax.fiveminutes)然后,我尝试使用iOSApp和WatchKitExtension访问共享文件夹URL:延期:iOS应用:但是,测试NSURL

  5. ios – Testflight无法安装应用程序

    我有几个测试人员注册了testflight并连接了他们的设备……他们有不同的ios型号……但是所有这些都有同样的问题.当他们从“safari”或“testflight”应用程序本身单击应用程序的安装按钮时……达到约90%并出现错误消息…

  6. ibm-mobilefirst – 在iOS 7.1上获取“无法安装应用程序,因为证书无效”错误

    当我的客户端将他们的设备更新到iOS7.1,然后尝试从AppCenter更新我们的应用程序时,我收到了上述错误.经过一番搜索,我找到了一个类似问题的帖子here.但是后来因为我在客户端使用AppCenter更新应用程序的环境中,我无法使用USB插件并为他们安装应用程序.在发布支持之前,是否有通过AppCenter进行下载的解决方法?

  7. ios – 视图的简单拖放?

    我正在学习iOS,但我找不到如何向UIView添加拖放行为.我试过了:它说“UIView没有可见的接口声明选择器addTarget”此外,我尝试添加平移手势识别器,但不确定这是否是我需要的它被称为,但不知道如何获得事件的坐标.在iOS中注册移动事件回调/拖放操作的标准简单方法是什么?

  8. ios – 什么控制iTunes中iPhone应用程序支持的语言列表?

    什么控制iPhone应用程序的iTunes页面中支持的语言?

  9. ios – 获得APNs响应BadDeviceToken或Unregistered的可能原因是什么?

    我知道设备令牌在某些时候是有效的.用户如何使其设备令牌变坏?从关于“未注册”的文档:Thedevicetokenisinactiveforthespecifiedtopic.这是否意味着应用程序已被删除?.您应该看到四种分发方法:如果您选择AppStore或Enterprise,您将在后面的对话框中看到Xcode将APNS权利更改为生产:如果选择AdHoc或Development,则aps-environment下的文本将是开发,然后应与后端的配置匹配.

  10. ios – 当我关闭应用程序时,我从调试器获得消息:由于信号15而终止

    我怎么能解决这个问题,我不知道这个链接MypreviousproblemaboutCoredata对我的问题有影响吗?当我cmd应用程序的Q时,将出现此消息.Messagefromdebugger:Terminatedduetosignal15如果谁知道我以前的问题的解决方案,请告诉我.解决方法>来自调试器的消息:每当用户通过CMD-Q(退出)或STOP手动终止应用程序(无论是在iOS模拟器中还是

随机推荐

  1. iOS实现拖拽View跟随手指浮动效果

    这篇文章主要为大家详细介绍了iOS实现拖拽View跟随手指浮动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  2. iOS – genstrings:无法连接到输出目录en.lproj

    使用我桌面上的项目文件夹,我启动终端输入:cd然后将我的项目文件夹拖到终端,它给了我路径.然后我将这行代码粘贴到终端中找.-name*.m|xargsgenstrings-oen.lproj我在终端中收到此错误消息:genstrings:无法连接到输出目录en.lproj它多次打印这行,然后说我的项目是一个目录的路径?没有.strings文件.对我做错了什么的想法?

  3. iOS 7 UIButtonBarItem图像没有色调

    如何确保按钮图标采用全局色调?解决方法只是想将其转换为根注释,以便为“回答”复选标记提供更好的上下文,并提供更好的格式.我能想出这个!

  4. ios – 在自定义相机层的AVFoundation中自动对焦和自动曝光

    为AVFoundation定制图层相机创建精确的自动对焦和曝光的最佳方法是什么?

  5. ios – Xcode找不到Alamofire,错误:没有这样的模块’Alamofire’

    我正在尝试按照github(https://github.com/Alamofire/Alamofire#cocoapods)指令将Alamofire包含在我的Swift项目中.我创建了一个新项目,导航到项目目录并运行此命令sudogeminstallcocoapods.然后我面临以下错误:搜索后我设法通过运行此命令安装cocoapodssudogeminstall-n/usr/local/bin

  6. ios – 在没有iPhone6s或更新的情况下测试ARKit

    我在决定下载Xcode9之前.我想玩新的框架–ARKit.我知道要用ARKit运行app我需要一个带有A9芯片或更新版本的设备.不幸的是我有一个较旧的.我的问题是已经下载了新Xcode的人.在我的情况下有可能运行ARKit应用程序吗?那个或其他任何模拟器?任何想法或我将不得不购买新设备?解决方法任何iOS11设备都可以使用ARKit,但是具有高质量AR体验的全球跟踪功能需要使用A9或更高版本处理器的设备.使用iOS11测试版更新您的设备是必要的.

  7. 将iOS应用移植到Android

    我们制作了一个具有2000个目标c类的退出大型iOS应用程序.我想知道有一个最佳实践指南将其移植到Android?此外,由于我们的应用程序大量使用UINavigation和UIView控制器,我想知道在Android上有类似的模型和实现.谢谢到目前为止,guenter解决方法老实说,我认为你正在计划的只是制作难以维护的糟糕代码.我意识到这听起来像很多工作,但从长远来看它会更容易,我只是将应用程序的概念“移植”到android并从头开始编写.

  8. ios – 在Swift中覆盖Objective C类方法

    我是Swift的初学者,我正在尝试在Swift项目中使用JSONModel.我想从JSONModel覆盖方法keyMapper,但我没有找到如何覆盖模型类中的Objective-C类方法.该方法的签名是:我怎样才能做到这一点?解决方法您可以像覆盖实例方法一样执行此操作,但使用class关键字除外:

  9. ios – 在WKWebView中获取链接URL

    我想在WKWebView中获取tapped链接的url.链接采用自定义格式,可触发应用中的某些操作.例如HTTP://我的网站/帮助#深层链接对讲.我这样使用KVO:这在第一次点击链接时效果很好.但是,如果我连续两次点击相同的链接,它将不报告链接点击.是否有解决方法来解决这个问题,以便我可以检测每个点击并获取链接?任何关于这个的指针都会很棒!解决方法像这样更改addobserver在observeValue函数中,您可以获得两个值

  10. ios – 在Swift的UIView中找到UILabel

    我正在尝试在我的UIViewControllers的超级视图中找到我的UILabels.这是我的代码:这是在Objective-C中推荐的方式,但是在Swift中我只得到UIViews和CALayer.我肯定在提供给这个方法的视图中有UILabel.我错过了什么?我的UIViewController中的调用:解决方法使用函数式编程概念可以更轻松地实现这一目标.

返回
顶部