如何在iPhone6s以下苹果6s设备管理找不到上使用LivePhoto

无需iPhone6s/6s Plus 新浪微博更新支持live photo
Livephoto是iPhone 6s/6s Plus中独有的功能,它可在拍照前后录制一段1.5秒的动态视频,当用户重按屏幕时可显示动态效果,不过目前只有6s用户能够拍摄。几天前新浪微博升级至V5.7版本,正式支持发送Livephoto图片,不仅如此,没有6s的用户也能查看Livephoto图片了!
在Livephoto图片右下角将显示&LIVE&字样,点击查看时图片是自动播放的与Gif类似,且带有声音,不过图片不支持重复播放,想看第二遍需长按图片。目前仅有新浪微博与Facebook支持Livephoto功能,用户可前往查看并下载心仪的图片作为壁纸使用。
注:查看Livephoto图片需运行iOS 9及以上系统版本。
您可能也感兴趣:
春节假期转瞬即逝,大家在这几天的假期中感受到了亲朋好友的问候以及家的温暖,但是我们即将...
官方微博/微信
每日头条、业界资讯、热点资讯、八卦爆料,全天跟踪微博播报。各种爆料、内幕、花边、资讯一网打尽。百万互联网粉丝互动参与,TechWeb官方微博期待您的关注。
↑扫描二维码
想在手机上看科技资讯和科技八卦吗?想第一时间看独家爆料和深度报道吗?请关注TechWeb官方微信公众帐号:1.用手机扫左侧二维码;2.在添加朋友里,搜索关注TechWeb。
Copyright (C)
All rights reserved. 京ICP证060517号/京ICP备号 京公网安备76号
TechWeb公众号
机情秀公众号1824人阅读
事情的经过是这样的:昨晚,一个朋友问我怎么越狱,我说越狱干嘛,他说他想用LivePhoto功能,但是他的手机是iPhone6,没有这个功能,说是越狱后装一个插件就可以。听完后,我说最好不要越狱,虽然可以用一些插件,但是手机里面信息的安全性非常差,说不定别人插件后台开个什么线程你也不知道,就好像你家里装了门,你还在门上开个洞,谁想来都可以。做为一名iOS程序猿,我觉得苹果如今开源性很强,很多功能都是可以实现的。于是,我很装逼的说,
我说你等着,明天上班我给你做一个。
今早一到办公室就开始查资料,说到LivePhoto就不得不提MOV,这两个都是苹果开发的格式,LivePhoto其实就是一个JPG加上一个MOV,只不过这个MOV里面写入了一些元数据,能让相册正确的识别。对应iOS中的框架是ImageIO/MobileCoreServices/Photos/AVFoundation&等。
下面附上资料,文中有很详细的解释,也有Demo地址,相信大家仔细看下就会明白的,毕竟,Talk is cheap, show me the code~
GIF/MOV/Live Photo
这次这篇文章来谈谈&GIF/MOV/Live Photo&两两之间的格式转换,这个需求来自于我最近在做的一个小项目,里面提供了类似的功能。
这三个格式有一个共同点,他们都可以由一个连续的图片序列得到。其中 MOV 和 Live Photo 都是苹果开发的格式,更进一步的讲 Live Photo 其实是一个 JPG 加上一个 MOV,只不过这个 MOV 里面写入了一些元数据,能让相册正确的识别。本文涉及到的核心框架有:ImageIO/MobileCoreServices/Photos/AVFoundation&等。
# GIF -& MOV
顾名思义,将 GIF 文件 decode 成 image array 和 duration array 的过程,通过&ImageIO Framework&去做,当然我这里还是会推荐 ibireme 的&,他已经做了大部分的工作。我们在显示了
imageView 之余可以使用:
- (UIImage *)animatedImageFrameAtIndex:(NSUInteger)index;
- (NSTimeInterval)animatedImageDurationAtIndex:(NSUInteger)index;
这两个代理方法得到图片和时间的数组,接下来就是把它通过 AVFoundation 框架写到一个 MOV 文件里面去。有这么几步:创建 AVAssetWriter 和 AVAssetWriterInput,然后使用 WriterInput 的这个方法:
- (void)requestMediaDataWhenReadyOnQueue:(dispatch_queue_t)queue usingBlock:(void (^)(void))block;
在这个 queue 中遍历 decode 出来的 image 列表,将 image 转换成 CVPixelBufferRef,并将 durations 里面的时间间隔转换成 CMTime,然后写进去:
[self.writerInput requestMediaDataWhenReadyOnQueue:mediaInputQueue usingBlock:^{
CMTime presentationTime = kCMTimeZero;
while (YES) {
if (index &= frameCount) {
if ([self.writerInput isReadyForMoreMediaData]) {
@autoreleasepool {
UIImage *image = images[index];
CVPixelBufferRef buffer = [self newPixelBufferFromCGImage:image.CGImage];
if (buffer) {
double scale = averageScale;
if (index & durations.count) {
scale = 1.0 / [durations[index] doubleValue];
[self.bufferAdapter appendPixelBuffer:buffer withPresentationTime:presentationTime];
presentationTime = CMTimeAdd(presentationTime, CMTimeMake(1, scale));
CVBufferRelease(buffer);
index++;
[self.writerInput markAsFinished];
[self.assetWriter finishWritingWithCompletionHandler:^{
dispatch_async(dispatch_get_main_queue(), ^{
self.completionBlock(self.fileURL);
CVPixelBufferPoolRelease(self.bufferAdapter.pixelBufferPool);
这里有个大坑,如果 GIF 文件的长宽不是&16&的整数倍,生成出来的 MOV 文件会有奇奇怪怪的问题,所以在创建 outputSettings 的时候,我使用了下面的方法:
+ (NSDictionary *)videoSettingsWithCodec:(NSString *)codec width:(CGFloat)width height:(CGFloat)height {
int w = (int)((int)(width / 16.0) * 16);
int h = (int)(height * w / width);
NSDictionary *videoSettings = @{
AVVideoCodecKey: codec,
AVVideoWidthKey: @(w),
AVVideoHeightKey: @(h)
return videoSettings;
将分辨率转换到与原分辨率最接近的 16 的整数倍,最后从 fileURL 里面取出生成的结果即可。
# MOV -& GIF
我在上次的文章里面提到过,NSGIF 这个项目提供了一个视频转到 GIF 的例子,但是写的不怎么好,所以这里大致讲一下原理是什么。最核心的概念有两个:使用&AVAssetImageGenerator&取关键帧,以及使用&CGImageDestinationAddImage&等函数往
GIF 文件里面添加帧。这里有一点可以提一下,AVAssetImageGenerator 有两个参数:requestedTimeToleranceBefore 和 requestedTimeToleranceAfter,这两个参数如果都填 kCMTimeZero 的话取出来的帧会精确无比,但同时也会因此而降低性能。同时这个过程中,时间的转换是 GIF -& MOV 的反过程,也即 CMTime 转换成帧与帧的时间间隔:
NSMutableArray *timePoints = [NSMutableArray array];
for (int currentFrame = 0; currentFrame&frameCount; ++currentFrame) {
float seconds = (float)increment * currentFrame + offset;
CMTime time = CMTimeMakeWithSeconds(seconds, [timeInterval intValue]);
[timePoints addObject:[NSValue valueWithCMTime:time]];
通过&CGImageDestinationCreateWithURL&创建 GIF 文件,CGImageDestinationAddImage&添加关键帧,最后&CGImageDestinationSetProperties&和&CGImageDestinationFinalize&来结束文件写入。
# MOV -& Live Photo
这一步可以直接看&&这个代码,基本上看完了也就懂了整个过程(但其实需要对
Live Photo 格式有所了解),这个代码是适用于&iOS 9.1&及以上的系统的,否则即便可以创建也没有&PHLivePhoto&这样的类来提供应用内显示的逻辑。简单说就是需要创建两个文件,一个 JPG 一个 MOV,但是两个文件都写进去了一些元数据,比如说创建 JPG 的时候 CGImageDestinationAddImageFromSource,这里面居然鬼使神差的要写入一个这样的元数据:
metadata[(id)kCGImagePropertyMakerAppleDictionary] = @{@&17&: @&UUID&};
这个东西其实是来自于作者对 Live Photo 文件的 EXIF 信息观察。我尝试用自己写的 app 看了一下任何一个 Live Photo 的 EXIFF:
果不其然这里面有个 17 对应过去是一个能够用来找到 MOV 文件的 UUID 信息。
至于 MOV 文件,元数据就更多更复杂,有一些类似于&com.apple.quicktime.still-image-time&这样的 metadata 在里面,StackOverflow 上面能找到一些描述:
之后我再对 Live Photo 的 MOV 文件进行一个格式的分析。
创建好这两个文件之后,使用&Photos Framework&可以把他们写到相册,使用&PhotosUI Framework&的PHLivePhotoView&可以展示和播放 Live Photo,从而完成了整个过程:
[[PHPhotoLibrary sharedPhotoLibrary] performChanges:^{
PHAssetCreationRequest *request = [PHAssetCreationRequest creationRequestForAsset];
PHAssetResourceCreationOptions *options = [[PHAssetResourceCreationOptions alloc] init];
[request addResourceWithType:PHAssetResourceTypePairedVideo fileURL:[NSURL fileURLWithPath:outputMOVPath] options:options];
[request addResourceWithType:PHAssetResourceTypePhoto fileURL:[NSURL fileURLWithPath:outputJPEGPath] options:options];
} completionHandler:^(BOOL success, NSError * _Nullable error) {
if (finishBlock) {
finishBlock(success, error);
# Live Photo -& MOV
根据上面的内容我们已经知道,Live Photo 不用转换到 MOV,它本身就包含一个 MOV,所以我们只要把它取出来,可以有两个方法做这个事情:
合法的方案,使用&PHAssetResourceManager:
[[PHAssetResourceManager defaultManager] writeDataForAssetResource:resource toFile:[NSURL fileURLWithPath:@&&] options:nil completionHandler:^(NSError * _Nullable error) {
这个方法会把 Asset 写到你指定的路径,然后通过路径取出来即可。另外一个方案不太合法,PHAsset 有个叫做&fileURLForVideoComplementFile&的方法,这是个私有的,他可以直接取到上述描述中的 MOV 文件的 URL,甚至还有另外一个叫做&fileURLForVideoPreviewFile能取到预览文件的
URL。至于怎么用的话,我还是不说了罢,反正都有合法的方法了。
# GIF &-& Live Photo
其实 Live Photo 到 GIF 已经不用讲了,通过上述方法拿到 MOV 再跑 MOV -& GIF 的流程即可。
理论上,GIF -& Live Photo 的过程也不太用讲,最笨的方法可以通过&GIF -& MOV -& Live Photo&来实现,这是一定可行的。但是这样有个缺陷就是性能,因为这个过程中相当于做了两次写入视频文件的操作。
我尝试过直接将 GIF decode 之后去写 Live Photo 的视频文件,遗憾的是没有成功,根本原因还是因为 GIF 转视频时候使用的 buffer 和 MOV 转 Live Photo 时候的 buffer 是不同的,是一个 pixel buffer,貌似没办法插入符合 Live Photo 的 metadata,这个我不是特别确定,尚存疑。目前我才用的方法就是做了两次转换,一个正常 5s 以内的视频在 iPhone
6s Plus 上面大概在 2s 以内,也算可以接受。
# 后续的点
后面有两点想做的,首先想完全搞清楚 Live Photo 的文件格式,搞清楚那些 metadata 如何得到的。另外就是想要优化一下 GIF 转换到 Live Photo 的性能,看能不能一步到位。
今天的文章很长,感谢看到这里的朋友,下次再见。
参考项目:
访问:119968次
积分:1751
排名:千里之外
原创:65篇
转载:29篇
(1)(2)(4)(8)(1)(1)(4)(3)(2)(5)(2)(13)(16)(7)(26)苹果 6slivephoto怎么用不了?_百度知道
苹果 6slivephoto怎么用不了?
3.用usb线连接手机和电脑,你选择live种的一个做墙纸就可以了,当你选择设定的时候,会让你选择是同时设定,如果不是系统自带的回答:在设置---墙纸里面选取新的墙纸,分别为动态墙纸.1、静态墙纸和Live,启动手机上的应用兔。2.如果是系统自带的就重按屏幕,壁纸就会动了。用户还可以将Live Photos设置为锁屏墙纸,随时重现动态瞬间,保持不锁屏,或者设定锁定屏幕。拓展回答:1,还是设定主屏幕,里面有三种墙纸.5秒的固定设置Live Photos,这新特性的作用是在在照片拍摄前后录制一段1.5秒的动态视频,当用户在照片上深按一下,照片就会自动播放动态效果
为您推荐:
其他类似问题
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。提高iPhone 6S辨识度:Live Photo自定义壁纸设置教程_使用评测_什么值得买
提高iPhone 6S辨识度:Live Photo自定义壁纸设置教程
追加修改( 20:31:14):买iPhone希望获得社交属性增益 多多少少应该会有点的
相信有很多值友在面对朋友在问iPhone6S与上一代区别时
临时找不到一个非常直观的表现方式
所以才发部这个教程 希望对大家有所帮助入了这部6S之后呢,最大的不满意就是和上一代iPhone辨识度太差。&无形装逼,伤害为零。好在Live Photo还是很有特色的。这也成了亲友询问6S与6的差异,我最爱的解答方式。可官方提供的壁纸就那么几张,很是不过瘾,后来在淘宝上看到了找个。感觉装哔犯的春天到了&后来在网络上学习制作方法,今日为大家简单讲讲制作过程。iPhone 6S/6S plus Live Photo 苹果动态锁屏壁纸 太空狗 钢铁侠等经典壁纸19张合集&当然首富家也有现成的。视频展示。---------------------------------------------------------------------------------------言归正传所谓的Live photo就是一张PNG图片+一张MOV视频然后通过PC导入到iPhone就可以了。以下是设置步骤第一步丨准备工具【工具一:iTools 3.0.exe &】【】&下载后安装【工具二:一根儿】我都觉得说的有些多余 但确实是必要的&【工具三:一张图与一段视频】图片格式PNG & &视频格式MOV要求相同比例,最好16:9,这样可以完美适配屏幕我这里就不讲如何剪辑视频。主要是我不擅长,容易误人子弟。&我这里提供一张剪裁好的 以供大家下载测试 【】&&下载后保存到桌面第二步丨操作拍摄一张Live photo照片然后将手机连接至电脑,打开刚刚下载iTools.exe第三步丨iPhone的操作进入相册 找到刚刚您的图 这时候点开就可以设置动态壁纸了用力按压就可以动了。&有的同学还注意到了,为什么相册中的缩略图还是之前拍的照片呢?这个也不用担心,打开图片,点击编辑,再点击右上角的小魔棒,保存。然后再点编辑,点击右下角的恢复,保存。就全部OK啦&&&
推荐关注:
鼠标移到标签上方,
尝试关注标签~
相关热门原创
群晖 DS218+ NAS & SkyNAS + 西数4TB红盘*2
Apple 苹果 HomePod 智能音箱
Jabra Elite 65t 捷波朗 臻律 无线蓝牙音乐耳机
赞214评论184
赞43评论106
赞25评论81
赞1318评论1104
赞1155评论253
赞932评论334
赞1064评论506
赞1075评论418
扫一下,分享更方便,购买更轻松
用户名/邮箱
两周内免登录

我要回帖

更多关于 6splus蓝牙搜不到设备 的文章

 

随机推荐