Compartir a través de


Clase COleControl

Una clase base eficaz para desarrollar controles OLE.

Sintaxis

class COleControl : public CWnd

Miembros

Constructores públicos

Nombre Descripción
COleControl::COleControl Crea un objeto COleControl.

Métodos públicos

Nombre Descripción
COleControl::AmbientAppearance Recupera la apariencia actual del control.
COleControl::AmbientBackColor Devuelve el valor de la propiedad BackColor del ambiente.
COleControl::AmbientDisplayName Devuelve el nombre del control según lo especificado por el contenedor.
COleControl::AmbientFont Devuelve el valor de la propiedad Font del ambiente.
COleControl::AmbientForeColor Devuelve el valor de la propiedad Fore del ambiente.
COleControl::AmbientLocaleID Devuelve el identificador de configuración regional del contenedor.
COleControl::AmbientScaleUnits Devuelve el tipo de unidades usadas por el contenedor.
COleControl::AmbientShowGrabHandles Determina si se deben mostrar los manipuladores.
COleControl::AmbientShowHatching Determina si se debe mostrar el sombreado.
COleControl::AmbientTextAlign Devuelve el tipo de alineación de texto especificada por el contenedor.
COleControl::AmbientUIDead Determina si el control debe responder a acciones de interfaz de usuario.
COleControl::AmbientUserMode Determina el modo del contenedor.
COleControl::BoundPropertyChanged Notifica al contenedor que se ha modificado una propiedad enlazada.
COleControl::BoundPropertyRequestEdit Solicita permiso para editar el valor de la propiedad.
COleControl::ClientToParent Convierte un punto relativo al origen del control a un punto relativo al origen de su contenedor.
COleControl::ClipCaretRect Ajusta un rectángulo de intercalación si está superpuesto por un control.
COleControl::ControlInfoChanged Llame a esta función después de que el conjunto mnemotécnico manipulado por el control haya cambiado.
COleControl::DisplayError Muestra los eventos de error del stock al usuario del control.
COleControl::DoClick Implementación del método stock DoClick.
COleControl::DoPropExchange Serializa las propiedades de un objeto COleControl.
COleControl::DoSuperclassPaint Vuelve a dibujar un control OLE que se ha sido subclasificado desde un control de Windows.
COleControl::EnableSimpleFrame Habilita el soporte de marcos simples para un control.
COleControl::ExchangeExtent Serializa el ancho y el alto del control.
COleControl::ExchangeStockProps Serializa las propiedades de stock del control.
COleControl::ExchangeVersion Serializa el número de versión del control.
COleControl::FireClick Activa el evento del stock Click.
COleControl::FireDblClick Activa el evento del stock DblClick.
COleControl::FireError Activa el evento del stock Error.
COleControl::FireEvent Activa un evento personalizado.
COleControl::FireKeyDown Activa el evento del stock KeyDown.
COleControl::FireKeyPress Activa el evento del stock KeyPress.
COleControl::FireKeyUp Activa el evento del stock KeyUp.
COleControl::FireMouseDown Activa el evento del stock MouseDown.
COleControl::FireMouseMove Activa el evento del stock MouseMove.
COleControl::FireMouseUp Activa el evento del stock MouseUp.
COleControl::FireReadyStateChange Desencadena un evento cuando el estado de preparación del control cambia.
COleControl::GetActivationPolicy Modifica el comportamiento de activación predeterminado de un control que admite la interfaz IPointerInactive.
COleControl::GetAmbientProperty Devuelve el valor de la propiedad de ambiente especificada.
COleControl::GetAppearance Devuelve el valor de la propiedad Appearance del stock.
COleControl::GetBackColor Devuelve el valor de la propiedad BackColor del stock.
COleControl::GetBorderStyle Devuelve el valor de la propiedad BorderStyle del stock.
COleControl::GetCapture Determina si un objeto de control activado y sin ventana tiene la captura del mouse.
COleControl::GetClassID Recupera el identificador de clase OLE del control.
COleControl::GetClientOffset Recupera la diferencia entre la esquina superior izquierda del área rectangular del control y la esquina superior izquierda de su área de cliente.
COleControl::GetClientRect Recupera el tamaño del área de cliente del control.
COleControl::GetClientSite Consulta a un objeto para el puntero a su sitio cliente actual dentro de su contenedor.
COleControl::GetControlFlags Recupera la configuración de la marca de control.
COleControl::GetControlSize Devuelve la posición y el tamaño del control OLE.
COleControl::GetDC Proporciona un medio para que un control sin ventana obtenga un contexto de dispositivo de su contenedor.
COleControl::GetEnabled Devuelve el valor de la propiedad Enabled del stock.
COleControl::GetExtendedControl Recupera un puntero a un objeto de control extendido que pertenece al contenedor.
COleControl::GetFocus Determina si el control tiene el foco.
COleControl::GetFont Devuelve el valor de la propiedad Font del stock.
COleControl::GetFontTextMetrics Devuelve las métricas de un objeto CFontHolder.
COleControl::GetForeColor Devuelve el valor de la propiedad ForeColor del stock.
COleControl::GetHwnd Devuelve el valor de la propiedad hWnd del stock.
COleControl::GetMessageString Proporciona texto de la barra de estado para un elemento de menú.
COleControl::GetNotSupported Impide el acceso al valor de la propiedad de un control por parte del usuario.
COleControl::GetReadyState Devuelve el estado de preparación del control.
COleControl::GetRectInContainer Devuelve el rectángulo del control relativo con su contenedor.
COleControl::GetStockTextMetrics Devuelve las métricas de la propiedad Font del stock.
COleControl::GetText Devuelve el valor de la propiedad Text o Caption del stock.
COleControl::GetWindowlessDropTarget Invalida para permitir que un control sin ventana sea el destino de las operaciones de arrastrar y colocar.
COleControl::InitializeIIDs Informa a la clase base de los IID que usará el control.
COleControl::InternalGetFont Devuelve un objeto CFontHolder para la propiedad Font del stock.
COleControl::InternalGetText Recupera la propiedad Caption o Text del stock.
COleControl::InternalSetReadyState Establece el estado de preparación del control y desencadena el evento ready-state-change.
COleControl::InvalidateControl Invalida un área del control mostrado, lo que hace que se vuelva a dibujar.
COleControl::InvalidateRgn Invalida el área de cliente de la ventana del contenedor dentro de la región especificada. Se puede usar para volver a dibujar controles sin ventanas en la región.
COleControl::IsConvertingVBX Permite la carga especializada de un control OLE.
COleControl::IsModified Determina si el estado del control ha cambiado.
COleControl::IsOptimizedDraw Indica si el contenedor admite el dibujo optimizado para la operación de dibujo actual.
COleControl::IsSubclassedControl Se llama para determinar si el control establece subclases en un control de Windows.
COleControl::Load Restablece cualquier dato asincrónico anterior e inicia una nueva carga de la propiedad asincrónica del control.
COleControl::LockInPlaceActive Determina si el contenedor puede desactivar el control.
COleControl::OnAmbientPropertyChange Se llama cuando se cambia una propiedad de ambiente.
COleControl::OnAppearanceChanged Se le llama cuando se cambia la propiedad Appearance del stock.
COleControl::OnBackColorChanged Se le llama cuando se cambia la propiedad BackColor del stock.
COleControl::OnBorderStyleChanged Se le llama cuando se cambia la propiedad BorderStyle stock.
COleControl::OnClick Se llama para desencadenar el evento Stock Click.
COleControl::OnClose Notifica al control que IOleControl::Close ha sido llamado.
COleControl::OnDoVerb Se llama después de que finalice la ejecución de un verbo de control.
COleControl::OnDraw Se llama cuando se solicita a un control que se vuelva a dibujar a sí mismo.
COleControl::OnDrawMetafile Lo llama el contenedor cuando se solicita que un control se vuelva a dibujar mediante un contexto de dispositivo de metarchivo.
COleControl::OnEdit Llamado por el contenedor para activar un control OLE en la interfaz de usuario.
COleControl::OnEnabledChanged Se le llama cuando se cambia la propiedad Enabled del stock.
COleControl::OnEnumVerbs Lo llama el contenedor para enumerar los verbos de un control.
COleControl::OnEventAdvise Se llama cuando los controladores de eventos están conectados o desconectados de un control.
COleControl::OnFontChanged Se llama cuando se cambia la propiedad Font del stock.
COleControl::OnForeColorChanged Se llama cuando se cambia la propiedad ForeColor del stock.
COleControl::OnFreezeEvents Se llama cuando los eventos de un control se inmovilizan o descongelan.
COleControl::OnGetColorSet Notifica al control que IOleObject::GetColorSet ha sido llamado.
COleControl::OnGetControlInfo Proporciona información mnemotécnica al contenedor.
COleControl::OnGetDisplayString Se llama para obtener una cadena para representar un valor de propiedad.
COleControl::OnGetInPlaceMenu Solicita el manipulador del menú del control que se combinará con el menú del contenedor.
COleControl::OnGetNaturalExtent Invalida para recuperar el tamaño de visualización del control más cercano al tamaño y el modo de extensión propuestos.
COleControl::OnGetPredefinedStrings Devuelve cadenas que representan los valores posibles para una propiedad.
COleControl::OnGetPredefinedValue Devuelve el valor correspondiente a una cadena predefinida.
COleControl::OnGetViewExtent Invalida para recuperar el tamaño de las áreas de visualización del control (se puede usar para habilitar el dibujo de dos pasos).
COleControl::OnGetViewRect Invalida para convertir el tamaño del control en un rectángulo a partir de una posición específica.
COleControl::OnGetViewStatus Invalida para recuperar el estado de vista del control.
COleControl::OnHideToolBars Lo llama el contenedor cuando se desactiva la interfaz de usuario del control.
COleControl::OnInactiveMouseMove Invalida para que el contenedor del control inactivo bajo el puntero del mouse envíe mensajes WM_MOUSEMOVE al control.
COleControl::OnInactiveSetCursor Invalida para que el contenedor del control inactivo bajo el puntero del mouse envíe mensajes WM_SETCURSOR al control.
COleControl::OnKeyDownEvent Se llama después de que se haya desencadenado el evento KeyDown del stock.
COleControl::OnKeyPressEvent Se llama después de que se haya desencadenado el evento KeyPress del stock.
COleControl::OnKeyUpEvent Se llama después de que se haya desencadenado el evento KeyUp del stock.
COleControl::OnMapPropertyToPage Indica la página de propiedades que se va a usar para editar una propiedad.
COleControl::OnMnemonic Se llama cuando se ha presionado una tecla mnemotécnica del control.
COleControl::OnProperties Se llama cuando se invoca el verbo "Propiedades" del control.
COleControl::OnQueryHitPoint Invalida para consultar si la presentación de un control se superpone a un punto determinado.
COleControl::OnQueryHitRect Invalida para consultar si la presentación de un control se superpone a cualquier punto de un rectángulo determinado.
COleControl::OnRenderData El marco de trabajo llama a este método para recuperar datos en el formato especificado.
COleControl::OnRenderFileData Lo llama el marco para recuperar datos de un archivo en el formato especificado.
COleControl::OnRenderGlobalData Lo llama el marco para recuperar datos de una memoria global en el formato especificado.
COleControl::OnResetState Restablece las propiedades de un control a los valores predeterminados.
COleControl::OnSetClientSite Notifica al control que IOleControl::SetClientSite ha sido llamado.
COleControl::OnSetData Reemplaza los datos del control por otro valor.
COleControl::OnSetExtent Se llama después de que la extensión del control haya cambiado.
COleControl::OnSetObjectRects Se llama después de cambiar las dimensiones del control.
COleControl::OnShowToolBars Se llama cuando se ha activado la IU para el control.
COleControl::OnTextChanged Se llama cuando se cambia la propiedad Text o Caption del stock.
COleControl::OnWindowlessMessage Procesa los mensajes de ventana (distintos de los mensajes del mouse y del teclado) para los controles sin ventana.
COleControl::ParentToClient Convierte un punto relativo al origen del contenedor a un punto relativo al origen del control.
COleControl::PostModalDialog Notifica al contenedor que se cerró un cuadro de diálogo modal.
COleControl::PreModalDialog Notifica al contenedor que se va a mostrar un cuadro de diálogo modal.
COleControl::RecreateControlWindow Destruye y vuelve a crear la ventana del control.
COleControl::Refresh Fuerza un reintentos de la apariencia de un control.
COleControl::ReleaseCapture Libera la captura del mouse.
COleControl::ReleaseDC Libera el contexto del dispositivo de visualización de un contenedor de un control sin ventanas.
COleControl::ReparentControlWindow Restablece el elemento primario de la ventana de control.
COleControl::ResetStockProps Inicializa las propiedades del stock COleControl en sus valores predeterminados.
COleControl::ResetVersion Inicializa el número de versión en un valor determinado.
COleControl::ScrollWindow Permite a un control sin ventana desplazar un área dentro de su imagen activa en la pantalla.
COleControl::SelectFontObject Selecciona una propiedad Font personalizada en un contexto de dispositivo.
COleControl::SelectStockFont Selecciona la propiedad Font del stock personalizada en un contexto de dispositivo.
COleControl::SerializeExtent Serializa o inicializa el espacio para mostrar del control.
COleControl::SerializeStockProps Serializa o inicializa las propiedades del stock COleControl.
COleControl::SerializeVersion Serializa o inicializa la información de versión del control.
COleControl::SetAppearance Establece el valor de la propiedad Appearance del stock.
COleControl::SetBackColor Establece el valor de la propiedad BackColor del stock.
COleControl::SetBorderStyle Establece el valor de la propiedad BorderStyle del stock.
COleControl::SetCapture Hace que la ventana contenedora del control tome posesión de la captura del mouse en nombre del control.
COleControl::SetControlSize Establece la posición y el tamaño del control OLE.
COleControl::SetEnabled Establece el valor de la propiedad Enabled del stock.
COleControl::SetFocus Hace que la ventana contenedora del control tome posesión del foco de entrada en nombre del control.
COleControl::SetFont Establece el valor de la propiedad Font del stock.
COleControl::SetForeColor Establece el valor de la propiedad ForeColor del stock.
COleControl::SetInitialSize Establece el tamaño de un control OLE cuando se muestra por primera vez en un contenedor.
COleControl::SetModifiedFlag Cambia el estado modificado de un control.
COleControl::SetNotPermitted Indica que se ha producido un error en una solicitud de edición.
COleControl::SetNotSupported Impide la modificación del valor de la propiedad de un control por parte del usuario.
COleControl::SetRectInContainer Establece el rectángulo del control relativo con su contenedor.
COleControl::SetText Establece el valor de la propiedad Text o Caption del stock.
COleControl::ThrowError Indica que se ha producido un error en un control OLE.
COleControl::TransformCoords Transforma los valores de coordenadas entre un contenedor y el control.
COleControl::TranslateColor Convierte un valor de OLE_COLOR en un valor COLORREF.
COleControl::WillAmbientsBeValidDuringLoad Determina si las propiedades de ambiente estarán disponibles la próxima vez que se cargue el control.
COleControl::WindowProc Proporciona un procedimiento de Windows para un objeto COleControl.

Métodos protegidos

Nombre Descripción
COleControl::DrawContent Lo llama el marco cuando es necesario actualizar la apariencia del control.
COleControl::DrawMetafile Lo llama el marco cuando se usa el contexto de dispositivo del metarchivo.
COleControl::IsInvokeAllowed Habilita la invocación de métodos de automatización.
COleControl::SetInitialDataFormats Lo llama el marco para inicializar la lista de formatos de datos admitidos por el control.

Comentarios

Esta clase, que se deriva de CWnd, hereda toda la funcionalidad de un objeto de ventana de Windows más la funcionalidad adicional específica de OLE, como la activación de eventos y la capacidad de admitir métodos y propiedades.

Los controles OLE se pueden insertar en aplicaciones del contenedor OLE y comunicarse con el contenedor mediante un sistema bidireccional de activación de eventos y exposición de métodos y propiedades al contenedor. Tenga en cuenta que los contenedores OLE estándar solo admiten la funcionalidad básica de un control OLE. No pueden admitir las características extendidas de un control OLE. La activación de eventos se produce cuando se envían eventos al contenedor como resultado de determinadas acciones que se realizan en el control. A su vez, el contenedor se comunica con el control mediante un conjunto expuesto de métodos y propiedades análogo a las funciones miembro y a los miembros de datos de una clase C++. Este enfoque permite al desarrollador controlar la apariencia del control y notificar al contenedor cuando se producen ciertas acciones.

Controles sin ventana

Los controles OLE se pueden usar en contexto activo sin una ventana. Los controles sin ventanas tienen ventajas significativas:

  • Los controles sin ventanas pueden ser transparentes y no rectangulares

  • Los controles sin ventanas reducen el tamaño de la instancia y el tiempo de creación del objeto

Los controles no necesitan una ventana. Los servicios que ofrece una ventana se pueden proporcionar fácilmente a través de una sola ventana compartida (normalmente del contenedor) y un poco de código de envío. Tener una ventana es sobre todo una complicación innecesaria en el objeto.

Cuando se usa la activación sin ventana, el contenedor (que sí tiene una ventana) es responsable de proporcionar servicios que, de lo contrario, habrían sido proporcionados por la propia ventana del control. Por ejemplo, si el control necesita consultar el foco del teclado, consultar la captura del mouse u obtener un contexto del dispositivo, el contenedor administra estas operaciones. Las funciones miembro de operación COleControl sin ventana invocan estas operaciones en el contenedor.

Cuando la activación sin ventana está habilitada, el contenedor delega los mensajes de entrada en la interfaz IOleInPlaceObjectWindowless del control (una extensión de IOleInPlaceObject para la compatibilidad sin ventanas). La implementación de COleControl de esta interfaz enviará estos mensajes a través de la asignación de mensajes del control después de ajustar las coordenadas del mouse correctamente. Se pueden procesar estos mensajes igual que los mensajes normales de la ventana, al agregar las entradas correspondientes a la asignación de mensajes.

En un control sin ventanas, siempre se debe usar las funciones miembro COleControl en lugar de las funciones miembro correspondientes CWnd o sus funciones API de Windows relacionadas.

Los objetos de control OLE también pueden crear una ventana solo cuando se activan, pero la cantidad de trabajo necesaria para la transición inactiva-activa aumenta y la velocidad de la transición disminuye. Hay casos en los que esto es un problema: por ejemplo, considere una cuadrícula de cuadros de texto. Al desplazarse hacia arriba y hacia abajo por la columna, cada control debe activarse en contexto y después desactivarse. La velocidad de la transición inactiva/activa afectará directamente a la velocidad de desplazamiento.

Para obtener más información sobre el desarrollo de un marco de control OLE, consulte los artículos Controles MFC ActiveX y Resumen: Creación de un programa de control MFC ActiveX. Para obtener información sobre cómo optimizar los controles OLE, incluidos los controles sin ventanas y sin parpadeo, consulte Controles ActiveX de MFC: Optimización.

Jerarquía de herencia

CObject

CCmdTarget

CWnd

COleControl

Requisitos

Encabezado: afxctl.h

COleControl::AmbientBackColor

Devuelve el valor de la propiedad BackColor del ambiente.

OLE_COLOR AmbientBackColor();

Valor devuelto

Valor actual de la propiedad de ambiente BackColor del contenedor, si existe. Si no se admite la propiedad, esta función devuelve el color de fondo de Windows definido por el sistema.

Comentarios

La propiedad de ambiente BackColor está disponible para todos los controles y está definida por el contenedor. Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientDisplayName

El nombre que el contenedor ha asignado al control se puede usar en los mensajes de error que se muestran al usuario.

CString AmbientDisplayName();

Valor devuelto

Nombre del control OLE. El valor predeterminado es una cadena de longitud cero.

Comentarios

Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientFont

Devuelve el valor de la propiedad Font del ambiente.

LPFONTDISP AmbientFont();

Valor devuelto

Puntero a la interfaz de distribución de fuentes de ambiente del contenedor. El valor predeterminado es NULL. Si la devolución no es igual a NULL, es responsable de liberar la fuente a llamar a su función miembro IUnknown::Release.

Comentarios

La propiedad de ambiente Font se define mediante el contenedor y está disponible para todos los controles. Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientForeColor

Devuelve el valor de la propiedad Fore del ambiente.

OLE_COLOR AmbientForeColor();

Valor devuelto

Valor actual de la propiedad de ambiente ForeColor del contenedor, si existe. Si no se admite, esta función devuelve el color de texto de Windows definido por el sistema.

Comentarios

La propiedad de ambiente ForeColor está disponible para todos los controles y está definida por el contenedor. Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientLocaleID

Devuelve el identificador de configuración regional del contenedor.

LCID AmbientLocaleID();

Valor devuelto

Valor de la propiedad LocaleID del contenedor, si existe. Si no se admite esta propiedad, esta función devuelve 0.

Comentarios

El control puede usar LocaleID para adaptar su interfaz de usuario para las configuraciones regionales específicas. Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientAppearance

Recupera la configuración de apariencia actual del objeto de control.

short AmbientAppearance();

Valor devuelto

La apariencia del control:

  • 0 Apariencia plana

  • 1 Apariencia 3D

Comentarios

Llame a esta función para recuperar el valor actual de la propiedad DISPID_AMBIENT_APPEARANCE para el control.

COleControl::AmbientScaleUnits

Devuelve el tipo de unidades usadas por el contenedor.

CString AmbientScaleUnits();

Valor devuelto

Cadena que contiene las ScaleUnits de ambiente del contenedor. Si no se admite esta propiedad, esta función devuelve una cadena de longitud 0.

Comentarios

La propiedad de ambiente ScaleUnits del contenedor se puede usar para mostrar posiciones o dimensiones etiquetadas con la unidad elegida, como twips o centímetros. Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientShowGrabHandles

Determina si el contenedor permite que el control muestre manipuladores de agarre para sí mismo cuando está activo.

BOOL AmbientShowGrabHandles();

Valor devuelto

Distinto de cero si se deben mostrar manipuladores de agarre; de lo contrario es 0. Si no se admite esta propiedad, esta función devuelve 0.

Comentarios

Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientShowHatching

Determina si el contenedor permite que el control se muestre a sí mismo con un patrón sombreado cuando la interfaz de usuario está activa.

BOOL AmbientShowHatching();

Valor devuelto

Distinto de cero si se debe mostrar el patrón sombreado; de lo contrario es 0. Si no se admite esta propiedad, esta función devuelve 0.

Comentarios

Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientTextAlign

Determina la alineación del texto ambiente preferida por el contenedor de controles.

short AmbientTextAlign();

Valor devuelto

Estado de la propiedad de ambiente TextAlign del contenedor. Si no se admite esta propiedad, esta función devuelve 0.

A continuación se muestra una lista de valores devueltos válidos:

Valor devuelto Significado
0 Alineación general (números a la derecha, texto a la izquierda).
1 Justificar a la izquierda
2 Centro
3 Justificar a la derecha

Comentarios

Esta propiedad está disponible para todos los controles incrustados y está definida por el contenedor. Tenga en cuenta que el contenedor no es necesario para admitir esta propiedad.

COleControl::AmbientUIDead

Determina si el contenedor quiere que el control responda a las acciones de la interfaz de usuario.

BOOL AmbientUIDead();

Valor devuelto

Distinto a cero si el control debe responder a acciones de interfaz de usuario, de lo contrario es 0. Si no se admite esta propiedad, esta función devuelve 0.

Comentarios

Por ejemplo, un contenedor podría establecer esto en TRUE en modo de diseño.

COleControl::AmbientUserMode

Determina si el contenedor está en modo de diseño o en modo de usuario.

BOOL AmbientUserMode();

Valor devuelto

Distinto de cero si el contenedor está en modo de usuario; en caso contrario es 0 (en modo de diseño). Si no se admite esta propiedad, esta función devuelve 0.

Comentarios

Por ejemplo, un contenedor podría establecer esto en FALSE en modo de diseño.

COleControl::BoundPropertyChanged

Indica que el valor de la propiedad enlazada ha cambiado.

void BoundPropertyChanged(DISPID dispid);

Parámetros

dispid
Identificador de envío de una propiedad enlazada del control.

Comentarios

Se debe llamar a esto cada vez que el valor de la propiedad cambie, incluso en los casos en los que el cambio no se realizó a través del método Set de propiedades. Tenga en cuenta especialmente de las propiedades enlazadas que se asignan a variables miembro. Cada vez que cambie esta variable miembro, se debe llamar a BoundPropertyChanged.

COleControl::BoundPropertyRequestEdit

Solicita permiso de la interfaz IPropertyNotifySink para cambiar un valor de propiedad enlazado proporcionado por el control.

BOOL BoundPropertyRequestEdit(DISPID dispid);

Parámetros

dispid
Identificador de envío de una propiedad enlazada del control.

Valor devuelto

Distinto de cero si se permite el cambio; de lo contrario es 0. El valor predeterminado es distinto de cero.

Comentarios

Si se deniega el permiso, el control no debe permitir que el valor de la propiedad cambie. Esto se puede hacer ignorando o fallando la acción que intentó cambiar el valor de la propiedad.

COleControl::ClientToParent

Convierte las coordenadas de pPoint en coordenadas primarias.

virtual void ClientToParent(
    LPCRECT lprcBounds,
    LPPOINT pPoint) const;

Parámetros

lprcBounds
Puntero a los límites del control OLE dentro del contenedor. No el área de cliente, sino el área de todo el control, incluidos los bordes y las barras de desplazamiento.

pPoint
Puntero al punto de área de cliente OLE que se va a trasladar a las coordenadas del elemento primario (contenedor).

Comentarios

En el pPoint de entrada es relativo al origen del área cliente del control OLE (esquina superior izquierda del área cliente del control). En el pPoint de salida es relativo al origen del elemento primario (esquina superior izquierda del contenedor).

COleControl::ClipCaretRect

Ajusta un rectángulo de intercalación si está cubierto total o parcialmente mediante objetos opacos superpuestos.

BOOL ClipCaretRect(LPRECT lpRect);

Parámetros

lpRect
En la entrada, un puntero a una estructura RECT que contiene el área de intercalación que se va a ajustar. En la salida, el área de intercalación ajustada o NULL si el rectángulo de intercalación está completamente cubierto.

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

Un cuadro de intercalación es una línea, un bloque o un mapa de bits que normalmente indica dónde se insertarán texto o gráficos.

Un objeto sin ventanas no puede mostrar de forma segura un cuadro de intercalación sin comprobar primero si éste está parcialmente o totalmente oculto por objetos superpuestos. Para que sea posible, un objeto puede usar ClipCaretRect para ajustar el cuadro de intercalación (reducido) para asegurarse de que encaja en la región de recorte.

Los objetos que crean un cuadro de intercalación deben enviar el rectángulo de intercalación a ClipCaretRect y usar el rectángulo ajustado para el cuadro de intercalación. Si el cuadro de intercalación está completamente oculto, este método devolverá FALSE y el cuadro de intercalación no debe mostrarse en absoluto en este caso.

COleControl::COleControl

Construye un objeto COleControl.

COleControl();

Comentarios

Normalmente esta función no se llama directamente. En su lugar, el control OLE suele ser creado por su generador de clases.

COleControl::ControlInfoChanged

Llame a esta función cuando el conjunto mnemotécnico admitido por el control haya cambiado.

void ControlInfoChanged();

Comentarios

Al recibir esta notificación, el contenedor del control obtiene el nuevo conjunto mnemotécnico al realizar una llamada a IOleControl::GetControlInfo. Tenga en cuenta que el contenedor no es necesario para responder a esta notificación.

COleControl::DisplayError

Lo llama el marco después de controlar el evento de error del stock (a menos que el controlador de eventos haya suprimido la presentación del error).

virtual void DisplayError(
    SCODE scode,
    LPCTSTR lpszDescription,
    LPCTSTR lpszSource,
    LPCTSTR lpszHelpFile,
    UINT nHelpID);

Parámetros

scode
Valor de código de estado que se va a informar. Para obtener una lista completa de los posibles códigos, consulte el artículo Controles ActiveX: Temas avanzados.

lpszDescription
Descripción del error que se está notificando.

lpszSource
Nombre del módulo que genera el error (normalmente, el nombre del módulo de control OLE).

lpszHelpFile
Nombre del archivo de ayuda que contiene una descripción del error.

nHelpID
Identificador de contexto de ayuda del error que se está informando.

Comentarios

El comportamiento predeterminado muestra un cuadro de mensaje que contiene la descripción del error, contenida en lpszDescription.

Invalide esta función para personalizar cómo se muestran los errores.

COleControl::DoClick

Simula una acción de clic del mouse en el control.

void DoClick();

Comentarios

Se llamará a la función miembro reemplazable COleControl::OnClick y se desencadenará un evento Click del stock, si el control lo admite.

Esta función es compatible con la clase base COleControl como método del stock, denominado DoClick. Para obtener más información, consulte el artículo Métodos de control ActiveX.

COleControl::DoPropExchange

Lo llama el marco al cargar o almacenar un control desde una representación de almacenamiento persistente, como una secuencia o un conjunto de propiedades.

virtual void DoPropExchange(CPropExchange* pPX);

Parámetros

pPX
Puntero a un objeto CPropExchange . El marco de trabajo proporciona este objeto para establecer el contexto del intercambio de propiedades, incluida su dirección.

Comentarios

Esta función usualmente realiza llamadas a la familia de funciones PX_ para cargar o almacenar propiedades específicas definidas por el usuario de un control OLE.

Si se ha usado el Asistente de controles para crear el proyecto de control OLE, la versión invalidada de esta función serializará las propiedades del stock compatibles COleControl con una llamada a la función de clase base, COleControl::DoPropExchange. A medida que se agreguen propiedades definidas por el usuario al control OLE, se deberá modificar esta función para serializar las nuevas propiedades. Para obtener más información sobre la serialización, vea el artículo Controles ActiveX: Serializar.

COleControl::DoSuperclassPaint

Vuelve a dibujar un control OLE que se ha sido subclasificado desde un control de Windows.

void DoSuperclassPaint(
    CDC* pDC,
    const CRect& rcBounds);

Parámetros

pDC
Puntero al contexto del dispositivo del contenedor de control.

rcBounds
Área en la que se va a dibujar el control.

Comentarios

Llame a esta función para manipular correctamente la pintura de un control OLE no activo. Esta función solo debe usarse si el control OLE hace de un control de Windows una subclase y se debe llamar a en la función OnDraw del control.

Para obtener más información sobre esta función y hacer de un control de Windows una subclase, consulte el artículo Controles ActiveX: Subclasificación de un control de Windows.

COleControl::DrawContent

Lo llama el marco cuando es necesario actualizar la apariencia del control.

void DrawContent(
    CDC* pDC,
    CRect& rc);

Parámetros

pDC
Puntero al contexto de dispositivo.

Rc
Área rectangular en la que se va a dibujar.

Comentarios

Esta función llama directamente a la función reemplazable OnDraw.

COleControl::DrawMetafile

Lo llama el marco cuando se usa el contexto de dispositivo del metarchivo.

void DrawMetafile(
    CDC* pDC,
    CRect& rc);

Parámetros

pDC
Puntero al contexto del dispositivo del metarchivo.

Rc
Área rectangular en la que se va a dibujar.

COleControl::EnableSimpleFrame

Habilita la característica del marco simple para un control OLE.

void EnableSimpleFrame();

Comentarios

Esta característica permite que un control admita la contención visual de otros controles, pero no la verdadera contención OLE. Un ejemplo sería un cuadro de grupo con varios controles dentro. Estos controles no están incluidos en OLE, pero están en el mismo cuadro de grupo.

COleControl::ExchangeExtent

Serializa o inicializa el estado de la extensión del control (sus dimensiones en unidades HIMETRIC).

BOOL ExchangeExtent(CPropExchange* pPX);

Parámetros

pPX
Puntero a un objeto CPropExchange. El marco de trabajo proporciona este objeto para establecer el contexto del intercambio de propiedades, incluida su dirección.

Valor devuelto

Es distinto de cero si la función se realiza correctamente; de lo contrario es 0.

Comentarios

Se llama normalmente a esta función mediante la implementación predeterminada de COleControl::DoPropExchange.

COleControl::ExchangeStockProps

Serializa o inicializa el estado de las propiedades del stock del control.

void ExchangeStockProps(CPropExchange* pPX);

Parámetros

pPX
Puntero a un objeto CPropExchange. El marco de trabajo proporciona este objeto para establecer el contexto del intercambio de propiedades, incluida su dirección.

Comentarios

Se llama normalmente a esta función mediante la implementación predeterminada de COleControl::DoPropExchange.

COleControl::ExchangeVersion

Serializa o inicializa el estado de la información de la versión de un control.

BOOL ExchangeVersion(
    CPropExchange* pPX,
    DWORD dwVersionDefault,
    BOOL bConvert = TRUE);

Parámetros

pPX
Puntero a un objeto CPropExchange . El marco de trabajo proporciona este objeto para establecer el contexto del intercambio de propiedades, incluida su dirección.

dwVersionDefault
Número de versión actual del control.

bConvert
Indica si los datos persistentes se deben convertir al formato más reciente al guardarse o mantenerse en el mismo formato que se cargó.

Valor devuelto

Es distinto de cero si la función se realiza correctamente; de lo contrario es 0.

Comentarios

Normalmente, esta será la primera función a la que llama la invalidación de un control de COleControl::DoPropExchange. Al cargar, esta función lee el número de versión de los datos persistentes y establece el atributo de la versión del objeto CPropExchange en consecuencia. Al guardar, esta función escribe el número de versión de los datos persistentes.

Para obtener más información sobre la persistencia y el control de versiones, consulte el artículo Controles ActiveX: Serializar.

COleControl::FireClick

Lo llama el marco cuando se hace clic en el mouse sobre un control activo.

void FireClick();

Comentarios

Si este evento se define como un evento personalizado, se determina cuándo se desencadena el evento.

Para que se produzca un desencadenamiento automático de un evento Click, la asignación de eventos del control debe tener definido un evento Click del stock.

COleControl::FireDblClick

Lo llama el marco cuando se hace doble clic en el mouse sobre un control activo.

void FireDblClick();

Comentarios

Si este evento se define como un evento personalizado, se determina cuándo se desencadena el evento.

Para que se produzca un desencadenamiento automático de un evento DblClick, la asignación de eventos del control debe tener definido un evento DblClick del stock.

COleControl::FireError

Activa el evento error del stock.

void FireError(
    SCODE scode,
    LPCTSTR lpszDescription,
    UINT nHelpID = 0);

Parámetros

scode
Valor de código de estado que se va a informar. Para obtener una lista completa de los posibles códigos, consulte el artículo Controles ActiveX: Temas avanzados.

lpszDescription
Descripción del error que se está notificando.

nHelpID
Identificador de ayuda del error que se está informando.

Comentarios

Este evento proporciona una manera de indicar, en los lugares adecuados del código, que se ha producido un error dentro del control. A diferencia de otros eventos del stock, como Click o MouseMove, el marco nunca desencadena el error.

Para notificar un error que se produce durante una función get de propiedades, una función de conjunto de propiedades o un método de automatización, llame a COleControl::ThrowError.

La implementación del evento de error del stock de un control OLE usa un valor SCODE. Si el control usa este evento y está pensado para usarse en Visual Basic 4.0, se recibirán errores porque el valor de SCODE no se admite en Visual Basic.

Para corregirlo, cambie manualmente el parámetro SCODE en el archivo .ODL del control en un objeto long. Además, cualquier evento, método o propiedad personalizada que use un parámetro SCODE también provoca el mismo problema.

COleControl::FireEvent

Desencadena un evento definido por el usuario desde el control con cualquier número de argumentos opcionales.

void AFX_CDECL FireEvent(
    DISPID dispid,
    BYTE* pbParams,
...);

Parámetros

dispid
El valor de este parámetro se corresponde con el id. de distribución del evento que se va a activar.

pbParams
Descriptor para los tipos de parámetros del evento.

Comentarios

Normalmente, esta función no debe llamarse directamente. En su lugar, llamará a las funciones de activación de eventos en la sección de asignación de eventos de la declaración de la clase de control.

El argumento pbParams es una lista separada por espacios de VTS_. Uno o varios de estos valores, separados por espacios (no por comas), especifican la lista de parámetros de la función. Los valores posibles son los siguientes:

Símbolo Parameter type (Tipo de parámetro)
VTS_COLOR OLE_COLOR
VTS_FONT IFontDisp*
VTS_HANDLE HWND
VTS_PICTURE IPictureDisp*
VTS_OPTEXCLUSIVE OLE_OPTEXCLUSIVE*
VTS_TRISTATE OLE_TRISTATE
VTS_XPOS_HIMETRIC OLE_XPOS_HIMETRIC
VTS_YPOS_HIMETRIC OLE_YPOS_HIMETRIC
VTS_XPOS_PIXELS OLE_XPOS_PIXELS
VTS_YPOS_PIXELS OLE_YPOS_PIXELS
VTS_XSIZE_PIXELS OLE_XSIZE_PIXELS
VTS_YSIZE_PIXELS OLE_XSIZE_PIXELS
VTS_XSIZE_HIMETRIC OLE_XSIZE_HIMETRIC
VTS_YSIZE_HIMETRIC OLE_XSIZE_HIMETRIC

Nota:

Se han definido constantes variant adicionales para todos los tipos de variante, excepto VTS_FONT y VTS_PICTURE, que proporcionan un puntero a la constante de datos variant. Estas constantes se denominan mediante la convención de VTS_P<CONSTANT-NAME>. Por ejemplo, VTS_PCOLOR es un puntero a una constante VTS_COLOR.

COleControl::FireKeyDown

Lo llama el marco cuando se presiona una tecla mientras el control está activo.

void FireKeyDown(
    USHORT* pnChar,
    short nShiftState);

Parámetros

pnChar
Puntero al valor de código de la clave virtual de la tecla presionada. Para obtener una lista de códigos de tecla virtual estándar, consulte Winuser.h.

nShiftState
Contiene una combinación de las marcas de los menú siguientes:

  • SHIFT_MASK se presionó la tecla MAYÚS durante la acción.

  • CTRL_MASK se presionó la tecla CONTROL durante la acción.

  • ALT_MASK se presionó la tecla ALT durante la acción.

Comentarios

Si este evento se define como un evento personalizado, se determina cuándo se desencadena el evento.

Para que se produzca un desencadenamiento automático de un evento KeyDown, la asignación de eventos del control debe tener definido un evento KeyDown del stock.

COleControl::FireKeyPress

Lo llama el marco cuando se presiona y libera una tecla mientras el control personalizado está activo en el contenedor.

void FireKeyPress(USHORT* pnChar);

Parámetros

pnChar
Puntero al valor de carácter de la tecla presionada.

Comentarios

Si este evento se define como un evento personalizado, se determina cuándo se desencadena el evento.

El destinatario del evento puede modificar pnChar, por ejemplo, convertir todos los caracteres en minúsculas por mayúsculas. Si desea examinar el carácter modificado, invalide OnKeyPressEvent.

Para que se produzca un desencadenamiento automático de un evento KeyPress, la asignación de eventos del control debe tener definido un evento KeyPress del stock.

COleControl::FireKeyUp

Lo llama el marco cuando se libera una tecla mientras el control personalizado está activo en el contenedor.

void FireKeyUp(
    USHORT* pnChar,
    short nShiftState);

Parámetros

pnChar
Puntero al valor de código de la clave virtual de la tecla liberada. Para obtener una lista de códigos de tecla virtual estándar, consulte Winuser.h.

nShiftState
Contiene una combinación de las marcas de los menú siguientes:

  • SHIFT_MASK se presionó la tecla MAYÚS durante la acción.

  • CTRL_MASK se presionó la tecla CONTROL durante la acción.

  • ALT_MASK se presionó la tecla ALT durante la acción.

Comentarios

Si este evento se define como un evento personalizado, se determina cuándo se desencadena el evento.

Para que se produzca un desencadenamiento automático de un evento KeyUp, la asignación de eventos del control debe tener definido un evento KeyUp del stock.

COleControl::FireMouseDown

Lo llama el marco cuando se presiona un botón del mouse sobre un control personalizado activo.

void FireMouseDown(
    short nButton,
    short nShiftState,
    OLE_XPOS_PIXELS x,
    OLE_YPOS_PIXELS y);

Parámetros

nButton
Valor numérico del botón del mouse presionado. Puede contener uno de los siguientes valores:

  • LEFT_BUTTON, se presionó el botón izquierdo del mouse.

  • MIDDLE_BUTTON, se presionó el botón central del mouse.

  • RIGHT_BUTTON, se presionó el botón derecho del mouse.

nShiftState
Contiene una combinación de las marcas de los menú siguientes:

  • SHIFT_MASK se presionó la tecla MAYÚS durante la acción.

  • CTRL_MASK se presionó la tecla CONTROL durante la acción.

  • ALT_MASK se presionó la tecla ALT durante la acción.

x
Coordenada x del cursor cuando se presionó un botón del mouse. La coordenada es relativa a la esquina superior izquierda de la ventana de control.

y
Coordenada y del cursor cuando se presionó un botón del mouse. La coordenada es relativa a la esquina superior izquierda de la ventana de control.

Comentarios

Si este evento se define como un evento personalizado, se determina cuándo se desencadena el evento.

Para que se produzca un desencadenamiento automático de un evento MouseDown, la asignación de eventos del control debe tener definido un evento MouseDown del stock.

COleControl::FireMouseMove

Lo llama el marco cuando el cursor se mueve sobre un control personalizado activo.

void FireMouseMove(
    short nButton,
    short nShiftState,
    OLE_XPOS_PIXELS x,
    OLE_YPOS_PIXELS y);

Parámetros

nButton
Valor numérico de los botones del mouse presionados. Contiene una combinación de las marcas de los valores siguientes:

  • LEFT_BUTTON, se presionó el botón izquierdo del mouse durante la acción.

  • MIDDLE_BUTTON, se presionó el botón central del mouse durante la acción.

  • RIGHT_BUTTON, se presionó el botón derecho del mouse durante la acción.

nShiftState
Contiene una combinación de las marcas de los menú siguientes:

  • SHIFT_MASK se presionó la tecla MAYÚS durante la acción.

  • CTRL_MASK se presionó la tecla CONTROL durante la acción.

  • ALT_MASK se presionó la tecla ALT durante la acción.

x
Coordenada x del cursor. La coordenada es relativa a la esquina superior izquierda de la ventana de control.

y
Coordenada y del cursor. La coordenada es relativa a la esquina superior izquierda de la ventana de control.

Comentarios

Si este evento se define como un evento personalizado, se determina cuándo se desencadena el evento.

Para que se produzca un desencadenamiento automático de un evento MouseMove, la asignación de eventos del control debe tener definido un evento MouseMove del stock.

COleControl::FireMouseUp

Lo llama el marco cuando se libera un botón del mouse sobre un control personalizado activo.

void FireMouseUp(
    short nButton,
    short nShiftState,
    OLE_XPOS_PIXELS x,
    OLE_YPOS_PIXELS y);

Parámetros

nButton
Valor numérico del botón del mouse liberado. Puede tener uno de los siguientes valores:

  • LEFT_BUTTON se liberó el botón izquierdo del mouse.

  • MIDDLE_BUTTON, se liberó el botón central del mouse.

  • RIGHT_BUTTON, se liberó el botón derecho del mouse.

nShiftState
Contiene una combinación de las marcas de los menú siguientes:

  • SHIFT_MASK se presionó la tecla MAYÚS durante la acción.

  • CTRL_MASK se presionó la tecla CONTROL durante la acción.

  • ALT_MASK se presionó la tecla ALT durante la acción.

x
Coordenada x del cursor cuando se liberó un botón del mouse. La coordenada es relativa a la esquina superior izquierda de la ventana de control.

y
Coordenada y un cursor cuando se liberó un botón del mouse. La coordenada es relativa a la esquina superior izquierda de la ventana de control.

Comentarios

Si este evento se define como un evento personalizado, se determina cuándo se desencadena el evento.

Para que se produzca un desencadenamiento automático de un evento MouseUp, la asignación de eventos del control debe tener definido un evento MouseUp del stock.

COleControl::FireReadyStateChange

Desencadena un evento con el valor actual del estado de preparación del control.

void FireReadyStateChange();

Comentarios

El estado de preparación puede ser uno de los siguientes valores:

Nombre Descripción
READYSTATE_UNINITIALIZED Estado de inicialización predeterminado
READYSTATE_LOADING El control está cargando actualmente sus propiedades
READYSTATE_LOADED Se ha inicializado el control
READYSTATE_INTERACTIVE El control tiene suficientes datos para ser interactivos, pero no todos los datos asincrónicos están todavía cargados
READYSTATE_COMPLETE El control tiene todos sus datos

Use GetReadyState para determinar la preparación actual del control.

InternalSetReadyState cambia el estado de preparación al valor proporcionado y, después llama a FireReadyStateChange.

COleControl::GetActivationPolicy

Modifica el comportamiento de activación predeterminado de un control que admite la interfaz IPointerInactive.

virtual DWORD GetActivationPolicy();

Valor devuelto

Una combinación de marcas de la enumeración POINTERINACTIVE. Las marcas posibles son:

Nombre Descripción
POINTERINACTIVE_ACTIVATEONENTRY El objeto debe activarse en el lugar cuando el mouse entra en él durante una operación de movimiento del mouse.
POINTERINACTIVE_DEACTIVATEONLEAVE El objeto debe desactivarse cuando el mouse sale del objeto durante una operación de movimiento del mouse.
POINTERINACTIVE_ACTIVATEONDRAG El objeto debe activarse en el lugar cuando el mouse se arrastra sobre él durante una operación de arrastrar y colocar.

Comentarios

Cuando la interfaz IPointerInactive está habilitada, el contenedor delegará en él los mensajes WM_SETCURSOR y WM_MOUSEMOVE. La implementación de COleControl de esta interfaz enviará estos mensajes a través de la asignación de mensajes del control después de ajustar las coordenadas del mouse correctamente.

Cada vez que el contenedor recibe un mensaje de WM_SETCURSOR o WM_MOUSEMOVE con el puntero del mouse sobre un objeto inactivo que admita IPointerInactive, debe llamar a GetActivationPolicy en la interfaz y devolver marcas desde la enumeración POINTERINACTIVE.

Se pueden procesar los mensajes igual que los mensajes normales de la ventana, al agregar las entradas correspondientes a la asignación de mensajes. En los controladores, evite usar la variable miembro m_hWnd (o cualquier función miembro que la use) sin primero comprobar que su valor no es NULL.

Cualquier objeto que pretenda hacer más que establecer el cursor del mouse o activar un evento de movimiento del mouse, como proporcionar comentarios visuales especiales, debe devolver la marca POINTERINACTIVE_ACTIVATEONENTRY y dibujar los comentarios solo cuando está activo. Si el objeto devuelve esta marca, el contenedor debe activarlo inmediatamente y después reenviar el mismo mensaje que desencadenó la llamada a GetActivationPolicy.

Si se devuelven las marcas POINTERINACTIVE_ACTIVATEONENTRY y POINTERINACTIVE_DEACTIVATEONLEAVE, el objeto solo se activará cuando el mouse esté sobre el objeto. Si solo se devuelve la marca de POINTERINACTIVE_ACTIVATEONENTRY, el objeto solo se activará una vez cuando el mouse entre por primera vez en el objeto.

También puede querer que un control inactivo sea el destino de una operación OLE de arrastrar y colocar. Esto requiere la activación del control en el momento en que el usuario arrastra un objeto sobre él, de modo que la ventana del control pueda registrarse como destino de colocación. Para que se produzca la activación durante una operación de arrastre, devuelva la marca POINTERINACTIVE_ACTIVATEONDRAG:

DWORD CMyAxCtrl::GetActivationPolicy()
{
   return POINTERINACTIVE_ACTIVATEONDRAG;
}

Un contenedor no debe almacenar en caché la información comunicada por GetActivationPolicy. En su lugar, se debe llamar a este método cada vez que el mouse entre en un objeto inactivo.

Si un objeto inactivo no solicita activarse en contexto cuando el mouse entra en él, su contenedor debe enviar mensajes posteriores WM_SETCURSOR a este objeto llamando a OnInactiveSetCursor siempre que el puntero del mouse permanezca sobre el objeto.

La activación de la interfaz IPointerInactive usualmente significa que se desea que el control sea capaz de procesar los mensajes del mouse en todo momento. Para obtener este comportamiento en un contenedor que no admite la interfaz IPointerInactive, es necesario que el control esté siempre activado cuando sea visible, lo que significa que el control debe tener la marca OLEMISC_ACTIVATEWHENVISIBLE entre sus diversas marcas. Sin embargo, para evitar que esta marca tenga efecto en un contenedor que admita IPointerInactive, también se puede especificar la marca OLEMISC_IGNOREACTIVATEWHENVISIBLE:

static const DWORD BASED_CODE _dwMyOleMisc =
    OLEMISC_ACTIVATEWHENVISIBLE |
    OLEMISC_IGNOREACTIVATEWHENVISIBLE |
    OLEMISC_SETCLIENTSITEFIRST |
    OLEMISC_INSIDEOUT |
    OLEMISC_CANTLINKINSIDE |
    OLEMISC_RECOMPOSEONRESIZE;

COleControl::GetAmbientProperty

Obtiene el valor de una propiedad ambiente del contenedor.

BOOL GetAmbientProperty(
    DISPID dispid,
    VARTYPE vtProp,
    void* pvProp);

Parámetros

dwDispid
El Id. de distribución de la propiedad de ambiente deseada.

vtProp
Etiqueta de tipo variant que especifica el tipo del valor que se va a devolver en pvProp.

pvProp
Punto a la dirección de la variable que recibirá el valor de la propiedad o el valor devuelto. El tipo real de este puntero debe coincidir con el tipo especificado por vtProp.

vtProp Tipo de pvProp
VT_BOOL BOOL*
VT_BSTR CString*
VT_I2 short*
VT_I4 long*
VT_R4 float*
VT_R8 double*
VT_CY CY*
VT_COLOR OLE_COLOR*
VT_DISPATCH LPDISPATCH*
VT_FONT LPFONTDISP*

Valor devuelto

Distinto de cero si se admite la propiedad ambiente; de lo contrario es 0.

Comentarios

Si usa GetAmbientProperty para recuperar las propiedades de ambiente DisplayName y ScaleUnits, establezca vtProp en VT_BSTR y pvProp en CString*. Si va a recuperar la propiedad ambiente Font, establezca vtProp en VT_FONT y pvProp en LPFONTDISP*.

Tenga en cuenta que las funciones ya se han proporcionado para propiedades de ambiente comunes, como AmbientBackColor y AmbientFont.

COleControl::GetAppearance

Implementa la función Get de la propiedad Appearance del stock de control.

short GetAppearance ();

Valor devuelto

El valor devuelto especifica el valor de apariencia actual como un valor short (VT_I2), si se ejecuta correctamente. Este valor es cero si la apariencia del control es plana y 1 si la apariencia del control es 3D.

COleControl::GetBackColor

Implementa la función Get de la propiedad BackColor del stock de control.

OLE_COLOR GetBackColor();

Valor devuelto

El valor devuelto especifica el color de fondo actual como un valor de OLE_COLOR, si se ejecuta correctamente. Este valor se puede traducir a un valor COLORREF con una llamada a TranslateColor.

COleControl::GetBorderStyle

Implementa la función Get de la propiedad BorderStyle del stock de control.

short GetBorderStyle();

Valor devuelto

1 si el control tiene un borde normal; 0 si el control no tiene borde.

COleControl::GetCapture

Determina si el objeto COleControl tiene la captura del mouse.

CWnd* GetCapture();

Valor devuelto

Si el control está activado y sin ventanas, devuelve this si el control actualmente tiene la captura del mouse (según lo determinado por el contenedor del control) o NULL si no tiene la captura.

De lo contrario, devuelve el objeto CWnd que tiene la captura del mouse (igual que CWnd::GetCapture).

Comentarios

Un control sin ventana activado recibe la captura del mouse cuando se llama a SetCapture.

COleControl::GetClassID

Lo llama el marco para recuperar el id. de clase OLE del control.

virtual HRESULT GetClassID(LPCLSID pclsid) = 0;

Parámetros

pclsid
Puntero a la ubicación del id. de clase.

Valor devuelto

Distinto de cero si la llamada no se realizó correctamente; de lo contrario es 0.

Comentarios

Normalmente se implementa mediante el IMPLEMENT_OLECREATE_EX.

COleControl::GetClientOffset

Recupera la diferencia entre la esquina superior izquierda del área rectangular del control y la esquina superior izquierda de su área de cliente.

virtual void GetClientOffset(long* pdxOffset, long* pdyOffset) const;

Parámetros

pdxOffset
Puntero al desplazamiento horizontal del área de cliente del control OLE.

pdyOffset
Puntero al desplazamiento vertical del área de cliente del control OLE.

Comentarios

El control OLE tiene un área rectangular dentro de su contenedor. El área cliente del control es el área de control que excluye los bordes y las barras de desplazamiento. El desplazamiento recuperado por GetClientOffset es la diferencia entre la esquina superior izquierda del área rectangular del control y la esquina superior izquierda de su área de cliente. Si su control tiene elementos que no son clientes, aparte de los bordes y las barras de desplazamiento estándar, invalide esta función miembro para especificar el desplazamiento.

COleControl::GetClientRect

Recupera el tamaño del área de cliente del control.

virtual void GetClientRect(LPRECT lpRect) const;

Parámetros

lpRect
Puntero a una estructura RECT que contiene las dimensiones del área cliente del control sin ventanas; es decir, el tamaño del control menos los bordes de ventana, los marcos, las barras de desplazamiento, etc. El parámetro lpRect indica el tamaño del rectángulo del cliente de control, no su posición.

COleControl::GetClientSite

Consulta a un objeto para el puntero a su sitio cliente actual dentro de su contenedor.

LPOLECLIENTSITE GetClientSite();

Valor devuelto

Puntero al sitio del cliente actual del control en su contenedor.

Comentarios

El puntero devuelto apunta a una instancia de IOleClientSite. La interfaz IOleClientSite, implementada por contenedores, es la vista del objeto de su contexto: donde está anclada en el documento, donde obtiene su almacenamiento, interfaz de usuario y otros recursos.

COleControl::GetControlFlags

Recupera la configuración de la marca de control.

virtual DWORD GetControlFlags();

Valor devuelto

Combinación de ORed de las marcas de la enumeración ControlFlags:

enum ControlFlags {
    fastBeginPaint = 0x0001,
    clipPaintDC = 0x0002,
    pointerInactive = 0x0004,
    noFlickerActivate = 0x0008,
    windowlessActivate = 0x0010,
    canOptimizeDraw = 0x0020,
    };

Comentarios

De forma predeterminada, GetControlFlags devuelve fastBeginPaint | clipPaintDC.

Nombre Descripción
fastBeginPaint Si se establece, usa una función begin-paint adaptada para controles OLE en lugar de la API BeginPaint (establecida de forma predeterminada).
clipPaintDC Si no se establece, deshabilita la llamada a IntersectClipRect realizada por COleControl y obtiene una pequeña ventaja de velocidad. Si usa la activación sin ventanas, la marca no tiene ningún efecto.
pointerInactive Si se establece, proporciona interacción del mouse mientras el control está inactivo habilitando la implementación de COleControl de la interfaz IPointerInactive, que está deshabilitada de forma predeterminada.
noFlickerActivate Si se establece, elimina las operaciones de dibujo adicionales y el parpadeo visual que las acompaña. Use cuando el control se dibuje de forma idéntica en los estados inactivos y activos. Si usa la activación sin ventanas, la marca no tiene ningún efecto.
windowlessActivate Si se establece, indica que el control usa la activación sin ventanas.
canOptimizeDraw Si se establece, indica que el control realizará un dibujo optimizado, si el contenedor lo admite.

Para obtener más información sobre GetControlFlags y otras optimizaciones de controles OLE, consulte Controles ActiveX: Optimización.

COleControl::GetControlSize

Recupera el tamaño de la ventana de control OLE.

void GetControlSize(
    int* pcx,
    int* pcy);

Parámetros

pcx
Especifica el ancho del control, en píxeles.

pcy
Especifica la altura del control, en píxeles.

Comentarios

Tenga en cuenta que todas las coordenadas de las ventanas de control son relativas a la esquina superior izquierda del control.

COleControl::GetDC

Permite que un objeto sin ventanas obtenga un contexto de dispositivo de pantalla (o compatible) de su contenedor.

CDC* GetDC(
    LPCRECT lprcRect = NULL,
    DWORD dwFlags = OLEDC_PAINTBKGND);

Parámetros

lprcRect
Puntero al rectángulo que el control sin ventana desea volver a dibujar, en coordenadas del cliente del control. NULL significa la extensión del objeto completo.

dwFlags
Atributos de dibujo del contexto del dispositivo. Las opciones son:

  • OLEDC_NODRAW indica que el objeto no usará el contexto del dispositivo para realizar ningún dibujo, sino simplemente para obtener información sobre el dispositivo de pantalla. El contenedor simplemente debe pasar el DC de la ventana sin más procesamiento.

  • OLEDC_PAINTBKGND solicita que el contenedor pinte el fondo antes de devolver el controlador de dominio. Un objeto debe usar esta marca si solicita un controlador de dominio para volver a dibujar un área con fondo transparente.

  • OLEDC_OFFSCREEN informa al contenedor de que el objeto desea representar en un mapa de bits fuera de pantalla que se debe copiar en la pantalla. Un objeto debe usar esta marca cuando la operación de dibujo que está a punto de realizar genera una gran cantidad de parpadeo. El contenedor es libre de respetar esta solicitud o no. Sin embargo, si no se establece esta marca, el contenedor debe devolver un DC en la pantalla. Esto permite a los objetos realizar operaciones de pantalla directas, como mostrar una selección (a través de una operación XOR).

Valor devuelto

Puntero al contexto del dispositivo de visualización para el área cliente del contenedor CWnd si se ejecuta correctamente; de lo contrario, el valor devuelto es NULL. El contexto del dispositivo de visualización se puede usar en funciones GDI posteriores para dibujar en el área cliente de la ventana del contenedor.

Comentarios

Se debe llamar a la función miembro ReleaseDC para liberar el contexto después de pintar. Al llamar a GetDC, los objetos pasan el rectángulo que desean dibujar en sus propias coordenadas de cliente. GetDC convierte estas en coordenadas del área cliente del contenedor. El objeto no debe solicitar un rectángulo de dibujo deseado mayor que su propio rectángulo de área de cliente, cuyo tamaño se puede recuperar con GetClientRect. Esto evita que los objetos se dibujen inadvertidamente donde no deben.

COleControl::GetEnabled

Implementa la función Get de la propiedad Enabled del stock de control.

BOOL GetEnabled();

Valor devuelto

Distinto de cero si el control está habilitado; de lo contrario es 0.

COleControl::GetExtendedControl

Obtiene un puntero a un objeto mantenido por el contenedor que representa el control con un conjunto extendido de propiedades.

LPDISPATCH GetExtendedControl();

Valor devuelto

Puntero al objeto de control extendido del contenedor. Si no hay ningún objeto disponible, el valor es NULL.

Este objeto se puede manipular a través de su interfaz IDispatch. También puede usar QueryInterface para obtener otras interfaces disponibles proporcionadas por el objeto. Sin embargo, el objeto no es necesario para admitir un conjunto específico de interfaces. Tenga en cuenta que depender de las características específicas del objeto de control extendido de un contenedor limita la portabilidad de su control a otros contenedores arbitrarios.

Comentarios

La función que llama a esta función es responsable de liberar el puntero cuando termine con el objeto. Tenga en cuenta que el contenedor no es necesario para admitir este objeto.

COleControl::GetFocus

Determina si el objeto COleControl tiene el foco.

CWnd* GetFocus();

Valor devuelto

Si el control está activado y sin ventanas, devuelve this si el control actualmente tiene el foco del teclado (según lo determinado por el contenedor del control) o NULL si no tiene el foco.

De lo contrario, devuelve el objeto CWnd que tiene el foco (igual que CWnd::GetFocus).

Comentarios

Un control sin ventana activado recibe el foco cuando se llama a SetFocus.

COleControl::GetFont

Implementa la función Get de la propiedad Font del stock.

LPFONTDISP GetFont();

Valor devuelto

Puntero a la interfaz de distribución de fuentes de la propiedad Font del stock de control.

Comentarios

Tenga en cuenta que el autor de la llamada debe liberar el objeto cuando termine. Dentro de la implementación del control, use InternalGetFont para acceder al objeto Font del stock de control. Para obtener más información sobre el uso de fuente de su control, consulte el artículo Controles ActiveX: Usar fuentes en un control ActiveX.

COleControl::GetFontTextMetrics

Mide las métricas de texto de cualquier objeto CFontHolder propiedad del control.

void GetFontTextMetrics(
    LPTEXTMETRIC lptm,
    CFontHolder& fontHolder);

Parámetros

lptm
Puntero a una estructura TEXTMETRIC.

fontHolder
Referencia a un objeto CFontHolder.

Comentarios

Esta fuente se puede seleccionar con la función COleControl::SelectFontObject. GetFontTextMetrics inicializará la estructura TEXTMETRIC a la que apunta lptm con información de métricas válida sobre la fuente de fontHolder si se ejecuta correctamente o rellenará la estructura con ceros si no se realiza correctamente. Debe usar esta función en lugar de GetTextMetrics al pintar el control porque los controles, como cualquier otro objeto OLE incrustado, pueden ser necesarios para representarse en un metarchivo.

La estructura TEXTMETRIC de la fuente predeterminada se actualiza cuando se llama a la función SelectFontObject. Solo se debe llamar a GetFontTextMetrics después de seleccionar la propiedad Font del stock para asegurarse de que la información que proporciona es válida.

COleControl::GetForeColor

Implementa la función Get de la propiedad ForeColor del stock.

OLE_COLOR GetForeColor();

Valor devuelto

El valor devuelto especifica el color de primer plano actual como un valor de OLE_COLOR, si se ejecuta correctamente. Este valor se puede trasladar a un valor COLORREF con una llamada a TranslateColor.

COleControl::GetHwnd

Implementa la función Get de la propiedad hWnd del stock.

OLE_HANDLE GetHwnd();

Valor devuelto

Manipulador de la ventana del control OLE, si existe; en caso contrario es NULL.

COleControl::GetMessageString

Llamado por el marco para obtener una cadena corta que describa el propósito del elemento del menú identificado por nID.

virtual void GetMessageString(
    UINT nID,
    CString& rMessage) const;

Parámetros

Nid
Id. de elemento de menú.

rMessage
Referencia a un objeto CString a través del cual se devolverá una cadena.

Comentarios

Se puede usar para obtener un mensaje para mostrarlo en una barra de estado mientras el elemento de menú está resaltado. La implementación predeterminada intenta cargar un recurso de cadena identificado por nID.

COleControl::GetNotSupported

Impide el acceso al valor de la propiedad de un control por parte del usuario.

void GetNotSupported();

Comentarios

Llame a esta función en lugar de la función Get de cualquier propiedad en la que no se admita la recuperación de la propiedad por parte del usuario del control. Un ejemplo sería una propiedad que es de solo escritura.

COleControl::GetReadyState

Devuelve el estado de preparación del control.

long GetReadyState();

Valor devuelto

El estado de preparación del control, uno de los siguientes valores:

Nombre Descripción
READYSTATE_UNINITIALIZED Estado de inicialización predeterminado
READYSTATE_LOADING El control está cargando actualmente sus propiedades
READYSTATE_LOADED Se ha inicializado el control
READYSTATE_INTERACTIVE El control tiene suficientes datos para ser interactivos, pero no todos los datos asincrónicos están todavía cargados
READYSTATE_COMPLETE El control tiene todos sus datos

Comentarios

La mayoría de los controles simples nunca necesitan diferenciar entre LOADED e INTERACTIVE. Sin embargo, es posible que los controles que admiten las propiedades de ruta de acceso de datos no estén listos para ser interactivos hasta que al menos algunos datos se reciban de forma asincrónica. Un control debe intentar volverse interactivo lo antes posible.

COleControl::GetRectInContainer

Obtiene las coordenadas del rectángulo del control en relación con el contenedor, expresado en unidades del dispositivo.

BOOL GetRectInContainer(LPRECT lpRect);

Parámetros

lpRect
Puntero a la estructura del rectángulo en la que se copiarán las coordenadas del control.

Valor devuelto

Distinto de cero si el elemento control está activo en el entorno local; de lo contrario es 0.

Comentarios

El rectángulo solo es válido si el control está activo en el lugar.

COleControl::GetStockTextMetrics

Mide las métricas de texto de la propiedad Font del stock de control, que se puede seleccionar con la función SelectStockFont.

void GetStockTextMetrics(LPTEXTMETRIC lptm);

Parámetros

lptm
Puntero a una estructura TEXTMETRIC.

Comentarios

La función GetStockTextMetrics inicializará la estructura TEXTMETRIC a la que apunta lptm con información de métricas válida si se ejecuta correctamente o rellenará la estructura con ceros si no se realiza correctamente. Use esta función en lugar de GetTextMetrics al pintar el control porque los controles, como cualquier otro objeto OLE incrustado, pueden ser necesarios para representarse en un metarchivo.

La estructura TEXTMETRIC de la fuente predeterminada se actualiza cuando se llama a la función SelectStockFont. Solo se debe llamar a esta función después de seleccionar la fuente del stock para asegurarse de que la información que proporciona es válida.

COleControl::GetText

Implementa la función Get de la propiedad Text o Caption del stock.

BSTR GetText();

Valor devuelto

Valor actual de la cadena de texto del control o una cadena de longitud cero si no hay ninguna cadena presente.

Nota:

Para obtener más información sobre el tipo de datos BSTR, consulte Tipos de datos en la sección Macros y Globales.

Comentarios

Tenga en cuenta que el autor de la llamada de esta función debe llamar a SysFreeString en la cadena devuelta para liberar el recurso. Dentro de la implementación del control, use InternalGetText para acceder a la propiedad Text o Caption del stock de control.

COleControl::GetWindowlessDropTarget

Invalide GetWindowlessDropTarget cuando desee que un control sin ventana sea el destino de una operación OLE de arrastrar y colocar.

virtual IDropTarget* GetWindowlessDropTarget();

Valor devuelto

Puntero a la interfaz del objeto IDropTarget. Debido a que no tiene una ventana, un objeto sin ventana no puede registrar una interfaz IDropTarget. Sin embargo, para participar en el arrastrar y colocar, un objeto sin ventana todavía puede implementar la interfaz y devolverla en GetWindowlessDropTarget.

Comentarios

Normalmente, esto requeriría que la ventana del control se registre como un destino de colocación. Pero dado que el control no tiene ninguna ventana propia, el contenedor usará su propia ventana como destino de colocación. El control simplemente debe proporcionar una implementación de la interfaz IDropTarget a la que el contenedor puede delegar llamadas en el momento adecuado. Por ejemplo:

IDropTarget *CMyAxCtrl::GetWindowlessDropTarget()
{
   m_xDropTarget.AddRef();
   return &m_xDropTarget;
}

COleControl::InitializeIIDs

Informa a la clase base de los IID que usará el control.

void InitializeIIDs(
    const IID* piidPrimary,
    const IID* piidEvents);

Parámetros

piidPrimary
Puntero al id. de interfaz de la interfaz de envío principal de control.

piidEvents
Puntero al id. de interfaz de la interfaz de eventos de control.

Comentarios

Llame a esta función en el constructor del control para informar a la clase base de los identificadores de interfaz que el control usará.

COleControl::InternalGetFont

Obtiene acceso a la propiedad Font del stock del control

CFontHolder& InternalGetFont();

Valor devuelto

Referencia a un objeto CFontHolder que contiene el objeto Font del stock.

COleControl::InternalGetText

Accede a la propiedad Text o Caption del stock del control.

const CString& InternalGetText();

Valor devuelto

Referencia a la cadena de texto de control.

COleControl::InternalSetReadyState

Establece el estado de preparación del control.

void InternalSetReadyState(long lNewReadyState);

Parámetros

lNewReadyState
El estado de preparación para establecer el control, uno de los siguientes valores:

Nombre Descripción
READYSTATE_UNINITIALIZED Estado de inicialización predeterminado
READYSTATE_LOADING El control está cargando actualmente sus propiedades
READYSTATE_LOADED Se ha inicializado el control
READYSTATE_INTERACTIVE El control tiene suficientes datos para ser interactivos, pero no todos los datos asincrónicos están todavía cargados
READYSTATE_COMPLETE El control tiene todos sus datos

Comentarios

La mayoría de los controles simples nunca necesitan diferenciar entre LOADED e INTERACTIVE. Sin embargo, es posible que los controles que admiten las propiedades de ruta de acceso de datos no estén listos para ser interactivos hasta que al menos algunos datos se reciban de forma asincrónica. Un control debe intentar volverse interactivo lo antes posible.

COleControl::InvalidateControl

Obliga al control a dibujarse nuevamente.

void InvalidateControl(
    LPCRECT lpRect = NULL,
    BOOL bErase = TRUE);

Parámetros

lpRect
Puntero a la región del control que se va a invalidar.

bErase
Especifica si el fondo dentro de la región de actualización debe borrarse cuando se procesa la actualización de la región.

Comentarios

Si lpRect tiene un valor NULL, se volverá a dibujar todo el control. Si lpRect no es NULL, se indica la parte del rectángulo del control que se va a invalidar. En los casos en donde el control no tiene ninguna ventana o actualmente no está activo, se omite el rectángulo y se realiza una llamada a la función miembro IAdviseSink::OnViewChange del sitio cliente. Use esta función en lugar de CWnd::InvalidateRect o InvalidateRect.

COleControl::InvalidateRgn

Invalida el área de cliente de la ventana del contenedor dentro de la región especificada.

void InvalidateRgn(CRgn* pRgn, BOOL bErase = TRUE);

Parámetros

pRgn
Puntero a un objeto CRgn que identifica la región de presentación del objeto OLE que se va a invalidar, en coordenadas cliente de la ventana contenedora. Si este parámetro es NULL, la extensión es todo el objeto.

bErase
Especifica si el fondo de la región de actualización debe borrarse. Si es TRUE, se borra el fondo. Si es FALSE, el fondo permanece sin cambios.

Comentarios

Se puede usar para volver a dibujar controles sin ventanas dentro del contenedor. La región invalidada, junto con todas las demás áreas de la región de actualización, se marca para pintar cuando se envía el mensaje WM_PAINT.

Si bErase es TRUE para cualquier parte de la región de actualización, se borra el fondo de toda la región, no solo en la parte especificada.

COleControl::IsConvertingVBX

Permite la carga especializada de un control OLE.

BOOL IsConvertingVBX();

Valor devuelto

Distinto de cero si el control se está convirtiendo; de lo contrario es 0.

Comentarios

Al convertir un formulario que usa controles VBX en uno que use controles OLE, es posible que se requiera código de carga especial para los controles OLE. Por ejemplo, si va a cargar una instancia del control OLE, es posible que tenga que llamar a PX_Font en su DoPropExchange:

PX_Font(pPX, _T("Font"), *m_pMyFont, &DefaultFont);

Sin embargo, los controles VBX no tenían un objeto Font; cada propiedad de fuente se guardó individualmente. En este caso, usaría IsConvertingVBX para distinguir entre estos dos casos:

if (!IsConvertingVBX())
{
   PX_Font(pPX, _T("Font"), *m_pMyFont, &DefaultFont);
}
else
{
   PX_String(pPX, _T("FontName"), tempString, DefaultName);
   m_pMyFont->m_pFont->put_Name(tempString.AllocSysString());
   PX_Bool(pPX, _T("FontUnderline"), tempBool, DefaultValue);
   m_pMyFont->m_pFont->put_Underline(tempBool);
}

Otro caso sería si el control VBX guardó datos binarios propietarios (en su controlador de mensajes VBM_SAVEPROPERTY) y el control OLE guarda sus datos binarios en un formato diferente. Si quiere que el control OLE sea compatible con versiones anteriores con el control VBX, podría leer tanto los formatos antiguos como los nuevos mediante la función IsConvertingVBX, para distinguir si se carga el control VBX o el control OLE.

En la función del control DoPropExchange, puede comprobar esta condición y, si es true, ejecute el código de carga específico para esta conversión (como los ejemplos anteriores). Si el control no se está convirtiendo, puede ejecutar el código de carga normal. Esta capacidad solo es aplicable a los controles que se convierten desde los homólogos de VBX.

COleControl::IsInvokeAllowed

Habilita la invocación de métodos de automatización.

BOOL IsInvokeAllowed(DISPID dispid);

Valor devuelto

Es distinto de cero si se ha inicializado el control; en caso contrario es 0.

Comentarios

La implementación del marco de IDispatch::Invoke llama a IsInvokeAllowed para determinar si se puede invocar una función determinada (identificada por dispid). El comportamiento predeterminado de un control OLE es permitir que los métodos de automatización se invoquen solo si se ha inicializado el control; sin embargo, IsInvokeAllowed es una función virtual y se puede invalidar si es necesario (por ejemplo, cuando el control se usa como servidor de automatización).

COleControl::IsModified

Determina si se ha modificado el estado del control.

BOOL IsModified();

Valor devuelto

Distinto de cero si el estado del control se ha modificado desde que se guardó por última vez; de lo contrario es 0.

Comentarios

El estado de un control se modifica cuando cambia el valor de una propiedad.

COleControl::IsOptimizedDraw

Determina si el contenedor admite el dibujo optimizado para la operación de dibujo actual.

BOOL IsOptimizedDraw();

Valor devuelto

TRUE si el contenedor admite el dibujo optimizado para la operación de dibujo actual, de lo contrario es FALSE.

Comentarios

Si se admite el dibujo optimizado, el control no necesita seleccionar objetos antiguos (lápices, pinceles, fuentes, etc.) en el contexto del dispositivo cuando finalice el dibujo.

COleControl::IsSubclassedControl

Lo llama el marco para determinar si el control establece subclases en un control de Windows.

virtual BOOL IsSubclassedControl();

Valor devuelto

Distinto de cero si el control está hecho una subclase; de lo contrario es 0.

Comentarios

Debe invalidar esta función y devolver TRUE si el control OLE hace de un control de Windows una subclase.

COleControl::Load

Restablece cualquier dato anterior cargado de forma asíncrona e inicia una nueva carga de la propiedad asíncrona del control.

void Load(LPCTSTR strNewPath, CDataPathProperty& prop);

Parámetros

strNewPath
Puntero a una cadena que contiene la ruta de acceso que hace referencia a la ubicación absoluta de la propiedad de control asincrónica.

prop
Objeto CDataPathProperty que implementa una propiedad de control asincrónica.

COleControl::LockInPlaceActive

Impide que el contenedor desactive el control.

BOOL LockInPlaceActive(BOOL bLock);

Parámetros

bLock
TRUE si el estado activo en el lugar del control debe ser bloqueado; FALSE si debe ser desbloqueado.

Valor devuelto

Distinto de cero si el bloqueo se ha realizado correctamente; de lo contrario es 0.

Comentarios

Tenga en cuenta que cada bloqueo del control debe emparejarse con un desbloqueo del control cuando termine. Solo debe bloquear el control durante períodos cortos, como cuando se activa un evento.

COleControl::OnAmbientPropertyChange

Lo llama el marco cuando una propiedad de ambiente del contenedor ha cambiado de valor.

virtual void OnAmbientPropertyChange(DISPID dispid);

Parámetros

dispID
Identificador de distribución de la propiedad ambiente que cambió o DISPID_UNKNOWN si han cambiado varias propiedades.

COleControl::OnAppearanceChanged

Lo llama el marco cuando el valor de la propiedad Appearance del stock ha cambiado.

virtual void OnAppearanceChanged ();

Comentarios

Invalide esta función si se desea una notificación después de que cambie esta propiedad. La implementación predeterminada llama a InvalidateControl.

COleControl::OnBackColorChanged

Lo llama el marco cuando el valor de la propiedad BackColor del stock ha cambiado.

virtual void OnBackColorChanged();

Comentarios

Invalide esta función si se desea una notificación después de que cambie esta propiedad. La implementación predeterminada llama a InvalidateControl.

COleControl::OnBorderStyleChanged

Lo llama el marco cuando el valor de la propiedad BorderStyle del stock ha cambiado.

virtual void OnBorderStyleChanged();

Comentarios

La implementación predeterminada llama a InvalidateControl.

Invalide esta función si se desea una notificación después de que cambie esta propiedad.

COleControl::OnClick

Lo llama el marco cuando se ha hecho clic en un botón del mouse o se ha invocado el método del stock DoClick.

virtual void OnClick(USHORT iButton);

Parámetros

iButton
Índice de un botón del mouse. Puede tener uno de los siguientes valores:

  • LEFT_BUTTON se hizo clic en el botón izquierdo del mouse.

  • MIDDLE_BUTTON, se hizo clic en el botón central del mouse.

  • RIGHT_BUTTON, se hizo clic en el botón derecho del mouse.

Comentarios

La implementación predeterminada llama a COleControl::FireClick.

Invalide esta función miembro para modificar o ampliar el control predeterminado.

COleControl::OnClose

Lo llama el marco cuando el contenedor ha llamado a la función IOleControl::Close del control.

virtual void OnClose(DWORD dwSaveOption);

Parámetros

dwSaveOption
Marca que indica si el objeto se debe guardar antes de cargarlo. Los valores válidos son:

  • OLECLOSE_SAVEIFDIRTY

  • OLECLOSE_NOSAVE

  • OLECLOSE_PROMPTSAVE

Comentarios

De forma predeterminada, OnClose guarda el objeto de control si se ha modificado y dwSaveOption es OLECLOSE_SAVEIFDIRTY o OLECLOSE_PROMPTSAVE.

COleControl::OnDoVerb

Lo llama el marco cuando el contenedor llama a la función miembro IOleObject::DoVerb.

virtual BOOL OnDoVerb(
    LONG iVerb,
    LPMSG lpMsg,
    HWND hWndParent,
    LPCRECT lpRect);

Parámetros

iVerb
Índice del verbo de control que se va a invocar.

lpMsg
Puntero al mensaje de Windows que provocó la invocación del verbo.

hWndParent
Manipulador de la ventana primaria del control. Si la ejecución del verbo crea una ventana (o ventanas), hWndParent debe usarse como elemento primario.

lpRect
Puntero a una estructura RECT en la que se copiarán las coordenadas del control, relativas al contenedor.

Valor devuelto

Distinto de cero si la llamada se ha realizado correctamente; de lo contrario es 0.

Comentarios

La implementación predeterminada usa las entradas de asignación de mensajes ON_OLEVERB y ON_STDOLEVERB para determinar la función adecuada que se va a invocar.

Invalide esta función para cambiar el control predeterminado del verbo.

COleControl::OnDraw

Llamado por el marco para dibujar el control OLE en el rectángulo delimitador especificado por el contexto de dispositivo especificado.

virtual void OnDraw(
    CDC* pDC,
    const CRect& rcBounds,
    const CRect& rcInvalid);

Parámetros

pDC
Contexto del dispositivo en el que se produce el dibujo.

rcBounds
Área rectangular del control, incluido el borde.

rcInvalid
Área rectangular del control que no es válida.

Comentarios

OnDraw se llama normalmente para la visualización de la pantalla, pasando un contexto del dispositivo de pantalla como pDC. El parámetro rcBounds identifica el rectángulo en el contexto del dispositivo de destino (en relación con su modo de asignación actual). El parámetro rcInvalid es el rectángulo real que no es válido. En algunos casos, será un área más pequeña que rcBounds.

COleControl::OnDrawMetafile

Llamado por el marco para dibujar el control OLE en el rectángulo delimitador especificado por el contexto de dispositivo del metarchivo especificado.

virtual void OnDrawMetafile(
    CDC* pDC,
    const CRect& rcBounds);

Parámetros

pDC
Contexto del dispositivo en el que se produce el dibujo.

rcBounds
Área rectangular del control, incluido el borde.

Comentarios

La implementación predeterminada llama a la función OnDraw.

COleControl::OnEdit

Hace que el control active la interfaz de usuario.

virtual BOOL OnEdit(
    LPMSG lpMsg,
    HWND hWndParent,
    LPCRECT lpRect);

Parámetros

lpMsg
Puntero al mensaje de Windows que invocó el verbo.

hWndParent
Identificador de la ventana primaria del control.

lpRect
Puntero al rectángulo utilizado por el control del contenedor.

Valor devuelto

Distinto de cero si el método es correcto; en caso contrario es 0.

Comentarios

Esto tiene el mismo efecto que invocar el verbo OLEIVERB_UIACTIVATE del control.

Esta función se usa normalmente como función del controlador para una entrada de asignación de mensajes de ON_OLEVERB. Esto hace que un verbo "Editar" esté disponible en el menú "Objeto" del control. Por ejemplo:

ON_OLEVERB(AFX_IDS_VERB_EDIT, OnEdit)

COleControl::OnEnabledChanged

Lo llama el marco cuando el valor de la propiedad Enabled del stock ha cambiado.

virtual void OnEnabledChanged();

Comentarios

Invalide esta función si se desea una notificación después de que cambie esta propiedad. La implementación predeterminada llama a InvalidateControl.

COleControl::OnEnumVerbs

Lo llama el marco cuando el contenedor llama a la función miembro IOleObject::EnumVerbs.

virtual BOOL OnEnumVerbs(LPENUMOLEVERB* ppenumOleVerb);

Parámetros

ppenumOleVerb
Puntero al objeto IEnumOLEVERB que enumera los verbos del control.

Valor devuelto

Distinto de cero si los verbos están disponibles; de lo contrario es 0.

Comentarios

La implementación predeterminada enumera las entradas de ON_OLEVERB en la asignación de mensajes.

Invalide esta función para cambiar la forma predeterminada de enumerar los verbos.

COleControl::OnEventAdvise

Lo llama el marco cuando un controlador de eventos está conectado o desconectado de un control OLE.

virtual void OnEventAdvise(BOOL bAdvise);

Parámetros

bAdvise
TRUE indica que un controlador de eventos se ha conectado al control. FALSE indica que un controlador de eventos se ha desconectado del control.

COleControl::OnFontChanged

Lo llama el marco cuando el valor de la propiedad Font del stock ha cambiado.

virtual void OnFontChanged();

Comentarios

La implementación predeterminada llama a COleControl::InvalidateControl. Si el control está haciendo de un control de Windows una subclase, la implementación predeterminada también envía un mensaje de WM_SETFONT a la ventana del control.

Invalide esta función si se desea una notificación después de que cambie esta propiedad.

Ejemplo

void CMyAxCtrl::OnFontChanged()
{
   // Always set it to the container's font
   if (m_MyEdit.m_hWnd != NULL)
   {
      IFontDisp *pFontDisp = NULL;
      IFont *pFont = NULL;
      HRESULT hr;

      // Get the container's FontDisp interface
      pFontDisp = AmbientFont();
      if (pFontDisp)
      {
         hr = pFontDisp->QueryInterface(IID_IFont, (LPVOID*)&pFont);
         if (FAILED(hr))
         {
            pFontDisp->Release();
            return;
         }
      }

      HFONT hFont = NULL;
      if (pFont)
      {
         pFont->get_hFont(&hFont);
         m_MyEdit.SendMessage(WM_SETFONT, (WPARAM)hFont, 0L);
      }

      pFontDisp->Release();
   }

   // Invalidate the control
   m_MyEdit.Invalidate();
   m_MyEdit.UpdateWindow();

   COleControl::OnFontChanged();
}

COleControl::OnForeColorChanged

Lo llama el marco cuando el valor de la propiedad ForeColor del stock ha cambiado.

virtual void OnForeColorChanged();

Comentarios

La implementación predeterminada llama a InvalidateControl.

Invalide esta función si se desea una notificación después de que cambie esta propiedad.

COleControl::OnFreezeEvents

Lo llama el marco después de que el contenedor llame a IOleControl::FreezeEvents.

virtual void OnFreezeEvents(BOOL bFreeze);

Parámetros

bFreeze
TRUE si el manejo de eventos del control está inmovilizado; en caso contrario, FALSE.

Comentarios

La implementación predeterminada no hace nada.

Invalide esta función si desea un comportamiento adicional cuando el control de eventos esté inmovilizado o sea movible.

COleControl::OnGetColorSet

Lo llama el marco cuando el contenedor llama a la función miembro IViewObject::GetColorSet.

virtual BOOL OnGetColorSet(
    DVTARGETDEVICE* ptd,
    HDC hicTargetDev,
    LPLOGPALETTE* ppColorSet);

Parámetros

ptd
Apunta al dispositivo de destino para el que se debe representar la imagen. Si este valor es NULL, la imagen debe representarse para un dispositivo de destino predeterminado, normalmente un dispositivo de visualización.

hicTargetDev
Especifica el contexto de información en el dispositivo de destino indicado por ptd. Este parámetro puede ser un contexto de dispositivo, pero no necesariamente. Si ptd es NULL, hicTargetDev también debe ser NULL.

ppColorSet
Puntero a la ubicación en la que se debe copiar el conjunto de colores que se usaría. Si la función no devuelve el conjunto de colores, se devuelve NULL.

Valor devuelto

Distinto de cero si se devuelve un conjunto de colores válido; de lo contrario es 0.

Comentarios

El contenedor llama a esta función para obtener todos los colores necesarios para dibujar el control OLE. El contenedor puede usar los conjuntos de colores obtenidos junto con los colores que necesita para establecer la paleta de colores general. La implementación predeterminada devuelve FALSE.

Invalide esta función para realizar cualquier procesamiento especial de esta solicitud.

COleControl::OnGetControlInfo

Lo llama el marco cuando el contenedor del control ha solicitado información sobre el control.

virtual void OnGetControlInfo(LPCONTROLINFO pControlInfo);

Parámetros

pControlInfo
Puntero a una estructura CONTROLINFO que debe rellenarse.

Comentarios

Esta información consta principalmente de una descripción de las claves mnemotécnicas del control. La implementación predeterminada rellena pControlInfo con información predeterminada.

Invalide esta función si el control necesita procesar claves mnemotécnicas.

COleControl::OnGetDisplayString

Llamado por el marco para obtener una cadena que representa el valor actual de la propiedad identificada por dispid.

virtual BOOL OnGetDisplayString(
    DISPID dispid,
    CString& strValue);

Parámetros

dispid
Identificador de envío de una propiedad del control.

strValue
Referencia a un objeto CString a través del cual se devolverá una cadena.

Valor devuelto

Distinto de cero si se ha devuelto una cadena en strValue; en caso contrario es 0.

Comentarios

Invalide esta función si el control tiene una propiedad cuyo valor no se puede convertir directamente en una cadena y desea que el valor de la propiedad se muestre en un explorador de propiedades proporcionado por el contenedor.

COleControl::OnGetInPlaceMenu

Lo llama el marco cuando se activa la interfaz de usuario del control para obtener el menú que se va a combinar en el menú existente del contenedor.

virtual HMENU OnGetInPlaceMenu();

Valor devuelto

Identificador del menú del control o NULL si el control no tiene ninguno. La implementación predeterminada devuelve NULL.

Comentarios

Para obtener más información sobre cómo combinar recursos OLE, consulte el artículo Menús y recursos (OLE).

COleControl::OnGetNaturalExtent

Lo llama el marco en respuesta a la solicitud de un contenedor IViewObjectEx::GetNaturalExtent.

virtual BOOL OnGetNaturalExtent(
    DWORD dwAspect,
    LONG lindex,
    DVTARGETDEVICE* ptd,
    HDC hicTargetDev,
    DVEXTENTINFO* pExtentInfo,
    LPSIZEL psizel);

Parámetros

dwAspect
Especifica cómo se va a representar el objeto. Las representaciones incluyen contenido, un icono, una miniatura o un documento impreso. Los valores válidos se toman de la enumeración DVASPECT o DVASPECT2.

lindex
Parte del objeto que es de interés. Actualmente, solo -1 es válido.

ptd
Apunta a la estructura DVTARGETDEVICE que define el dispositivo de destino para el que se debe devolver el tamaño del objeto.

hicTargetDev
Especifica el contexto de información para el dispositivo de destino indicado por el parámetro ptd del que el objeto puede extraer las métricas del dispositivo y probar las funciones del dispositivo. Si ptd es NULL, el objeto debe omitir el valor en el parámetro hicTargetDev.

pExtentInfo
Apunta a la estructura DVEXTENTINFO que especifica los datos de tamaño. La estructura DVEXTENTINFO es:

typedef struct tagExtentInfo
{
    UINT cb;
    DWORD dwExtentMode;
    SIZEL sizelProposed;
}   DVEXTENTINFO;

El miembro de estructura dwExtentMode puede tomar uno de los dos valores:

  • DVEXTENT_CONTENT indica el tamaño que debe tener el control para ajustarse exactamente al contenido (ajustar al tamaño)

  • DVEXTENT_INTEGRAL cuando al cambia el tamaño, pase el tamaño propuesto al control

psizel
Apunta a los datos de tamaño devueltos por el control. Los datos de dimensionamiento de tamaño devueltos se establecen en -1 para cualquier dimensión que no se haya ajustado.

Valor devuelto

Distinto de cero si devuelve o ajusta correctamente el tamaño; de lo contrario es 0.

Comentarios

Invalide esta función para devolver el tamaño de presentación del objeto más cercano al modo de tamaño y extensión propuestos en la estructura DVEXTENTINFO. La implementación predeterminada devuelve FALSE y no realiza ningún ajuste en el tamaño.

COleControl::OnGetPredefinedStrings

Lo llama el marco para obtener un conjunto de cadenas predefinidas que representan los valores posibles para una propiedad.

virtual BOOL OnGetPredefinedStrings(
    DISPID dispid,
    CStringArray* pStringArray,
    CDWordArray* pCookieArray);

Parámetros

dispid
Identificador de envío de una propiedad del control.

pStringArray
Matriz de cadenas que se va a rellenar con los valores devueltos.

pCookieArray
Matriz DWORD que se va a rellenar con los valores devueltos.

Valor devuelto

Distinto de cero si se han agregado elementos a pStringArray y pCookieArray.

Comentarios

Invalide esta función si el control tiene una propiedad con un conjunto de valores posibles que pueden representarse mediante cadenas. Para cada elemento agregado a pStringArray, se debe agregar un elemento "cookie" correspondiente a pCookieArray. Estos valores "cookie" pueden ser pasados posteriormente por el marco a la función COleControl::OnGetPredefinedValue.

COleControl::OnGetPredefinedValue

Llamado por el marco para obtener el valor correspondiente a una de las cadenas predefinidas devueltas previamente por una invalidación de COleControl::OnGetPredefinedStrings.

virtual BOOL OnGetPredefinedValue(
    DISPID dispid,
    DWORD dwCookie,
    VARIANT* lpvarOut);

Parámetros

dispid
Identificador de envío de una propiedad del control.

dwCookie
Valor de cookie devuelto previamente por una invalidación de COleControl::OnGetPredefinedStrings.

lpvarOut
Puntero a una estructura VARIANT a través de la cual se devolverá un valor de propiedad.

Valor devuelto

Distinto de cero si se ha devuelto un valor en lpvarOut; de lo contrario es 0.

COleControl::OnGetViewExtent

Lo llama el marco en respuesta a la solicitud IViewObject2::GetExtent de un contenedor.

virtual BOOL OnGetViewExtent(
    DWORD dwDrawAspect,
    LONG lindex,
    DVTARGETDEVICE* ptd,
    LPSIZEL lpsizel);

Parámetros

dwDrawAspect
DWORD que describe qué formulario o aspecto de un objeto se va a mostrar. Los valores válidos se toman de la enumeración DVASPECT o DVASPECT2.

lindex
Parte del objeto que es de interés. Actualmente, solo -1 es válido.

ptd
Apunta a la estructura DVTARGETDEVICE que define el dispositivo de destino para el que se debe devolver el tamaño del objeto.

lpsizel
Apunta a la ubicación donde se devuelve el tamaño del objeto.

Valor devuelto

Distinto de cero si la información de extensión se devuelve correctamente; de lo contrario es 0.

Comentarios

Invalide esta función si el control usa un dibujo de dos pasos y sus partes opacas, y transparentes tienen dimensiones diferentes.

COleControl::OnGetViewRect

Lo llama el marco en respuesta a la solicitud de un contenedor IViewObjectEx::GetRect.

virtual BOOL OnGetViewRect(DWORD dwAspect, LPRECTL pRect);

Parámetros

dwAspect
DWORD que describe qué formulario o aspecto de un objeto se va a mostrar. Los valores válidos se toman de la enumeración DVASPECT o DVASPECT2:

  • DVASPECT_CONTENT, rectángulo delimitador del objeto completo. Esquina superior izquierda en el origen y tamaño del objeto igual a la extensión devuelta por GetViewExtent.

  • DVASPECT_OPAQUE, objetos con una región opaca rectangular devuelve ese rectángulo. Otros fallan.

  • DVASPECT_TRANSPARENT, rectángulo que cubre todas las partes transparentes o irregulares.

pRect
Apunta a la estructura RECTL que especifica el rectángulo en el que se debe dibujar el objeto. Este parámetro controla el posicionamiento y la extensión del objeto.

Valor devuelto

Distinto de cero si el rectángulo de tamaño para el objeto se devuelve correctamente; de lo contrario es 0.

Comentarios

El tamaño del objeto se convierte mediante OnGetViewRect en un rectángulo que comienza en una posición específica (el valor predeterminado es la esquina superior izquierda de la pantalla). Invalide esta función si el control usa un dibujo de dos pasos y sus partes opacas, y transparentes tienen dimensiones diferentes.

COleControl::OnGetViewStatus

Lo llama el marco en respuesta a la solicitud de un contenedor IViewObjectEx::GetViewStatus.

virtual DWORD OnGetViewStatus();

Valor devuelto

Uno de los valores de la enumeración VIEWSTATUS si se ejecuta correctamente; de lo contrario es 0. Los valores posibles son cualquier combinación de los siguientes:

Nombre Descripción
VIEWSTATUS_OPAQUE El objeto es completamente opaco. Si no se establece este bit, el objeto contiene partes transparentes. Este bit solo se aplica a aspectos relacionados con el contenido y no a DVASPECT_ICON o DVASPECT_DOCPRINT.
VIEWSTATUS_SOLIDBKGND El objeto tiene un fondo sólido (que consta de un color sólido, no un patrón de pincel). Este bit solo es significativo si se establece VIEWSTATUS_OPAQUE y solo se aplica a aspectos relacionados con el contenido y no a DVASPECT_ICON o DVASPECT_DOCPRINT.
VIEWSTATUS_DVASPECTOPAQUE El objeto admite DVASPECT_OPAQUE. Todos los métodos IViewObjectEx que toman un aspecto de dibujo como parámetro se pueden llamar con este aspecto.
VIEWSTATUS_DVASPECTTRANSPARENT El objeto admite DVASPECT_TRANSPARENT. Todos los métodos IViewObjectEx que toman un aspecto de dibujo como parámetro se pueden llamar con este aspecto.

Comentarios

Invalide esta función si el control usa un dibujo de dos pasos. La implementación predeterminada devuelve VIEWSTATUS_OPAQUE.

COleControl::OnHideToolBars

Lo llama el marco cuando se desactiva la interfaz de usuario del control.

virtual void OnHideToolBars();

Comentarios

La implementación debe ocultar todas las barras de herramientas mostradas por OnShowToolbars.

COleControl::OnInactiveMouseMove

Lo llama el contenedor del objeto inactivo bajo el puntero del mouse al recibir un mensaje de WM_MOUSEMOVE.

virtual void OnInactiveMouseMove(
    LPCRECT lprcBounds,
    long x,
    long y,
    DWORD dwKeyState);

Parámetros

lprcBounds
Rectángulo delimitador de objetos, en coordenadas de cliente de la ventana contenedora. Indica al objeto su posición y tamaño exactos en la pantalla cuando se recibió el mensaje WM_MOUSEMOVE.

x
Coordenada x de la ubicación del mouse en coordenadas de cliente de la ventana contenedora.

y
Coordenada y de la ubicación del mouse en coordenadas de cliente de la ventana contenedora.

dwKeyState
Identifica el estado actual de las teclas modificadoras del teclado. Los valores válidos pueden ser una combinación de cualquiera de las marcas MK_CONTROL, MK_SHIFT, MK_ALT, MK_BUTTON, MK_LBUTTON, MK_MBUTTON y MK_RBUTTON.

Comentarios

Tenga en cuenta que las coordenadas cliente de la ventana (píxeles) se usan para pasar la posición del cursor del mouse. Esto se hace posible pasando también el rectángulo delimitador del objeto en el mismo sistema de coordenadas.

COleControl::OnInactiveSetCursor

Lo llama el contenedor del objeto inactivo bajo el puntero del mouse al recibir un mensaje de WM_SETCURSOR.

virtual BOOL OnInactiveSetCursor(
    LPCRECT lprcBounds,
    long x,
    long y,
    DWORD dwMouseMsg,
    BOOL bSetAlways);

Parámetros

lprcBounds
Rectángulo delimitador de objetos, en coordenadas de cliente de la ventana contenedora. Indica al objeto su posición y tamaño exactos en la pantalla cuando se recibió el mensaje WM_SETCURSOR.

x
Coordenada x de la ubicación del mouse en coordenadas de cliente de la ventana contenedora.

y
Coordenada y de la ubicación del mouse en coordenadas de cliente de la ventana contenedora.

dwMouseMsg
Identificador del mensaje del mouse para el que se produjo un WM_SETCURSOR.

bSetAlways
Especifica si el objeto debe establecer el cursor o no. Si es TRUE, el objeto debe establecer el cursor; si es FALSE, el cursor no está obligado a establecer el cursor y debe devolver S_FALSE en ese caso.

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

Tenga en cuenta que las coordenadas cliente de la ventana (píxeles) se usan para pasar la posición del cursor del mouse. Esto se hace posible pasando también el rectángulo delimitador del objeto en el mismo sistema de coordenadas.

COleControl::OnKeyDownEvent

Lo llama el marco después de procesar un evento KeyDown del stock.

virtual void OnKeyDownEvent(
    USHORT nChar,
    USHORT nShiftState);

Parámetros

nChar
Valor de código de la clave virtual de la tecla presionada. Para obtener una lista de códigos de tecla virtual estándar, consulte Winuser.h.

nShiftState
Contiene una combinación de las marcas de los menú siguientes:

  • SHIFT_MASK se presionó la tecla MAYÚS durante la acción.

  • CTRL_MASK se presionó la tecla CONTROL durante la acción.

  • ALT_MASK se presionó la tecla ALT durante la acción.

Comentarios

Invalide esta función si el control necesita acceso a la información de la clave después de que se haya desencadenado el evento.

COleControl::OnKeyPressEvent

Lo llama el marco después de que se haya desencadenado el evento KeyPress del stock.

virtual void OnKeyPressEvent(USHORT nChar);

Parámetros

nChar
Contiene el valor del código de la clave virtual de la tecla presionada. Para obtener una lista de códigos de tecla virtual estándar, consulte Winuser.h.

Comentarios

Tenga en cuenta que el contenedor puede haber modificado el valor nChar.

Invalide esta función si se desea una notificación después de que ocurra el evento.

COleControl::OnKeyUpEvent

Lo llama el marco después de procesar un evento KeyDown del stock.

virtual void OnKeyUpEvent(
    USHORT nChar,
    USHORT nShiftState);

Parámetros

nChar
Valor de código de la clave virtual de la tecla presionada. Para obtener una lista de códigos de tecla virtual estándar, consulte Winuser.h.

nShiftState
Contiene una combinación de las marcas de los menú siguientes:

  • SHIFT_MASK se presionó la tecla MAYÚS durante la acción.

  • CTRL_MASK se presionó la tecla CONTROL durante la acción.

  • ALT_MASK se presionó la tecla ALT durante la acción.

Comentarios

Invalide esta función si el control necesita acceso a la información de la clave después de que se haya desencadenado el evento.

COleControl::OnMapPropertyToPage

Lo llama el marco para obtener el id. de clase de una página de propiedades que implementa la edición de la propiedad especificada.

virtual BOOL OnMapPropertyToPage(
    DISPID dispid,
    LPCLSID lpclsid,
    BOOL* pbPageOptional);

Parámetros

dispid
Identificador de envío de una propiedad del control.

lpclsid
Puntero a una estructura CLSID a través de la cual se devolverá un id. de clase.

pbPageOptional
Devuelve un indicador de si el uso de la página de propiedades especificada es opcional.

Valor devuelto

Distinto de cero si se ha devuelto un identificador de clase en lpclsid; de lo contrario es 0.

Comentarios

Invalide esta función para proporcionar una forma de invocar las páginas de propiedades del control desde el explorador de propiedades del contenedor.

COleControl::OnMnemonic

Lo llama el marco cuando el contenedor ha detectado que se ha presionado una tecla mnemotécnica del control OLE.

virtual void OnMnemonic(LPMSG pMsg);

Parámetros

Pmsg
Puntero al mensaje de Windows generado por la presión de una tecla mnemónica.

COleControl::OnProperties

Lo llama el marco cuando el contenedor invoca el verbo de propiedades del control.

virtual BOOL OnProperties(
    LPMSG lpMsg,
    HWND hWndParent,
    LPCRECT lpRect);

Parámetros

lpMsg
Puntero al mensaje de Windows que invocó el verbo.

hWndParent
Identificador de la ventana primaria del control.

lpRect
Puntero al rectángulo utilizado por el control del contenedor.

Valor devuelto

Distinto de cero si el método es correcto; en caso contrario es 0.

Comentarios

La implementación predeterminada muestra un cuadro de diálogo de propiedad modal.

También puede usar esta función para provocar la visualización de las páginas de propiedades del control. Realice una llamada a la función OnProperties y pase el identificador del elemento primario del control en el parámetro hWndParent. En este caso, se ignoran los valores de los parámetros lpMsg y lpRect.

COleControl::OnQueryHitPoint

Lo llama el marco en respuesta a la solicitud de un contenedor IViewObjectEx::QueryHitPoint.

virtual BOOL OnQueryHitPoint(
    DWORD dwAspect,
    LPCRECT pRectBounds,
    POINT ptlLoc,
    LONG lCloseHint,
    DWORD* pHitResult);

Parámetros

dwAspect
Especifica cómo se representa el objeto. Los valores válidos se toman de la enumeración DVASPECT o DVASPECT2.

pRectBounds
Puntero a una estructura RECT que especifica el rectángulo delimitador del área cliente de control OLE.

ptlLoc
Puntero a la estructura POINT que especifica el punto que se va a comprobar para obtener una visita. El punto se especifica en las coordenadas del área de cliente OLE.

lCloseHint
Distancia que define "cerrar" al punto comprobado para una visita.

pHitResult
Puntero al resultado de la consulta de la visita. Uno de los valores siguientes:

  • HITRESULT_OUTSIDE ptlLoc está fuera del objeto OLE y no se cierra.

  • HITRESULT_TRANSPARENT ptlLoc está dentro de los límites del objeto OLE, pero no cerca de la imagen. Por ejemplo, un punto en medio de un círculo transparente podría ser HITRESULT_TRANSPARENT.

  • HITRESULT_CLOSE ptlLoc está dentro o fuera del objeto OLE, pero lo suficientemente cerca del objeto que se debe considerar adentro. Los objetos pequeños, finos o detallados pueden usar este valor. Incluso si un punto está afuera del rectángulo delimitador de un objeto, puede que siga estando cerca (esto es necesario para alcanzar objetos pequeños).

  • HITRESULT_HIT ptlLoc está dentro de la imagen del objeto.

Valor devuelto

Distinto de cero si se devuelve correctamente una línea ejecutada de aciertos; de lo contrario es 0. Un visita es una superposición con el área de presentación del control OLE.

Comentarios

Consulta si el rectángulo de presentación de un objeto se superpone al punto especificado (alcanza el punto). QueryHitPoint se puede invalidar para probar las visitas de los objetos no rectangulares.

COleControl::OnQueryHitRect

Lo llama el marco en respuesta a la solicitud de un contenedor IViewObjectEx::QueryHitRect.

virtual BOOL OnQueryHitRect(
    DWORD dwAspect,
    LPCRECT pRectBounds,
    LPCRECT prcLoc,
    LONG lCloseHint,
    DWORD* pHitResult);

Parámetros

dwAspect
Especifica cómo se va a representar el objeto. Los valores válidos se toman de la enumeración DVASPECT o DVASPECT2.

pRectBounds
Puntero a una estructura RECT que especifica el rectángulo delimitador del área cliente de control OLE.

prcLoc
Puntero a la estructura RECT que especifica el rectángulo que se va a comprobar para obtener una visita (superposición con el rectángulo de objeto), en relación con la esquina superior izquierda del objeto.

lCloseHint
No se utiliza.

pHitResult
Puntero al resultado de la consulta de la visita. Uno de los valores siguientes:

  • HITRESULT_OUTSIDE no hay ningún punto en el rectángulo alcanzado por el objeto OLE.

  • HITRESULT_HIT al menos un punto en el rectángulo sería una visita en el objeto.

Valor devuelto

Distinto de cero si se devuelve correctamente una línea ejecutada de aciertos; de lo contrario es 0.

Comentarios

Consulta si el rectángulo de visualización de un objeto se superpone a cualquier punto del rectángulo especificado (alcanza el rectángulo). QueryHitRect se puede invalidar para probar las visitas de los objetos no rectangulares.

COleControl::OnRenderData

El marco de trabajo llama a este método para recuperar datos en el formato especificado.

virtual BOOL OnRenderData(
    LPFORMATETC lpFormatEtc,
    LPSTGMEDIUM lpStgMedium);

Parámetros

lpFormatEtc
Apunta a la estructura FORMATETC que especifica el formato en el que se solicita la información.

lpStgMedium
Apunta a una estructura STGMEDIUM a la que se van a devolver los datos.

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

El formato especificado es uno colocado anteriormente en el objeto de control mediante las funciones miembro DelayRenderData o DelayRenderFileData para la representación retrasada. La implementación predeterminada de esta función llama a OnRenderFileData o OnRenderGlobalData, respectivamente, si el medio de almacenamiento proporcionado es un archivo o memoria. Si el formato solicitado es CF_METAFILEPICT o el formato del conjunto de propiedades persistentes, la implementación predeterminada representa los datos adecuados y devuelve un valor distinto de cero. De lo contrario, devuelve 0 y no hace nada.

Si lpStgMedium->tymed es TYMED_NULL, el STGMEDIUM debe asignarse y rellenarse según lo especificado por lpFormatEtc->tymed. Si no es TYMED_NULL, el STGMEDIUM debe rellenarse en su lugar con los datos.

Invalide esta función para proporcionar los datos en el formato y el medio solicitados. En función de los datos, es posible que se desee invalidar una de las otras versiones de esta función en su lugar. Si los datos son pequeños y fijos en su tamaño, invalide OnRenderGlobalData. Si los datos están en un archivo o tienen un tamaño variable, invalide OnRenderFileData.

Para obtener más información, consulte las estructuras FORMATETC y STGMEDIUM en Windows SDK.

COleControl::OnRenderFileData

Lo llama el marco para recuperar datos en el formato especificado cuando el medio de almacenamiento es un archivo.

virtual BOOL OnRenderFileData(
    LPFORMATETC lpFormatEtc,
    CFile* pFile);

Parámetros

lpFormatEtc
Apunta a la estructura FORMATETC que especifica el formato en el que se solicita la información.

pFile
Apunta a un objeto CFile en el que se van a representar los datos.

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

El formato especificado es uno colocado anteriormente en el objeto de control mediante la función miembro DelayRenderData para la representación retrasada. La implementación predeterminada de esta función devuelve FALSE.

Invalide esta función para proporcionar los datos en el formato y el medio solicitados. En función de los datos, es posible que se desee invalidar una de las otras versiones de esta función en su lugar. Si desea controlar varios medios de almacenamiento, invalide OnRenderData. Si los datos están en un archivo o tienen un tamaño variable, invalide OnRenderFileData.

Para obtener más información, vea la estructura FORMATETC en Windows SDK.

COleControl::OnRenderGlobalData

El marco de trabajo llama a este método para recuperar los datos en el formato especificado cuando el medio de almacenamiento especificado es la memoria global.

virtual BOOL OnRenderGlobalData(
    LPFORMATETC lpFormatEtc,
    HGLOBAL* phGlobal);

Parámetros

lpFormatEtc
Apunta a la estructura FORMATETC que especifica el formato en el que se solicita la información.

phGlobal
Apunta a un manipulador de la memoria global en la que se van a devolver los datos. Si no se ha asignado una memoria, este parámetro puede ser NULL.

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

El formato especificado es uno colocado anteriormente en el objeto de control mediante la función miembro DelayRenderData para la representación retrasada. La implementación predeterminada de esta función devuelve FALSE.

Si phGlobal es NULL, se debe asignar y devolver un nuevo elemento HGLOBAL en phGlobal. De lo contrario, el elemento HGLOBAL especificado por phGlobal se debe rellenar con los datos. La cantidad de datos colocados en HGLOBAL no debe superar el tamaño actual del bloque de memoria. Además, el bloque no se puede reasignar a un tamaño mayor.

Invalide esta función para proporcionar los datos en el formato y el medio solicitados. En función de los datos, es posible que se desee invalidar una de las otras versiones de esta función en su lugar. Si desea controlar varios medios de almacenamiento, invalide OnRenderData. Si los datos están en un archivo o tienen un tamaño variable, invalide OnRenderFileData.

Para obtener más información, vea la estructura FORMATETC en Windows SDK.

COleControl::OnResetState

Lo llama el marco cuando las propiedades del control deben establecerse en sus valores predeterminados.

virtual void OnResetState();

Comentarios

La implementación predeterminada llama a DoPropExchange, pasando un objeto CPropExchange que hace que las propiedades se establezcan en sus valores predeterminados.

El escritor de control puede insertar un código de inicialización para el control OLE en este reemplazable. Se llama a esta función cuando se produce un error en IPersistStream::Load o IPersistStorage::Load, o se llama a IPersistStreamInit::InitNew, o IPersistStorage::InitNew, sin llamar primero a IPersistStream::Load o IPersistStorage::Load.

COleControl::OnSetClientSite

Lo llama el marco cuando el contenedor ha llamado a la función IOleControl::SetClientSite del control.

virtual void OnSetClientSite();

Comentarios

De forma predeterminada, OnSetClientSite comprueba si se cargan las propiedades de ruta de acceso de datos y, si son, llama a DoDataPathPropExchange.

Invalide esta función para realizar cualquier procesamiento especial de esta notificación. En concreto, las invalidaciones de esta función deben llamar a la clase base.

COleControl::OnSetData

Llamado por el marco para reemplazar los datos del control con los datos especificados.

virtual BOOL OnSetData(
    LPFORMATETC lpFormatEtc,
    LPSTGMEDIUM lpStgMedium,
    BOOL bRelease);

Parámetros

lpFormatEtc
Puntero a una estructura FORMATETC que especifica el formato de los datos.

lpStgMedium
Puntero a una estructura STGMEDIUM en la que residen los datos.

bRelease
TRUE si el control debe liberar el medio de almacenamiento; FALSE si el control no debe liberar el medio de almacenamiento.

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

Si los datos están en el formato de conjunto de propiedades persistentes, la implementación predeterminada modifica el estado del control en consecuencia. De lo contrario, la implementación predeterminada no hace nada. Si bRelease es TRUE, se realiza una llamada a ReleaseStgMedium; de lo contrario, no se realiza.

Invalide esta función para reemplazar los datos de control con los datos especificados.

Para obtener más información, consulte las estructuras FORMATETC y STGMEDIUM en Windows SDK.

COleControl::OnSetExtent

Lo llama el marco cuando es necesario cambiar la extensión del control, como resultado de una llamada a IOleObject::SetExtent.

virtual BOOL OnSetExtent(LPSIZEL lpSizeL);

Parámetros

lpSizeL
Puntero a la estructura SIZEL que usa enteros largos para representar el ancho y el alto del control, expresados en unidades HIMETRIC.

Valor devuelto

Distinto de cero si se aceptó el cambio de tamaño; de lo contrario es 0.

Comentarios

La implementación predeterminada controla el cambio de tamaño de la extensión del control. Si el control está activo en el lugar, se realiza una llamada al contenedor OnPosRectChanged.

Invalide esta función para modificar el cambio de tamaño predeterminado del control.

COleControl::OnSetObjectRects

Lo llama el marco para implementar una llamada a IOleInPlaceObject::SetObjectRects.

virtual BOOL OnSetObjectRects(
    LPCRECT lpRectPos,
    LPCRECT lpRectClip);

Parámetros

lpRectPos
Puntero a una estructura RECT que indica la nueva posición y el tamaño del control en relación con el contenedor.

lpRectClip
Puntero a una estructura RECT que indica un área rectangular a la que se va a recortar el control.

Valor devuelto

Distinto de cero si se aceptó el cambio de posición; de lo contrario es 0.

Comentarios

La implementación predeterminada controla automáticamente el cambio de posición y el cambio del tamaño de la ventana de control y devuelve TRUE.

Invalide esta función para modificar el comportamiento predeterminado de esta función.

COleControl::OnShowToolBars

Lo llama el marco cuando se ha activado la interfaz de usuario del control.

virtual void OnShowToolBars();

Comentarios

La implementación predeterminada no hace nada.

COleControl::OnTextChanged

Lo llama el marco cuando el valor de la propiedad Caption o Text del stock ha cambiado.

virtual void OnTextChanged();

Comentarios

La implementación predeterminada llama a InvalidateControl.

Invalide esta función si se desea una notificación después de que cambie esta propiedad.

COleControl::OnWindowlessMessage

Lo llama el marco en respuesta a la solicitud de un contenedor IOleInPlaceObjectWindowless::OnWindowMessage.

virtual BOOL OnWindowlessMessage(
    UINT msg,
    WPARAM wParam,
    LPARAM lParam,
    LRESULT* plResult);

Parámetros

msg
Identificador de mensaje tal y como lo pasa Windows.

wParam
Tal y como pasa Windows. Especifica información adicional específica de los mensajes. El contenido de este parámetro depende del valor del parámetro msg.

lParam
Tal y como pasa Windows. Especifica información adicional específica de los mensajes. El contenido de este parámetro depende del valor del parámetro msg.

plResult
Código de resultado de Windows. Especifica el resultado del procesamiento del mensaje y depende del mensaje enviado.

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

Procesa los mensajes de ventana para los controles sin ventana. Los COleControl deOnWindowlessMessage se deben usar para los mensajes de ventana distintos de los mensajes del mouse y los mensajes de teclado. COleControl proporciona SetCapture y SetFocus específicamente para obtener la captura del mouse y el foco de teclado para objetos OLE sin ventana.

Dado que los objetos sin ventana no tienen una ventana, necesitan un mecanismo para permitir que el contenedor envíe mensajes a ellos. Un objeto OLE sin ventana obtiene mensajes de su contenedor, a través del método OnWindowMessage en la interfaz IOleInPlaceObjectWindowless (una extensión de IOleInPlaceObject para la compatibilidad sin ventanas). OnWindowMessage no acepta un parámetro HWND.

COleControl::ParentToClient

Convierte las coordenadas de pPoint en coordenadas cliente.

virtual UINT ParentToClient(
    LPCRECT lprcBounds,
    LPPOINT pPoint,
    BOOL bHitTest = FALSE) const;

Parámetros

lprcBounds
Puntero a los límites del control OLE dentro del contenedor. No el área de cliente, sino el área de todo el control, incluidos los bordes y las barras de desplazamiento.

pPoint
Puntero al punto primario (contenedor) que debe trasladarse a las coordenadas del área cliente del control.

bHitTest
Especifica si se deben realizar pruebas de alcance o no en el punto.

Valor devuelto

Si bHitTest es FALSE, devuelve HTNOWHERE. Si bHitTest es TRUE, devuelve la ubicación en la que el punto primario (contenedor) se encuentra en el área cliente del control OLE y es uno de los siguientes valores de prueba de posicionamiento del mouse:

  • HTBORDER en el borde de una ventana que no tiene un borde de dimensionamiento de tamaño.

  • HTBOTTOM en el borde horizontal inferior de la ventana.

  • HTBOTTOMLEFT en la esquina inferior izquierda del borde de la ventana.

  • HTBOTTOMRIGHT en la esquina inferior derecha del borde de la ventana.

  • HTCAPTION en un área de barra de título.

  • HTCLIENT en un área de cliente.

  • HTERROR en el fondo de la pantalla o en una línea divisoria entre ventanas (igual que HTNOWHERE, excepto que la función de Windows DefWndProc genere un pitido del sistema para indicar un error).

  • HTGROWBOX en un cuadro de tamaño.

  • HTHSCROLL en la barra de desplazamiento horizontal.

  • HTLEFT en el borde izquierdo de la ventana.

  • HTMAXBUTTON en un botón de maximizar.

  • HTMENU en un área del menú.

  • HTMINBUTTON en un botón de minimizar.

  • HTNOWHERE en el fondo de la pantalla o en una línea divisoria entre ventanas.

  • HTREDUCE en un botón de minimizar.

  • HTRIGHT en el borde derecho de la ventana.

  • HTSIZE en un cuadro de tamaño (igual que HTGROWBOX).

  • HTSYSMENU en un menú de control o en un botón de cierre en una ventana secundaria.

  • HTTOP en el borde horizontal superior de la ventana.

  • HTTOPLEFT en la esquina superior izquierda del borde de la ventana.

  • HTTOPRIGHT en la esquina superior derecha del borde de la ventana.

  • HTTRANSPARENT en una ventana cubierta actualmente por otra ventana.

  • HTVSCROLL en la barra de desplazamiento vertical.

  • HTZOOM en un botón de maximizar.

Comentarios

En el pPoint de entrada es relativo al origen del elemento primario (esquina superior izquierda del contenedor). En el pPoint de salida es relativo al origen del área cliente del control OLE (esquina superior izquierda del área cliente del control).

COleControl::PostModalDialog

Notifica al contenedor que se cerró un cuadro de diálogo modal.

void PostModalDialog(HWND hWndParent = NULL);

Parámetros

hWndParent
Manipulador a la ventana primaria del cuadro de diálogo modal.

Comentarios

Llame a esta función después de mostrar cualquier cuadro de diálogo modal. Se debe llamar a esta función para que el contenedor pueda habilitar cualquier ventana de nivel superior deshabilitada por PreModalDialog. Esta función debe emparejarse con una llamada a PreModalDialog.

COleControl::PreModalDialog

Notifica al contenedor que se va a mostrar un cuadro de diálogo modal.

void PreModalDialog(HWND hWndParent = NULL);

Parámetros

hWndParent
Manipulador a la ventana primaria del cuadro de diálogo modal.

Comentarios

Llame a esta función antes de mostrar cualquier cuadro de diálogo modal. Se debe llamar a esta función para que el contenedor pueda deshabilitar todas sus ventanas. Después de mostrar el cuadro de diálogo modal, debe llamar a PostModalDialog.

COleControl::RecreateControlWindow

Destruye y vuelve a crear la ventana del control.

void RecreateControlWindow();

Comentarios

Esto puede ser necesario si se necesitan cambiar los bits de estilo de la ventana.

COleControl::Refresh

Fuerza un reintentos del control OLE.

void Refresh();

Comentarios

Esta función es compatible con la clase base COleControl como método del stock, denominado Refresh. Esto permite a los usuarios del control OLE volver a dibujar el control en un momento específico. Para obtener más información de este método, consulte el artículo Métodos de control ActiveX.

COleControl::ReleaseCapture

Libera la captura del mouse.

BOOL ReleaseCapture();

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

Si el control tiene actualmente la captura del mouse, se libera la captura. De lo contrario, esta función no tendrá efecto.

COleControl::ReleaseDC

Libera el contexto del dispositivo para mostrar un contenedor de un control sin ventanas, liberando el contexto del dispositivo para que lo usen otras aplicaciones.

int ReleaseDC(CDC* pDC);

Parámetros

pDC
Identifica el contexto del dispositivo contenedor que va a liberarse.

Valor devuelto

Si es correcta, su valor es distinto de cero. En caso contrario, es cero.

Comentarios

La aplicación debe llamar a ReleaseDC, para cada llamada a GetDC.

COleControl::ReparentControlWindow

Establece el elemento primario del control.

virtual void ReparentControlWindow(
    HWND hWndOuter,
    HWND hWndParent);

Parámetros

hWndOuter
Manipulador de la ventana de control.

hWndParent
Manipulador de la nueva ventana primaria.

Comentarios

Llame a esta función para restablecer el elemento primario de la ventana de control.

COleControl::ResetStockProps

Inicializa el estado de las propiedades del stock COleControl en sus valores predeterminados.

void ResetStockProps();

Comentarios

Las propiedades son: Appearance, BackColor, BorderStyle, Caption, Enabled, Font, ForeColor, hWnd y Text. Para obtener una descripción de las propiedades del stock, consulte Controles ActiveX: Agregar propiedades de stock.

Puede mejorar el rendimiento de inicialización binaria de un control mediante ResetStockProps y ResetVersion para invalidar COleControl::OnResetState. Observe el ejemplo siguiente. Para obtener más información sobre cómo optimizar la inicialización, consulte Controles ActiveX: Optimización.

Ejemplo

void CMyAxCtrl::OnResetState()
{
   ResetVersion(MAKELONG(_wVerMinor, _wVerMajor));
   ResetStockProps();

   // initialize custom properties here
}

COleControl::ResetVersion

Inicializa el número de versión en el valor especificado.

void ResetVersion(DWORD dwVersionDefault);

Parámetros

dwVersionDefault
Número de versión que se va a asignar al control.

Comentarios

Puede mejorar el rendimiento de inicialización binaria de un control mediante ResetVersion y ResetStockProps para invalidar COleControl::OnResetState. Vea el ejemplo en ResetStockProps. Para obtener más información sobre cómo optimizar la inicialización, consulte Controles ActiveX: Optimización.

COleControl::ScrollWindow

Permite a un objeto OLE sin ventanas desplazar un área dentro de su imagen activa en la pantalla.

void ScrollWindow(
    int xAmount,
    int yAmount,
    LPCRECT lpRect = NULL,
    LPCRECT lpClipRect = NULL);

Parámetros

xAmount
Especifica la cantidad, en unidades de dispositivo, de desplazamiento horizontal. Este parámetro debe tener un valor negativo para desplazarse a la izquierda.

yAmount
Especifica la cantidad, en unidades de dispositivo, de desplazamiento vertical. Este parámetro debe tener un valor negativo para desplazarse hacia arriba.

lpRect
Apunta a un objeto CRect o a una estructura RECT que especifica la parte del área cliente del objeto OLE que se va a desplazar, en coordenadas de cliente de la ventana contenedora. Si lpRect es NULL, se desplaza el área de cliente del objeto OLE por completo.

lpClipRect
Apunta a un objeto CRect o estructura RECT que especifica el rectángulo de recorte que se va a recortar. Solo se desplazan los píxeles dentro del rectángulo. Los bits fuera del rectángulo no se ven afectados aunque estén en el rectángulo lpRect. Si lpClipRect es NULL, no se realiza ningún recorte en el rectángulo de desplazamiento.

COleControl::SelectFontObject

Selecciona una fuente en un contexto de dispositivo.

CFont* SelectFontObject(
    CDC* pDC,
    CFontHolder& fontHolder);

Parámetros

pDC
Puntero a un objeto de contexto del dispositivo.

fontHolder
Referencia al objeto CFontHolder que representa la fuente que se va a seleccionar.

Valor devuelto

Puntero a la fuente seleccionada previamente. Cuando el autor de la llamada haya terminado todas las operaciones de dibujo que usan fontHolder, debe volver a seleccionar la fuente seleccionada previamente pasándola como parámetro a CDC::SelectObject.

COleControl::SelectStockFont

Selecciona la propiedad Font del stock personalizada en un contexto de dispositivo.

CFont* SelectStockFont(CDC* pDC);

Parámetros

pDC
Contexto del dispositivo en el que se seleccionará la fuente.

Valor devuelto

Puntero al objeto CFont seleccionado previamente. Debe usar CDC::SelectObject para volver a seleccionar esta fuente en el contexto del dispositivo cuando haya terminado.

COleControl::SerializeExtent

Serializa o inicializa el estado del espacio de presentación asignado al control.

void SerializeExtent(CArchive& ar);

Parámetros

Ar
Objeto CArchive que se va a serializar hacia o desde.

Comentarios

Se puede mejorar el rendimiento de la persistencia binaria de un control mediante SerializeExtent, SerializeStockProps y SerializeVersion para invalidar a COleControl::Serialize. Observe el ejemplo siguiente. Para obtener más información sobre cómo optimizar la inicialización, consulte Controles ActiveX: Optimización.

Ejemplo

void CMyAxCtrl::Serialize(CArchive &ar)
{
   SerializeVersion(ar, MAKELONG(_wVerMinor, _wVerMajor));
   SerializeExtent(ar);
   SerializeStockProps(ar);

   if (ar.IsStoring())
   { // storing code
   }
   else
   { // loading code
   }
}

COleControl::SerializeStockProps

Serializa o inicializa el estado de las propiedades de COleControl del stock: Appearance, BackColor, BorderStyle, Caption, Enabled, Font, ForeColor y Text.

void SerializeStockProps(CArchive& ar);

Parámetros

Ar
Objeto CArchive que se va a serializar hacia o desde.

Comentarios

Para obtener una descripción de las propiedades del stock, consulte Controles ActiveX: Agregar propiedades de stock.

Se puede mejorar el rendimiento de la persistencia binaria de un control mediante SerializeStockProps, SerializeExtent y SerializeVersion para invalidar a COleControl::Serialize. Para obtener un ejemplo, vea el código en SerializeExtent. Para obtener más información sobre cómo optimizar la inicialización, consulte Controles ActiveX: Optimización.

COleControl::SerializeVersion

Serializa o inicializa el estado de la información de la versión de un control.

DWORD SerializeVersion(
    CArchive& ar,
    DWORD dwVersionDefault,
    BOOL bConvert = TRUE);

Parámetros

Ar
Objeto CArchive que se va a serializar hacia o desde.

dwVersionDefault
Número de versión actual del control.

bConvert
Indica si los datos persistentes se deben convertir al formato más reciente al guardarse o deben mantenerse en el mismo formato cuando se cargaron.

Valor devuelto

Número de versión del control. Si el archivo especificado se está cargando, SerializeVersion devuelve la versión cargada desde ese archivo. De lo contrario, devuelve la versión cargada actualmente.

Comentarios

Se puede mejorar el rendimiento de la persistencia binaria de un control mediante SerializeVersion, SerializeExtent y SerializeStockProps para invalidar a COleControl::Serialize. Para obtener un ejemplo, vea el código en SerializeExtent. Para obtener más información sobre cómo optimizar la inicialización, consulte Controles ActiveX: Optimización.

COleControl::SetAppearance

Establece el valor de la propiedad Appearance del stock de control.

void SetAppearance (short sAppearance);

Parámetros

sAppearance
Valor short (VT_I2) que se usará para la apariencia del control. Un valor de cero establece la apariencia del control en plano y un valor de 1 establece la apariencia del control en 3D.

Comentarios

Para obtener más información sobre las propiedades del stock, consulte Controles ActiveX: Propiedades.

COleControl::SetBackColor

Establece el valor de la propiedad BackColor del stock de control.

void SetBackColor(OLE_COLOR dwBackColor);

Parámetros

dwBackColor
Valor de OLE_COLOR que se usará para el dibujo en segundo plano del control.

Comentarios

Para obtener más información sobre el uso de esta propiedad y otras propiedades relacionadas, consulte el artículo Controles ActiveX: Propiedades.

COleControl::SetBorderStyle

Establece el valor de la propiedad BorderStyle del stock de control.

void SetBorderStyle(short sBorderStyle);

Parámetros

sBorderStyle
Nuevo estilo de borde para el control; 0 indica que no hay borde y 1 indica un borde normal.

Comentarios

La ventana de control se volverá a crear y se llamará a OnBorderStyleChanged.

COleControl::SetCapture

Hace que la ventana contenedora del control tome posesión de la captura del mouse en nombre del control.

CWnd* SetCapture();

Valor devuelto

Puntero al objeto de ventana CWnd que ha recibido previamente la entrada del mouse.

Comentarios

Si el control está activado y sin ventanas, esta función hace que la ventana contenedora del control tome posesión de la captura del mouse, en nombre del control. De lo contrario, esta función hace que el propio control tome posesión de la captura del mouse (igual que CWnd::SetCapture).

COleControl::SetControlSize

Establece el tamaño de la ventana de control OLE y notifica al contenedor que el sitio de control está cambiando.

BOOL SetControlSize(int cx, int cy);

Parámetros

cx
Especifica el nuevo ancho del control, en píxeles.

Cy
Especifica la nueva altura del control, en píxeles.

Valor devuelto

Distinto de cero si el método fue correcto; en caso contrario es 0.

Comentarios

Esta función no se debe usar en el constructor del control.

Tenga en cuenta que todas las coordenadas de las ventanas de control son relativas a la esquina superior izquierda del control.

COleControl::SetEnabled

Establece el valor de la propiedad Enabled del stock de control.

void SetEnabled(BOOL bEnabled);

Parámetros

bEnabled
TRUE si se va a habilitar el control; en caso contrario, FALSE.

Comentarios

Después de establecer esta propiedad, se llama a OnEnabledChange.

COleControl::SetFocus

Hace que la ventana contenedora del control tome posesión del foco de entrada en nombre del control.

CWnd* SetFocus();

Valor devuelto

Puntero al objeto de ventana CWnd que anteriormente tenía el foco de entrada o NULL si no hay dicha ventana.

Comentarios

Si el control está activado y sin ventanas, esta función hace que la ventana contenedora del control tome posesión del foco de entrada, en nombre del control. El foco de entrada dirige la entrada del teclado a la ventana del contenedor y el contenedor envía todos los mensajes de teclado posteriores al objeto OLE que llama a SetFocus. Cualquier ventana que tuviera previamente el foco de entrada lo pierde.

Si el control no es sin ventanas, esta función hace que el propio control tome posesión del foco de entrada (igual que CWnd::SetFocus).

COleControl::SetFont

Establece la propiedad Font del stock del control.

void SetFont(LPFONTDISP pFontDisp);

Parámetros

pFontDisp
Puntero a una interfaz de envío Font.

COleControl::SetForeColor

Establece el valor de la propiedad ForeColor del stock de control.

void SetForeColor(OLE_COLOR dwForeColor);

Parámetros

dwForeColor
Valor de OLE_COLOR que se usará para el dibujo en primer plano del control.

Comentarios

Para obtener más información sobre el uso de esta propiedad y otras propiedades relacionadas, consulte el artículo Controles ActiveX: Propiedades.

COleControl::SetInitialDataFormats

Lo llama el marco para inicializar la lista de formatos de datos admitidos por el control.

virtual void SetInitialDataFormats();

Comentarios

La implementación predeterminada especifica dos formatos: CF_METAFILEPICT y el conjunto de propiedades persistentes.

COleControl::SetInitialSize

Establece el tamaño de un control OLE cuando se muestra por primera vez en un contenedor.

void SetInitialSize(
    int cx,
    int cy);

Parámetros

cx
Ancho inicial del control OLE en píxeles.

Cy
Altura inicial del control OLE en píxeles.

Comentarios

Llame a esta función en el constructor para establecer el tamaño inicial del control. El tamaño inicial se mide en unidades de dispositivo o píxeles. Se recomienda realizar esta llamada en el constructor del control.

COleControl::SetModifiedFlag

Cambia el estado modificado de un control.

void SetModifiedFlag(BOOL bModified = TRUE);

Parámetros

bModified
Nuevo valor para la marca modificada del control. TRUE indica que se ha modificado el estado del control; FALSE indica que el estado del control se acaba de guardar.

Comentarios

Llame a esta función cada vez que se produzca un cambio que pueda afectar al estado persistente del control. Por ejemplo, si cambia el valor de una propiedad persistente, llame a esta función con bModifiedTRUE.

COleControl::SetNotPermitted

Indica que se ha producido un error en una solicitud de edición.

void SetNotPermitted();

Comentarios

Llame a esta función cuando BoundPropertyRequestEdit falle. Esta función produce una excepción de tipo COleDispScodeException para indicar que no se permitió la operación Set.

COleControl::SetNotSupported

Impide la modificación del valor de la propiedad de un control por parte del usuario.

void SetNotSupported();

Comentarios

Llame a esta función en lugar de la función Set de cualquier propiedad donde no se admita la modificación del valor de propiedad por parte del usuario del control. Un ejemplo sería una propiedad que es de solo lectura.

COleControl::SetRectInContainer

Establece las coordenadas del rectángulo del control en relación con el contenedor, expresado en unidades del dispositivo.

BOOL SetRectInContainer(LPCRECT lpRect);

Parámetros

lpRect
Puntero a un rectángulo que contiene las nuevas coordenadas del control en relación con el contenedor.

Valor devuelto

Distinto de cero si el método fue correcto; en caso contrario es 0.

Comentarios

Si el control está abierto, se cambia el tamaño; de lo contrario, se llama a la función OnPosRectChanged del contenedor.

COleControl::SetText

Establece el valor de la propiedad Caption o Text del stock del control.

void SetText(LPCTSTR pszText);

Parámetros

pszText
Un puntero a la cadena de caracteres.

Comentarios

Tenga en cuenta que las propiedades Caption y Text del stock están asignadas al mismo valor. Esto significa que los cambios realizados en cualquiera de las propiedades cambiarán automáticamente a ambas propiedades. En general, un control debe admitir la propiedad Caption o Text del stock, pero no ambas.

COleControl::ThrowError

Indica la aparición de un error en el control.

void ThrowError(
    SCODE sc,
    UINT nDescriptionID,
    UINT nHelpID = -1);

void ThrowError(
    SCODE sc,
    LPCTSTR pszDescription = NULL,
    UINT nHelpID = 0);

Parámetros

sc
Valor de código de estado que se va a informar. Para obtener una lista completa de los posibles códigos, consulte el artículo Controles ActiveX: Temas avanzados.

nDescriptionID
Identificador de recurso de cadena de la excepción que se va a informar.

nHelpID
Id. de ayuda del tema en el que se va a informar.

pszDescription
Cadena que contiene una explicación de la excepción que se va a informar.

Comentarios

Solo se debe llamar a esta función desde una función Get o Set para una propiedad OLE o desde la implementación de un método de automatización OLE. Si necesita indicar los errores que se producen en otros momentos, se debe desencadenar el evento error del stock.

COleControl::TransformCoords

Transforma los valores de coordenadas entre las unidades HIMETRIC y las unidades nativas del contenedor.

void TransformCoords(
    POINTL* lpptlHimetric,
    POINTF* lpptfContainer,
    DWORD flags);

Parámetros

lpptlHimetric
Puntero a una estructura POINTL que contiene coordenadas en unidades HIMETRIC.

lpptfContainer
Puntero a una estructura POINTF que contiene coordenadas en el tamaño de unidad del contenedor.

flags
Combinación de las marcas de los valores siguientes:

  • XFORMCOORDS_POSITION, posición en el contenedor.

  • XFORMCOORDS_SIZE, un tamaño en el contenedor.

  • XFORMCOORDS_HIMETRICTOCONTAINER, transformar unidades HIMETRIC en las unidades del contenedor.

  • XFORMCOORDS_CONTAINERTOHIMETRIC, transformar las unidades del contenedor en unidades HIMETRIC.

Comentarios

Las dos primeras marcas, XFORMCOORDS_POSITION y XFORMCOORDS_SIZE, indican si las coordenadas deben tratarse como una posición o un tamaño. Las dos marcas restantes indican la dirección de la transformación.

COleControl::TranslateColor

Convierte un valor de color del tipo de datos OLE_COLOR al tipo de datos COLORREF.

COLORREF TranslateColor(
    OLE_COLOR clrColor,
    HPALETTE hpal = NULL);

Parámetros

clrColor
Tipo de datos OLE_COLOR. Para obtener más información, consulte la función OleTranslateColor de Windows.

hpal
Manipulador de una paleta opcional; puede ser NULL.

Valor devuelto

Valor de color RGB (rojo, verde, azul) de 32 bits que define el color sólido más cercano al valor clrColor que el dispositivo puede representar.

Comentarios

Esta función es útil para trasladar las propiedades ForeColor y BackColor del stock a tipos COLORREF usados por las funciones miembro CDC .

COleControl::WillAmbientsBeValidDuringLoad

Determina si el control debe usar los valores de las propiedades de ambiente como valores predeterminados, cuando posteriormente se carga desde su estado persistente.

BOOL WillAmbientsBeValidDuringLoad();

Valor devuelto

Distinto a cero indica que las propiedades de ambiente serán válidas; de lo contrario, dichas propiedades no serán válidas.

Comentarios

En algunos contenedores, es posible que el control no tenga acceso a sus propiedades de ambiente durante la llamada inicial a la invalidación de COleControl::DoPropExchange. Este es el caso si el contenedor llama a IPersistStreamInit::Load o IPersistStorage::Load antes de llamar a IOleObject::SetClientSite (es decir, si no respeta el bit de estado de OLEMISC_SETCLIENTSITEFIRST).

COleControl::WindowProc

Proporciona un procedimiento de Windows para un objeto COleControl.

virtual LRESULT WindowProc(
    UINT message,
    WPARAM wParam,
    LPARAM lParam);

Parámetros

message
Especifica el mensaje de Windows que se va a procesar.

wParam
Proporciona información adicional que se usa para procesar el mensaje. El valor de este parámetro depende del mensaje.

lParam
Proporciona información adicional que se usa para procesar el mensaje. El valor de este parámetro depende del mensaje.

Valor devuelto

Valor devuelto del mensaje enviado.

Comentarios

Llame a esta función para enviar mensajes específicos a través de la asignación de mensajes del control.

Consulte también

Muestra MFC CIRC3
Muestra de MFC TESTHELP
COlePropertyPage (clase)
CWnd (clase)
Gráfico de jerarquías
CFontHolder (clase)
CPictureHolder (clase)