当前位置: 首页 > news >正文

上海中国建设银行网站最近最新的新闻

上海中国建设银行网站,最近最新的新闻,网站开发商换了,图文识别微信小程序是什么绿幕(green screen)技术,又称 chroma key effect,实际上是将图片上指定颜色设置为透明的图形处理技术,这些透明区域也可以被任意背景图片替换。 这种技术在 视频合成中被广泛使用。iOS 中,通过 CoreImage …

绿幕(green screen)技术,又称 chroma key effect,实际上是将图片上指定颜色设置为透明的图形处理技术,这些透明区域也可以被任意背景图片替换。

这种技术在 视频合成中被广泛使用。iOS 中,通过 CoreImage 的某些滤镜比如 CIBlendWithMask 可以实现这种效果,但是实现过程比较繁琐。然而功夫不负有心人,在 Github 上我们找到一个现成的实现:GitHub - quentinfasquel/MyTransparentVideoExample: A simple example of how to play a transparent video in a UIView

打开项目,可以看到一个 playdoh-bat.mp4 文件,这种视频文件具有特殊格式,并非一般的 mp4,实际上它的每一帧都可以被分成上下两部分(两帧合成一帧):

上半帧是原图,下半帧是 mask,将下半帧叠在上半帧之上,先把白色部分用上半帧的像素填充,黑色的部分用透明像素填充,形成“绿幕”效果。它的使用非常简单,通过框架提供的 AVPlayerView 类来使用它。

首先初始化一个 AVPlayerView 并添加到 View 中:

let playerView = AVPlayerView(frame: CGRect(origin: .zero, size: videoSize))
view.addSubview(playerView)

AVPlayerView 上自带了一个 AVPlayerLayer,AVPlayerView 实际上是用它来播放视频的。当然在播放之前,你需要将这个特殊的 mp4 格式合成绿幕效果应用之后的 AVPlayerItem:

let itemUrl: URL = Bundle.main.url(forResource: "playdoh-bat", withExtension: "mp4")!
let playerItem = createTransparentItem(url: itemUrl)

createTransparentItem 方法中,你需要调用 特殊的滤镜特效 AlphaFrameFilter 进行视频的合成:

		func createTransparentItem(url: URL) -> AVPlayerItem {let asset = AVAsset(url: url)let playerItem = AVPlayerItem(asset: asset)// Set the video so that seeking also renders with transparencyplayerItem.seekingWaitsForVideoCompositionRendering = true// Apply a video composition (which applies our custom filter)playerItem.videoComposition = createVideoComposition(for: asset)return playerItem}func createVideoComposition(for asset: AVAsset) -> AVVideoComposition {let filter = AlphaFrameFilter(renderingMode: .builtInFilter)let composition = AVMutableVideoComposition(asset: asset, applyingCIFiltersWithHandler: { request indo {let (inputImage, maskImage) = request.sourceImage.verticalSplit()let outputImage = try filter.process(inputImage, mask: maskImage)return request.finish(with: outputImage, context: nil)} catch {os_log("Video composition error: %s", String(describing: error))return request.finish(with: error)}})composition.renderSize = asset.videoSize.applying(CGAffineTransform(scaleX: 1.0, y: 0.5))return composition}

AlphaFrameFilter 类继承了 CIFilter,实现了绿幕特效(框架已经提供)。

最后播放 AVPlayItem:

				playerView.loadPlayerItem(playerItem) { [weak self] result inswitch result {case .failure(let error):return print("Something went wrong when loading our video", error)case .success(let player):// Finally, we can start playingplayer.play()// Animate backgroundself?.animateBackgroundColor()}}

在回调块中处理错误。最终运行效果如图:

原视频中的背景被 view controller 中的背景色(绿色)替换,可见实际上播放的是合成特效后的视频而非原视频。

http://www.zhongyajixie.com/news/30648.html

相关文章:

  • 上海专业做网站公司电话怎么做公司网站推广
  • 建设部网站关于乡建助理职责谷歌浏览器最新版本
  • 和先锋影音和做的网站建设公司网站大概需要多少钱?
  • 云南电商网站开发个人永久免费自助建站
  • 中国建设局网站查询seo是怎么优化上去
  • 大作设计网站官网登录入口百度指数有哪些功能
  • 建设一个商城式网站可以吗在线网页编辑平台
  • 网站建设工作室是干嘛的杭州seo网
  • 暴走漫画网站建设目的提升排名
  • 品牌网站建设小h蝌蚪西安seo排名外包
  • 网站设计欣赏郑州seo培训班
  • 电子书籍网站开发热词搜索排行榜
  • 网站素材下载宁波 seo整体优化
  • 局域网建站软件seo网站优化服务商
  • 杭州的网站建设公司nba排名赛程
  • wordpress 博客页面杭州网站优化咨询
  • 做直通车任务的网站快速提升排名seo
  • 栖霞做网站价格网络营销产品策略
  • php网站 mysql数据库配置文件seo优化课程
  • 咸阳网站建设多少钱网站排名首页前三位
  • 3d建站企业网络的组网方案
  • 行业门户网站建设方案书公司企业网站建设
  • 东莞网站优化平台今天
  • 做食品网站有哪些宁波专业seo外包
  • 网站制作应该注意到的问题seo优化器
  • 沈阳专业制作网站无锡百度推广代理商
  • 网站开发前端框架和后端框架今天的热搜榜
  • 外贸网站如何优化网络推广怎么做好
  • 长沙今日检出2例阳性seo比较好的优化方法
  • 河南夏邑网站建设谷歌独立站