Partager via


IWMSCacheProxyServerCallback.OnDownloadContentProgress (Visual Basic .NET)

The OnDownloadContentProgress method is called by the server when each media item identified in a playlist has been downloaded.

IWMSCacheProxyServerCallback.OnDownloadContentProgress(  lHr As Integer,
  opCode As WMS_RECORD_PROGRESS_OPCODE,
  pArchiveContext As IWMSContext,
  varContext As Object
)

Arguments

[in] Integer indicating whether the call to IWMSCacheProxyServer.DownloadContent.

[in] Member of the WMS_RECORD_PROGRESS_OPCODE enumeration type indicating the state of the download. This must be one of the following values.

Value

Description

WMS_RECORD_PROGRESS_ARCHIVE_STARTED

The requested content is being saved.

WMS_RECORD_PROGRESS_ARCHIVE_FINISHED

The archiving process has been completed.

[in] IWMSContextIWMSContext Object (Visual Basic .NET) containing a pointer to an INSSBufferINSSBuffer Object (Visual Basic .NET) that contains the serialized metadata for the media item being downloaded. The metadata must be persisted by the plug-in. For more information, see Downloading Content.

[in] Object containing a value defined by the plug-in when it called IWMSCacheProxyServer.DownLoadContent. For example, your plug-in can use this parameter to persist state information. The server does not alter this value and passes it back when calling OnDownloadContentProgress.

Return Value

This method does not return a value. To report an error, the plug-in can throw a COMException object to the server. If the plug-in uses the IWMSEventLogIWMSEventLog Object (C#) to log error information, it is recommended that it throw NS_E_PLUGIN_ERROR_REPORTED (0xC00D157D). Typically, the server attempts to make plug-in error information available to the server object model, the Windows Event Viewer, and the troubleshooting list in the details pane of the Windows Media Services MMC. However, if the plug-in uses the IWMSEventLog object to send custom error information to the Windows Event Viewer, throwing NS_E_PLUGIN_ERROR_REPORTED stops the server from also logging to the event viewer. For more information about plug-in error information, see Identifying Plug-in Errors.

Example

Imports Microsoft.WindowsMediaServices.Interop
Imports System.Runtime.InteropServices

Public Sub OnDownloadContentProgress(ByVal lHr As Integer, _
                                     ByVal opCode As WMS_RECORD_PROGRESS_OPCODE, _
                                     ByVal ArchiveContext As IWMSContext, _
                                     ByVal varContext As Object) _
  Implements IWMSCacheProxyServerCallback.OnDownloadContentProgress

    Dim Buffer As INSSBuffer
    Dim CacheFile As String
    Dim ci As ContentInfo
    Dim strCDL As String
    Dim Item As PlaylistItem

    Try
        ' Retrieve the name of the download file.
        ArchiveContext.GetAndQueryIUnknownValue(WMSDefines.WMS_ARCHIVE_CONTENT_DESCRIPTION_LIST_BUFFER, _
                                                WMSDefines.WMS_ARCHIVE_CONTENT_DESCRIPTION_LIST_BUFFER_ID, _
                                                GetType(INSSBuffer).GUID, _
                                                Buffer, _
                                                0)
        ArchiveContext.GetStringValue(WMSDefines.WMS_ARCHIVE_FILENAME, _
                                      WMSDefines.WMS_ARCHIVE_FILE_SIZE_ID, _
                                      CacheFile, _
                                      0)

        ' Retrieve the user-defined ContentInfo object
        ' from the varContext parameter. The ContentInfo
        ' class is used to describe an item of cached content.
        ci = varContext

        ' If this is not a playlist, assign the file
        ' name to the cache URL. GetStringFromNSSBuffer()
        ' is user-defined.
        strCDL = GetStringFromNSSBuffer(Buffer)
        If (ci.ContentType And 2) = 0 Then
            ci.CDLData = strCDL
            ci.CacheUrl = CacheFile
        Else
            ' This is a playlist.
            Item = New PlaylistItem()
            Item.CacheUrl = CacheFile
            Item.CDLData = strCDL
            ci.CDL.Add(Item)

        End If

    Catch
        Throw New COMException()
    End Try

End Sub

Requirements

Reference: Add a reference to Microsoft.WindowsMediaServices.

Namespace: Microsoft.WindowsMediaServices.Interop.

Assembly: Microsoft.WindowsMediaServices.dll.

Library: WMSServerTypeLib.dll.

Platform: Windows Server 2003, Enterprise Edition; Windows Server 2003, Datacenter Edition; Windows Server 2008.

See Also

Concepts

IWMSCacheProxyServerCallback Object (Visual Basic .NET)