我正在尝试制作一个简单的视频播放器,例如使用 Direct2D 和 WIC 位图的程序。
它需要快速和 CPU 经济地绘制(拉伸(stretch))YUV 像素格式帧数据。
我已经用 GDI 测试过了。我希望切换到 Direct2D 至少可以提高 10 倍的性能(CPU 开销更小)。
我要做的基本上是这样的:
对于第 1、2 步,我必须选择一种像素格式。
WIC Native Pixel Formats
有一个MSDN页面推荐WICPixelFormat32bppPBGRA。
http://msdn.microsoft.com/en-us/library/windows/desktop/hh780393(v=vs.85).aspx
WICPixelFormat32bppPBGRA 和 WICPixelFormat32bppBGRA 有什么区别? (前者有附加P)
如果 WICPixelFormat32bppPBGRA 是要走的路,它总是这样吗?无论硬件和/或配置如何?
WIC 位图处理实际上最有效的像素格式是什么?
最佳答案
不幸的是,使用 Direct2D 1.1 或更低版本,您不能使用不同于 DXGI_FORMAT_B8G8R8A8_UNORM 的像素格式,后者等同于 WIC 的WICPixelFormat32bppPBGRA(“P”表示您使用D2D1_ALPHA_MODE_PREMULTIPLIED D2D 中的 alpha 模式)。
如果您的目标操作系统是 Windows 8,那么您可以使用 Direct2D 的更新功能。据我所知,D2D 位图有某种 YUV 支持。 (编辑:不,没有。RGB32 仍然是唯一支持的像素格式以及一些仅 alpha 格式)
What is the most effective pixel format for WIC bitmap processing actually?
我不确定如何衡量像素格式的有效性,但如果您想使用硬件加速,您应该使用 D2D 而不是 WIC 进行绘制,并且仅将 WIC 用于颜色空间转换。 (顺便说一句,GDI 也是硬件加速的)。
What's the difference WICPixelFormat32bppPBGRA and WICPixelFormat32bppBGRA? (former has additional P)
P表示RGB分量预乘。 (see here)
What I'll doing is basically such as below:
- Create an empty WIC bitmap A (for drawing canvas)
- Create another WIC bitmap B with YUV frame data (format conversion)
- Draw bitmap B onto A, then draw A to the D2D render target
如果您以性能为目标,则应尽量减少位图复制操作,还应避免使用 WIC 位图渲染目标,因为它使用软件渲染。如果你的播放器只渲染到一个窗口,你可以使用 HWND render target , 或 DeviceContext与交换链(取决于您使用的 Direct2D 版本)。
您可以使用 WIC 的软件像素格式转换功能(例如 IWICFormatConverter),而不是将帧 B 渲染到帧 A。另一种方法是使用 SIMD 操作编写(或查找)自定义转换例程。或者使用着色器在 GPU 端 转换格式(色彩空间)。但后两者需要高深的知识。
转换后,您可以锁定像素以获取像素数据并将该数据直接复制到 D2D 位图 (ID2D1Bitmap::CopyFromMemory())。鉴于您已经有了一个现成的 d2d 位图。
最后一步是将位图渲染到渲染目标。并且可以使用变换矩阵来实现拉伸(stretch)。
关于windows - WIC 位图处理最有效的像素格式是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26139710/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
它不等于主线程的binding,这个toplevel作用域是什么?此作用域与主线程中的binding有何不同?>ruby-e'putsTOPLEVEL_BINDING===binding'false 最佳答案 事实是,TOPLEVEL_BINDING始终引用Binding的预定义全局实例,而Kernel#binding创建的新实例>Binding每次封装当前执行上下文。在顶层,它们都包含相同的绑定(bind),但它们不是同一个对象,您无法使用==或===测试它们的绑定(bind)相等性。putsTOPLEVEL_BINDINGput
我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象