前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >iOS的QuickTime Plugin

iOS的QuickTime Plugin

作者头像
全栈程序员站长
发布2021-12-27 08:21:07
4120
发布2021-12-27 08:21:07
举报
文章被收录于专栏:全栈程序员必看

当UIWebView播放视频时,可以看到view hierarchy里有FigPluginView的身影。这个类来自于QuickTime Plugin,plugin的路径为:

/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator6.1.sdk/System/Library/Internet Plug-Ins/QuickTime Plugin.webplugin 这是个文件夹,里面还有链接库以及文件和图片资源。

QuickTime Plugin这个名字起得很响亮,其实代码并不多,Objective-C类只有9个,也就只是FigPluginView为主了。与WebKit.framework有耦合,或者说就是为了封装视频播放控件来给WebKit.framework用的。类关系如下图:

iOS的QuickTime Plugin
iOS的QuickTime Plugin

UIWebDocumentView会以成员变量struct __CFDictionary *_plugInViews来配对FigPluginView和UIWebPlugInView,其中FigPluginView为key,UIWebPlugInView为value。 UIWebPlugInView有成员变量UIView *_uiView指向FigPluginView, FigPluginView有成员变量WAKView *_wakView指向UIWebPlugInView。

当然,视频只是PluginView的一种,UIWebPlugInView还会管理别的种类的plugin。

渲染流程中会有这样的关系:

iOS的QuickTime Plugin
iOS的QuickTime Plugin

RenderLayerBacking在更新layer树时,从RenderWidget出发通过几层关系得到UIWebPlugInView,调用其函数attachPluginLayer把FigPluginView添加到UIWebDocumentView中。注意这个“添加”是通过好多层CALayer间接实现的,UIWebPlugInView还会创建一个hostLayer作为MediaLayer。调用链的末端实现代码如下:

代码语言:javascript
复制
- (void)_connectPluginLayers  
{  
    WebThreadLock();  
    if (!_hostingLayer)  
    {  
        _hostingLayer = [[CALayer alloc] init];  
    }  
    [_webView.layer insertSublayer:_hostingLayer atIndex:0];  
    if ([[_webView webView] _setMediaLayer:_hostingLayer forPluginView:self])  
    {  
        self.parentedInLayer = YES;  
        [_uiView retain];  
        [_hostingLayer addSublayer:_uiView.layer];  
        [_uiView release];  
        [_webView _setSubviewCachesNeedUpdate:YES];  
        [self _reshapeOnMainThread];  
    }  
}  /* 何问起 hovertree.com */

这里只列个大概了,类间网状依赖,好难画图和用文字说明。总之可以更确定,WAKView就是替代了NSView,以求和Mac的WebView共用代码,但iOS application是单进程程序,只能用CALayer树来代替NSView树做组合了。

推荐:http://www.cnblogs.com/roucheng/p/3528371.html

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/120479.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档