Share via


Administrador de visualización

El administrador visual es un objeto que controla la apariencia de una aplicación completa.Actúa como una sola clase donde se puede colocar todo el código de dibujo para la aplicación.La biblioteca MFC contiene varios administradores visuales.También puede crear su propio administrador visual si desea crear una vista personalizada para la aplicación.Las imágenes muestran la misma aplicación cuando permiten a los administradores visuales:

MyApp que utiliza el administrador de la representación visual de CMFCVisualManagerWindows

MyApp representadas por CMFCVisualManagerWindows

MyApp que utiliza el administrador de representación visual CMFCVisualManagerVS2005

MyApp representadas por CMFCVisualManagerVS2005

MyApp que utiliza el administrador de la representación visual de CMFCVisualManagerOfficeXP

MyApp representadas por CMFCVisualManagerOfficeXP

MyApp que utiliza el administrador de representación visual CMFCVisualManagerOffice2003

MyApp representadas por CMFCVisualManagerOffice2003

MyApp que utiliza el administrador de representación visual CMFCVisualManagerOffice2007

MyApp representada por CMFCVisualManagerOffice2007

De forma predeterminada, el administrador visual mantiene el código de dibujo para varios elementos de GUI.Para proporcionar elementos personalizados de interfaz de usuario, debe invalidar los métodos relacionados del gráfico de administrador visual.Para la lista de estos métodos, vea CMFCVisualManager (Clase).Los métodos que puede reemplazar para proporcionar un aspecto personalizado son todos los métodos que comienzan con OnDraw.

La aplicación puede tener sólo un objeto de CMFCVisualManager .Para obtener un puntero al administrador visual para la aplicación, llame a la función estática CMFCVisualManager::GetInstance.Dado que todos los administradores visuales heredan de CMFCVisualManager, el método de CMFCVisualManager::GetInstance obtendrán un puntero al administrador visual adecuado, incluso si se crea un administrador visual personalizado.

Si desea crear un administrador visual personalizado, debe derivarlo de un administrador visual que ya existe.La clase predeterminada a derivar de es CMFCVisualManager.Sin embargo, con otro administrador visual si se parece mejor a lo que desea para la aplicación.Por ejemplo, si desea utilizar el administrador visual de CMFCVisualManagerOffice2007 , pero deseado para cambiar solo cómo separadores apariencia, puede derivar la clase personalizada de CMFCVisualManagerOffice2007.En este escenario, debe sobrescribir únicamente los métodos para dibujar los separadores.

Hay dos posibles maneras de utilizar un administrador visual concreto para la aplicación.Una consiste en llamar al método de CMFCVisualManager::SetDefaultManager y pasar el administrador visual adecuado como parámetro.El ejemplo de código siguiente se muestra cómo utilizar el administrador visual de CMFCVisualManagerVS2005 con este método:

CMFCVisualManager::SetDefaultManager (RUNTIME_CLASS (CMFCVisualManagerVS2005));

La otra forma de utilizar un administrador visual en la aplicación es hacerlo manualmente.La aplicación a continuación utilizará en este nuevo administrador visual para toda la representación.Sin embargo, dado que solo puede haber un objeto de CMFCVisualManager por la aplicación, tendrá que eliminar el administrador visual actual antes de crear un nuevo.En el ejemplo siguiente, CMyVisualManager es un administrador visual personalizado que es derivado de CMFCVisualManager.El método siguiente cambiará utilizan a qué administrador visual para mostrar la aplicación, dependiendo de un índice:

void CMyApp::SetSkin (int index)
{
   if (CMFCVisualManager::GetInstance() != NULL)
   {
      delete CMFCVisualManager::GetInstance();
   }

   switch (index)
   {
   case DEFAULT_STYLE:
      // The following statement creates a new CMFCVisualManager
      CMFCVisualManager::GetInstance();
      break;

   case CUSTOM_STYLE:
      new CMyVisualManager;
      break;

   default:
      CMFCVisualManager::GetInstance();
      break;
   }

   CMFCVisualManager::GetInstance()->RedrawAll();
}

Vea también

Referencia

CMFCVisualManager (Clase)

Otros recursos

Interfaz de usuario