DirectShow 建立在COM基础上,是针对流数据的处理的解决方案。
Filter的高级抽象与低级抽象:高级抽象面向组件,每个Filter都是一个组件,低级抽象面向对象,每个Filter内部都有相应的功能类,具有相应的职责。与之相应的是Filter,是系统级的部署,在整操作系统级别进行复用。
Filter与Filter之间的连接依靠Pin,Pin也是一种组件。每个Filter都包含一些Pin,每个Pin都遵从一定的传输协议,两个Pin之间的传输协议匹配的时候才能连接起来。
由许多Filter和Pin连接起来的模块叫Graph。
数据流也是一个COM对象,同样的,管理数据样本(Sample)的也是一个COM对象,Allocator。一个allocator创建的是一个拥有有限个sample的sample池。每个Sample是否可用取决于其引用计数。
分配器(Allocator)的提交与反提交机制:当一个filter首次创建一个allocator时,allocator并不为其分配内存缓冲,此时如果调用GetBuffer方法的话会失败。当流开始流动时,输出pin调用IMemAllocator::Commit来提交allocator,从而为其分配内存。此时pin可以调用GetBuffer了。当流停止时,pin调用IMemAllocator::Decommit来 反提交allocator,在allocator被再次提交前所有后来的GetBuffer调用都将失败,同样,如果有阻塞的正在等待sample的 GetBuffer调用,也将立即返回失败信息。Decommit方法是否释放内存取决于实现方式,如CMemAllocator类直至析构时才释放内存。
请求数据的两种模式:推模式和拉模式
流的同步方法:参考时钟
流数据的质量控制:由下游Filter发起,传递至上游Filter。