使用LEADTOOLS DVR组件创建一个188宝金博怎么下载LEADTOOLS多媒体捕获应用程序

执行以下步骤,使用LEADTOOLS MPEG-2传输模块的LEADTOOLS multimed188宝金博怎么下载ia CaptureCtrl和PlayCtrl控件和DVR组件创建和运行多媒体捕获DVR应用程序。

  1. 启动Visual Studio。

  2. 选择文件- >- >项目…菜单上的。

  3. 新项目对话框中,选择Visual c#项目或者VB项目在项目类型列表中,并选择“Windows应用程序在模板列表中。

  4. 输入项目名称为“188宝金博怎么下载多媒体DVR“在项目名称字段,然后单击好吧.类型为项目键入新位置或选择目录(如果需要)浏览按钮,然后单击好吧

  5. 在“解决方案资源管理器窗口,右键单击参考文献"文件夹并选择"添加引用…从上下文菜单。在“添加引用对话框中,选择net选项卡并选择Leadtools。188宝金博怎么下载多媒体并点击好吧.同时,右键单击参考文献"文件夹并选择"添加引用…从上下文菜单。在“添加引用对话框中,选择COM选项卡并选择:

    • LEAD MPEG2传输解复用器库
    • 领导DVR水槽库
    • 铅MPEG-2编码器滤波器库

    注意:以上COM对象必须注册;万一他们不是;用regsvr32。有关更多信息,请参阅DirectShow无注册表激活

    下一个点击好吧

  6. 确保Form1在设计视图中。去工具箱(视图->工具箱),并拖动CaptureCtrl控件和PlayCtrl控件。将其添加到表单后,在控件上设置以下属性:

    财产 价值
    的名字 _capturectrl
    上,下,左
    的名字 _playctrl
    上,下,右
    自动启动
  7. 转到工具箱(视图->工具箱),并拖动窗体上的TrackBar控件(在播放控件的下面),并设置以下属性:

    财产 价值
    的名字 _track
    下,左,右
  8. 转到工具箱(视图->工具箱),将两个Button控件拖到窗体底部,并设置以下属性:

    财产 价值
    的名字 _buttonCapture
    文本 捕获
    下,右
    的名字 _buttonPlay
    文本
    下,右
  9. 开关Form1编码视图(右键单击Form1在“解决方案资源管理器”中选择视图代码),并在文件开头添加以下行:

    vbLeadtools进口。188宝金博怎么下载多媒体进口LMMpgDmxTLib进口LMDVRSinkLib进口LMMPEG2EncoderLib
    c#
    使用Leadtools.188宝金博怎么下载Multimedia;使用LMMpgDmxTLib;使用LMDVRSinkLib;使用LMMPEG2EncoderLib;

  10. 声明以下私有变量:

    vbPrivate Const SLIDER_MAX As Integer = 10000Private _targetFile As StringPrivate _targetFolder As StringPrivate _capturing As BooleanPrivate _mpegDemux作为LMMpgDmxTPrivate _dvrSink作为ILMDVRSinkPrivate _firstPTS As DoublePrivate _lastPTS As Double
    c#
    私人常量intSlider_max = 10000;私人字符串_targetFile;私人字符串_targetFolder;私人保龄球_capturing;私人LMMpgDmxT _mpegDemux;私人ILMDVRSink _dvrSink;私人_firstPTS;私人_lastPTS;

  11. 在Form1 Load事件中添加一个事件处理程序,代码如下:

    vb私有子Form1_Load(ByVal发送方作为系统。Object, ByVal e As System.EventArgs)处理MyBase。负载如果_capturectrl.VideoDevices。Count = 0则抛出新异常(“没有可用的捕获设备”如果如果_capturectrl。VideoDevices (“模拟”)那么什么都不是抛出新异常(“没有模拟电视捕捉设备可用”如果_capturectrl。VideoDevices (“模拟”).选中= True_capturectrl。UseVideoDeviceAudio = True_capturing = False_targetFolder = Path.Combine(Directory.GetCurrentDirectory(),“DVRFolder”If (Not Directory.Exists(_targetFolder)Directory.CreateDirectory (_targetFolder)如果_targetFile =“capture.lbl”_capturectrl。PreviewTap = CapturePreviewTap。源_capturectrl。预览=True_capturectrl。PreviewSource = CapturePreview。视频终止子
    c#
    私人无效Form1_Load (对象发送者,系统。EventArgs e)如果(_capturectrl.VideoDevices。计数== 0)异常(“没有可用的捕获设备”);如果(_capturectrl。VideoDevices [“模拟”) = =异常(“没有模拟电视捕捉设备可用”);_capturectrl。VideoDevices [“模拟”]。选择=真正的_capturectrl。UseVideoDeviceAudio =真正的_capturing =_targetFolder = Path.Combine(Directory.GetCurrentDirectory(),“DVRFolder”);如果(! Directory.Exists (_targetFolder))Directory.CreateDirectory (_targetFolder);_targetFile =“capture.lbl”_capturectrl。PreviewTap = CapturePreviewTap.Source;_capturectrl。预览=真正的_capturectrl。PreviewSource = CapturePreview.Video;

  12. 添加如下helper方法:

    vb私有函数IsStreaming()作为布尔值(_capturectrl返回。视频捕获StreamType = Leadtools.Multimedia.Constants.MEDIATYPE_Stream)结束函数私有函数PTSToSliderPosition(ByVal curPTS As Double)作为整数Dim retVal As Integer = 0If curPTS <= _firstPTS ThenretVal = 0ElseIf curPTS >= _lastPTS然后retVal = SLIDER_MAX其他的((curPTS - _firstPTS) * SLIDER_MAX) / (_lastPTS - _firstPTS) + 0.5)如果返回retVal结束函数私有函数SliderPositionToPTS(ByVal nPos As Integer) As Double返回_firstPTS + CDbl(nPos) * (_lastPTS - _firstPTS) / CDbl(SLIDER_MAX)结束函数
    c#
    私人保龄球IsStreaming ()返回(_capturectrl。视频捕获StreamType == Constants.MEDIATYPE_Stream);私人intPTSToSliderPosition (curPTS)intretVal = 0;如果(curPTS <= _firstPTS)retVal = 0;其他的如果(curPTS >= _lastPTS)retVal = SLIDER_MAX;其他的retVal = (int)((curPTS - _firstPTS) * SLIDER_MAX) / (_lastPTS - _firstPTS) + 0.5);返回retVal;私人SliderPositionToPTS (int非营利组织)返回_ (1)nPos * (_lastPTS - _firstPTS) / () SLIDER_MAX;

  13. 向_capturectrl Progress事件添加一个事件处理程序,并将其编码如下:

    vbPrivate Sub _capturectrl_Progress(ByVal sender As Object, ByVal e As progres76args)处理_capturectrl。进步如果不是_mpegDemux是什么那么_mpegDemux.RefreshPosition (0)Dim curPTS As Double = _mpegDemux。CurrentStreamPTS_firstPTS = _mpegDemux。FirstStreamPTS_lastPTS = _mpegDemux。LastStreamPTS如果curPTS < _firstPTS AndAlso _playctrl。状态=游戏状态。停顿了一下然后_playctrl.Run ()如果如果终止子
    c#
    私人无效_capturectrl_Progress (对象发送者,progressevenargs e)如果(_mpegDemux ! =_mpegDemux.RefreshPosition (0);curPTS = _mpegDemux.CurrentStreamPTS;_firstPTS = _mpegDemux.FirstStreamPTS;_lastPTS = _mpegDemux.LastStreamPTS;如果(curPTS < _firstPTS && _playctrl。状态== PlayState.Paused)_playctrl.Run ();

  14. 为_playctrl TrackingPositionChanged事件添加一个事件处理程序,并按如下代码编写:

    vbPrivate Sub _playctrl_TrackingPositionChanged(ByVal sender As System。Object, ByVal e As TrackingPositionChangedEventArgs)处理_playctrl。TrackingPositionChanged如果不是_mpegDemux是什么那么_mpegDemux.RefreshPosition (0)Dim curPTS As Double = _mpegDemux。CurrentStreamPTS_firstPTS = _mpegDemux。FirstStreamPTS_lastPTS = _mpegDemux。LastStreamPTS_track。价值= PTSToSliderPosition(curPTS)如果终止子
    c#
    私人无效_playctrl_TrackingPositionChanged (对象发件人,TrackingPositionChangedEventArgs e)如果(_mpegDemux ! =_mpegDemux.RefreshPosition (0);curPTS = _mpegDemux.CurrentStreamPTS;_firstPTS = _mpegDemux.FirstStreamPTS;_lastPTS = _mpegDemux.LastStreamPTS;_track。价值= PTSToSliderPosition(curPTS);

  15. 向_track Scroll事件添加一个事件处理程序,并按如下代码编写:

    vbPrivate Sub _track_Scroll(ByVal发送方作为系统。Object, ByVal e As EventArgs)处理_track。滚动如果不是_mpegDemux是什么那么Dim ptsPos As Double = SliderPositionToPTS(_track.Value)_mpegDemux。CurrentStreamPTS = ptsPos如果终止子
    c#
    私人无效_track_Scroll (对象发送者,EventArgs如果(_mpegDemux ! =ptsPos = SliderPositionToPTS(_track.Value);_mpegDemux。CurrentStreamPTS = ptsPos;

  16. 在_capturectrl Complete事件中添加一个事件处理程序,并按照如下代码编写它:

    vbPrivate Sub _capturectrl_Complete(ByVal sender As System.)Object, ByVal e As EventArgs)处理_capturectrl。完整的对话框。显示(“捕获完整”_buttonCapture。启用了=真正的终止子
    c#
    私人无效_capturectrl_Complete (对象发送者,EventArgs对话框。显示(“捕获完整”);_buttonCapture。启用了=真正的

  17. 在_playctrl StateChanged事件中添加一个事件处理程序,并按照如下代码编写它:

    vbPrivate Sub _playctrl_StateChanged(ByVal sender As Object, ByVal e As StateChangedEventArgs)处理_playctrl。statechange如果e.state = PlayState。然后运行_mpegDemux =无_mpegDemux = TryCast(_playctrl.GetSubObject(PlayObject.Splitter), LMMpgDmxT)如果终止子
    c#
    私人无效_playctrl_StateChanged (对象发送者:StateChangedEventArgs如果(e.state == PlayState.Running)_mpegDemux =_mpegDemux = _playctrl.GetSubObject(PlayObject.Splitter)作为LMMpgDmxT;

  18. 向_buttonCapture Click事件添加一个事件处理程序,并按照如下代码编写它:

    vbPrivate Sub _buttonCapture_Click(ByVal sender As System.)Object, ByVal e As System.EventArgs)处理_buttonCapture。点击试一试如果_capturing = True那么_capturectrl.StopCapture ()其他的Dim recVideoComp As String =字符串。空Dim recAudioComp As String =字符串。空如果IsStreaming()那么_capturectrl.TargetFormats.DVR。选中= True_capturectrl。TargetFormat = TargetFormatType。DVR_capturectrl.VideoCompressors。选择= -1_capturectrl.AudioCompressors。选择= -1其他的_capturectrl.TargetFormats.DVRTransport。选中= TruerecVideoComp = _capturectrl.TargetFormats.DVRTransport.RecommendedVideoCompressorrecAudioComp = _capturectrl.TargetFormats.DVRTransport.RecommendedAudioCompressor_capturectrl。TargetFormat = TargetFormatType。DVRTransport如果recVideoComp <>字符串。空然后_capturectrl.VideoCompressors (recVideoComp)。选中= True如果如果recAudioComp <> String。空然后_capturectrl.AudioCompressors (recAudioComp)。选中= True如果如果_capturectrl.VideoCompressors.Mpeg2。选中= True那么Dim mpeg2Encoder As LMMPEG2Encoder = TryCast(_capturerectrl . getsubobject (CaptureObject.VideoCompressor), LMMPEG2Encoder)如果没有mpeg2Encoder是什么mpeg2Encoder。EncodingThreads = eMpeg2EncodingThreads。MPEG2_THREAD_AUTOmpeg2Encoder。视频Format = eMPEG2VIDEOFORMAT.MPEG2_VF_NTSCMarshal.ReleaseComObject (mpeg2Encoder)如果如果如果_capturectrl。预览=True_capturectrl。TargetFile = _targetFile_capturectrl.ReadyCapture (CaptureMode。视频AndAudio Or CaptureMode.InhibitRun)_dvrSink = TryCast(_capturerectrl . getsubobject (CaptureObject.Sink), ILMDVRSink)如果不是_dvrSink Is Nothing那么Dim dBuffSize As Double = 102400000 ' 100 MBDim lFileCount As Integer = 8 ' 8缓冲文件_dvrSink.StartChangingAttributes ()_dvrSink。FolderCount = 1_dvrSink.FolderName(0) = _targetFolder_dvrSink。SetBufferSize(0, lFileCount, dBuffSize)_dvrSink.StopChangingAttributes(假)Dim bufferFolder As String = _dvrSink。BaseName如果_capturectrl.RunCapture ()_buttonCapture。Enabled = False_capturing = True如果Catch ex作为异常MessageBox.Show (ex.Message)最后试一试终止子
    c#
    私人无效_buttonCapture_Click (对象发送者,系统。EventArgs e)试一试如果(_capturing = =真正的_capturectrl.StopCapture ();其他的字符串recVideoComp =字符串空虚;字符串recAudioComp =字符串空虚;如果(IsStreaming ())_capturectrl.TargetFormats.DVR。选择=真正的_capturectrl。TargetFormat = targetformatttype . dvr;_capturectrl.VideoCompressors。选择= -1;_capturectrl.AudioCompressors。选择= -1;其他的_capturectrl.TargetFormats.DVRTransport。选择=真正的recVideoComp = _capturectrl.TargetFormats.DVRTransport.RecommendedVideoCompressor;recAudioComp = _capturectrl.TargetFormats.DVRTransport.RecommendedAudioCompressor;_capturectrl。TargetFormat = targetformatttype . dvrtransport;如果(recVideoComp ! =字符串空虚)_capturectrl.VideoCompressors [recVideoComp]。选择=真正的如果(recAudioComp ! =字符串空虚)_capturectrl.AudioCompressors [recAudioComp]。选择=真正的如果(_capturectrl.VideoCompressors.Mpeg2。选择= =真正的mpeg2Encoder = _capturetrl . getsubobject (CaptureObject.VideoCompressor)作为LMMPEG2Encoder;如果(mpeg2Encoder ! =mpeg2Encoder。EncodingThreads = eMpeg2EncodingThreads.MPEG2_THREAD_AUTO;mpeg2Encoder。视频Format = eMPEG2VIDEOFORMAT.MPEG2_VF_NTSC;Marshal.ReleaseComObject (mpeg2Encoder);_capturectrl。预览=真正的_capturectrl。目标文件= _targetFile;_capturectrl.ReadyCapture (CaptureMode。视频AndAudio | CaptureMode.InhibitRun);_dvrSink = _capturetrl . getsubobject (CaptureObject.Sink)作为ILMDVRSink;如果(_dvrSink ! =dBuffSize = 102400000;// 100 MBintlFileCount = 8;// 8个缓冲文件_dvrSink.StartChangingAttributes ();_dvrSink。FolderCount = 1;_dvrSink。set_FolderName (0, _targetFolder);_dvrSink。SetBufferSize(0, lFileCount, dBuffSize);_dvrSink。StopChangingAttributes ();字符串bufferFolder = _dvrSink.BaseName;_capturectrl.RunCapture ();_buttonCapture。启用了=_capturing =真正的(异常交货)对话框。显示(, ex.Message);

  19. 为_buttonPlay Click事件添加一个事件处理程序,并按如下代码编写:

    vbPrivate Sub _buttonPlay_Click(ByVal sender As System.)Object, ByVal e As System.EventArgs)处理_buttonPlay。点击试一试_mpegDemux =无_playCtrl.ResetSource ()_playCtrl。PreferredMPEG2Splitter = Leadtools.188宝金博怎么下载Multimedia.Constants.Filter_MPEG2_Transport_Demux_playctrl。源File = Path.Combine(_targetFolder, _targetFile)_playctrl。运行Catch ex作为异常MessageBox.Show (ex.Message)最后试一试终止子
    c#
    私人无效_buttonPlay_Click (对象发送者,系统。EventArgs e)试一试_mpegDemux =_playCtrl.ResetSource ();_playCtrl。PreferredMPEG2Splitter = Constants.Filter_MPEG2_Transport_Demux;_playctrl。源File = Path.Combine(_targetFolder, _targetFile);_playctrl.Run ();(异常交货)对话框。显示(, ex.Message);

  20. 构建并运行程序以测试它。

LEADTOOLS多188宝金博怎么下载媒体
188金宝搏的网址客服|支持|联系我们|知识产权公告
©1991 - 2022领德科技有限公司版权所有。