public virtual object TargetObject { get; set; }
An object representing a COM target interface.
This property allows the user to assign a COM object as the media target for the capturing process. The object may be the SampleTarget object or any other DirectShow renderer filter. The ResetTarget method should be called to stop the capture control from accessing the object. The TargetType will be set to TargetObjectType.Object. Assignment can raise an error exception. For more information, refer to the Error Codes.
using Leadtools;using Leadtools.Multimedia;using LeadtoolsMultimediaExamples.Fixtures;public bool _result = false;public CaptureAndPlayCtrlForm _form = new CaptureAndPlayCtrlForm();public SampleTarget _captureTarget;public SampleSource _playSource;public void GetPortableTypeExample(){// reference the convert controlCaptureCtrl capturectrl = _form.CaptureCtrl;PlayCtrl playctrl = _form.PlayCtrl;// This example demonstrates how to play a capture stream// using a play control and portable media types.try{// set the source deviceif (capturectrl.VideoDevices["Analog"] == null)throw new Exception("No Analog video devices available!");capturectrl.VideoDevices["Analog"].Selected = true;// set the previewcapturectrl.Preview = true;// create a sample target object for the capture control_captureTarget = new SampleTarget();// set the capture target to our sample target created earliercapturectrl.TargetObject = _captureTarget;// create a new sample source object for the play control_playSource = new SampleSource();// set the video compressorcapturectrl.VideoCompressors.MCmpMJpeg.Selected = true;//// for this example we will only capture 120 seconds of videocapturectrl.UseTimeLimit = true;capturectrl.TimeLimit = 120;// start the capturecapturectrl.StartCapture(CaptureMode.Video);// we could just assign the media type from target to source// however, let's use the portable type to simulate// the needed steps for remote playbackByte[] portableMediaType = _captureTarget.GetConnectedMediaType().GetPortableType();// initialize a new media type object with the portable typeMediaType mt = new MediaType();mt.SetPortableType(portableMediaType);// set the sample source media type_playSource.SetMediaType(mt);// set the play controls sample source objectplayctrl.SourceObject = _playSource;// create a timer to drive the sample delivery_form.TestTimer.Tick += new EventHandler(SampleDeliver_Tick);_form.TestTimer.Interval = 33;_form.TestTimer.Start();// we'll loop on the state and pump messages for this example.// but you should not need to if running from a Windows Forms application.while (capturectrl.State == CaptureState.Running|| capturectrl.State == CaptureState.Paused|| capturectrl.State == CaptureState.Pending)Application.DoEvents();}catch (Exception){_result = false;}}void SampleDeliver_Tick(object sender, EventArgs e){_form.TestTimer.Stop();bool eos = false;MediaSample cs = null;try{cs = _captureTarget.GetSample(1000);}catch (COMException cex){if (cex.ErrorCode == (int)ErrorCode.VFW_E_SAMPLE_REJECTED_EOS)eos = true;elsethrow;}catch (Exception ex){throw new Exception(ex.Message);}if (!eos){_playSource.DeliverSample(1000, cs);_form.TestTimer.Start();}else{_playSource.DeliverEndOfStream(1000);_form.TestTimer.Stop();// set the result_result = true;}}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document
