Ordenar listas de reproducción por prioridad de sincronización

[La característica asociada a esta página, Reproductor multimedia de Windows SDK, es una característica heredada. Se ha reemplazado por MediaPlayer. MediaPlayer se ha optimizado para Windows 10 y Windows 11. Microsoft recomienda encarecidamente que el nuevo código use MediaPlayer en lugar de Reproductor multimedia de Windows SDK, siempre que sea posible. Microsoft sugiere que el código existente que usa las API heredadas se reescriba para usar las nuevas API si es posible.

El código siguiente realiza un tipo sencillo de listas de reproducción. Puede ver cómo se usa esta función en el código de ejemplo de Enumeración de listas de reproducción de sincronización. La función toma los parámetros siguientes:

  • pPlaylist. Puntero a la lista de reproducción de Reproductor multimedia de Windows que se va a ordenar. Los elementos multimedia de la lista de reproducción deben apuntar a otras listas de reproducción, no a archivos multimedia digitales individuales.
  • bstrSyncAttribute. Un BSTR que contiene el nombre del atributo de asociación de sincronización para el dispositivo actual ("Sync01", "Sync02", etc.).
  • plSelected. Puntero a una variable larga que recibe el recuento de listas de reproducción de sincronización.

La función inspecciona el atributo de asociación de sincronización para cada elemento multimedia (que representa una lista de reproducción) en la lista de reproducción especificada por pPlaylist. Si el atributo tiene un valor distinto de cero, el código mueve el elemento multimedia al principio de la lista de reproducción e lo inserta en orden de prioridad.

Cuando termine, la función devuelve el recuento de elementos multimedia (listas de reproducción de sincronización) que tenían un valor distinto de cero para el atributo de asociación de sincronización.

STDMETHODIMP CSyncSettings::SortPlaylist(IWMPPlaylist *pPlaylist, BSTR bstrSyncAttribute, long *plSelected)
{
    HRESULT hr = S_OK;
    long lSyncItemCount = 0;

    ATLASSERT (pPlaylist);
    ATLASSERT (plSelected);

    // Local copies of the parameters.
    CComPtr<IWMPPlaylist> spPlaylist(pPlaylist);
    CComBSTR bstrAttribute(bstrSyncAttribute);

    ATLASSERT (bstrAttribute.Length());

    // Get the count of playlist media items.
    long lCount = 0;
    spPlaylist->get_count(&lCount);

    // Walk the playlist.
    for(long i = 0; i < lCount; i++)
    {
        CComPtr<IWMPMedia> spMedia;                 
        CComBSTR bstrVal;            
        long lPriority = 0;
        
        hr = spPlaylist->get_item(i, &spMedia);

        if(SUCCEEDED(hr) && spMedia)
        {      
            // Get the sync priority value as a string.
            hr = spMedia->getItemInfo(bstrAttribute, &bstrVal);
        }

        if(SUCCEEDED(hr) && spMedia)
        {
            // Convert sync priority to a long number.
            lPriority = _wtol(bstrVal);
        }

        // Sort the playlist.
        // Only move the current item if it has a
        // sync priority value.
        if(lPriority > 0)
        {
            lSyncItemCount++;

            // Walk down the list and insert the item
            // in ascending order.
            for(long j = 0; j < lCount; j++)
            {
                CComPtr<IWMPMedia> spMediaCompare;
                CComBSTR bstrValCompare;
                long lPriorityTest = 0;

                hr = spPlaylist->get_item(j, &spMediaCompare);

                if(SUCCEEDED(hr) && spMediaCompare.p)
                {
                    hr = spMediaCompare->getItemInfo(bstrAttribute, &bstrValCompare);
                }
                if(SUCCEEDED(hr) && spMediaCompare.p)
                {
                    lPriorityTest = _wtol(bstrValCompare);
                    
                    if(lPriority <= lPriorityTest || 
                        0 == lPriorityTest)
                    {
                        hr = spPlaylist->moveItem(i, j);
                        break;                            
                    }                        
                } 
            } // for j                       
        } // if(lPriority > 0)          
    } // for i  
  
    // Return the sync item count.
    *plSelected = lSyncItemCount;

    return hr;
}

IWMPMedia::getItemInfo

IWMPPlaylist::get_item

IWMPPlaylist::moveItem

Administrar listas de reproducción de sincronización

Atributos de sincronización