Struttura OLEUIPASTESPECIALA (oledlg.h)

Contiene informazioni usate dalla libreria dell'interfaccia utente OLE per inizializzare la finestra di dialogo Incolla speciale , nonché lo spazio per la libreria per restituire informazioni quando la finestra di dialogo viene ignorata.

Sintassi

typedef struct tagOLEUIPASTESPECIALA {
  DWORD              cbStruct;
  DWORD              dwFlags;
  HWND               hWndOwner;
  LPCSTR             lpszCaption;
  LPFNOLEUIHOOK      lpfnHook;
  LPARAM             lCustData;
  HINSTANCE          hInstance;
  LPCSTR             lpszTemplate;
  HRSRC              hResource;
  LPDATAOBJECT       lpSrcDataObj;
  LPOLEUIPASTEENTRYA arrPasteEntries;
  int                cPasteEntries;
  UINT               *arrLinkTypes;
  int                cLinkTypes;
  UINT               cClsidExclude;
  LPCLSID            lpClsidExclude;
  int                nSelectedIndex;
  BOOL               fLink;
  HGLOBAL            hMetaPict;
  SIZEL              sizel;
} OLEUIPASTESPECIALA, *POLEUIPASTESPECIALA, *LPOLEUIPASTESPECIALA;

Members

cbStruct

Dimensioni della struttura, in byte. Questo membro deve essere compilato in input.

dwFlags

In input, dwFlags specifica i flag di inizializzazione e creazione. In uscita specifica le scelte dell'utente. Può essere una combinazione dei flag seguenti.

Valore Significato
PSF_SHOWHELP
Nella finestra di dialogo verrà visualizzato un pulsante Della Guida .
PSF_SELECTPASTE
Il pulsante di opzione Incolla verrà selezionato all'avvio della finestra di dialogo. Si tratta del valore predefinito, se PSF_SELECTPASTE o PSF_SELECTPASTELINK non sono specificati. Specifica anche lo stato del pulsante sulla terminazione della finestra di dialogo. Flag IN/OUT.
PSF_SELECTPASTELINK
Il pulsante di opzione PasteLink verrà selezionato all'avvio della finestra di dialogo. Specifica anche lo stato del pulsante sulla terminazione della finestra di dialogo. Flag IN/OUT.
PSF_CHECKDISPLAYASICON
Se il pulsante di opzione Visualizza come icona è stato selezionato sulla terminazione della finestra di dialogo. Flag OUT.
PSF_DISABLEDISPLAYASICON
Nella casella di controllo Visualizza icona verrà disabilitata l'inizializzazione.
HIDECHANGEICON
Usato per disabilitare il pulsante di modifica icona nella finestra di dialogo, disponibile per gli utenti quando incollano un oggetto OLE per impostazione predefinita. Vedere STAYONCLIPBOARDCHANGE in caso contrario.
STAYONCLIPBOARDCHANGE
Usato per indicare alla finestra di dialogo di rimanere aggiornati se gli Appunti cambiano durante la finestra di dialogo. Se l'utente passa a un'altra applicazione e copia o taglia qualcosa, la finestra di dialogo eseguirà per impostazione predefinita un'operazione di annullamento, che rimuoverà la finestra di dialogo poiché le opzioni che si trovano al centro della presentazione all'utente non sono più aggiornate rispetto a ciò che è realmente negli Appunti.
NOREFRESHDATAOBJECT
Usato in combinazione con STAYONCLIPBOARDCHANGE (non fa nulla in caso contrario). Se gli Appunti cambiano mentre la finestra di dialogo è su e VIENE specificato STAYONCLIPBOARDCHANGE , NOREFRESHDATAOBJECT indica che la finestra di dialogo non deve aggiornare il contenuto della finestra di dialogo per riflettere il nuovo contenuto degli Appunti. Ciò è utile se l'applicazione usa la finestra di dialogo incolla-speciale su un oggetto IDataObject oltre a quello negli Appunti, ad esempio come parte di un'operazione di trascinamento trascinamento e rilascio con il pulsante destro del mouse.

hWndOwner

Finestra proprietaria della finestra di dialogo. Questo membro non deve essere NULL.

lpszCaption

Puntatore a una stringa da utilizzare come titolo della finestra di dialogo. Se NULL, la libreria usa Incolla speciale.

lpfnHook

Puntatore a una funzione hook che elabora i messaggi destinati alla finestra di dialogo. La funzione hook deve restituire zero per passare un messaggio che non è stato elaborato nella procedura della finestra di dialogo nella libreria. La funzione hook deve restituire un valore diverso da zero per impedire alla routine della finestra di dialogo della libreria di elaborare un messaggio già elaborato.

lCustData

Dati definiti dall'applicazione che la libreria passa alla funzione hook a cui punta il membro lpfnHook . La libreria passa un puntatore alla struttura OLEUIPASTESPECIAL nel parametro lParam del messaggio di WM_INITDIALOG; questo puntatore può essere usato per recuperare il membro lCustData .

hInstance

Istanza che contiene un modello di finestra di dialogo specificato dal membro lpTemplateName .

lpszTemplate

Puntatore a una stringa con terminazione null che specifica il nome del file di risorsa per il modello di finestra di dialogo che deve essere sostituito per il modello di finestra di dialogo Incolla speciale della libreria.

hResource

Handle modello personalizzato.

lpSrcDataObj

Puntatore all'interfaccia IDataObject dell'oggetto dati da incollare (dagli Appunti). Questo membro viene compilato in input. Se lpSrcDataObj è NULL quando viene chiamato OleUIPasteSpecial, OleUIPasteSpecial tenterà di recuperare un puntatore a un oggetto IDataObject dagli Appunti. Se OleUIPasteSpecial riesce, è responsabilità del chiamante liberare IDataObject restituito in lpSrcDataObj.

arrPasteEntries

Matrice OLEUIPASTEENTRY che specifica formati accettabili. Questo membro viene compilato in input.

cPasteEntries

Numero di voci della matrice OLEUIPASTEENTRY . Questo membro viene compilato in input.

arrLinkTypes

Elenco di tipi di collegamento accettabili. I tipi di collegamento vengono definiti usando OLEUIPASTEFLAG in arrPasteEntries. Questo membro viene compilato in input.

cLinkTypes

Numero di tipi di collegamento. Questo membro viene compilato in input.

cClsidExclude

Numero di CLSID in lpClsidExclude. Questo membro viene compilato in input.

lpClsidExclude

Puntatore a una matrice di CLSID da escludere dall'elenco di oggetti server disponibili per un'operazione Incolla. Si noti che questo non influisce sul collegamento incolla. Un'applicazione può impedire l'incorporamento in se stessa elencando il proprio CLSID in questo elenco. Questo campo viene riempito in input.

nSelectedIndex

Indice di arrPasteEntries selezionato dall'utente. Questo membro viene compilato nell'output.

fLink

Se incolla o incolla collegamento è stato selezionato dall'utente. Questo membro viene compilato nell'output.

hMetaPict

Gestire il metafile contenente l'icona e il titolo dell'icona selezionati dall'utente. Questo membro viene compilato nell'output.

sizel

Dimensione dell'oggetto visualizzato nell'origine, se l'aspetto visualizzato scelto dall'utente corrisponde all'aspetto visualizzato nell'origine. Se l'utente sceglie un aspetto diverso, sizel.cx e sizel.cy sono entrambi impostati su zero. Le dimensioni dell'oggetto visualizzato nell'origine vengono recuperate dall'oggetto ObjectDescriptor se fLink è FALSE e dal LinkSrcDescriptor se fLink è TRUE. Questo membro viene compilato nell'output.

Commenti

Nota

L'intestazione oledlg.h definisce OLEUIPASTESPECIAL come alias che seleziona automaticamente la versione ANSI o Unicode di questa funzione in base alla definizione della costante preprocessore UNICODE. La combinazione dell'utilizzo dell'alias di codifica neutrale con il codice che non è neutrale dalla codifica può causare errori di corrispondenza che causano errori di compilazione o runtime. Per altre informazioni, vedere Convenzioni per i prototipi di funzione.

Requisiti

Requisito Valore
Client minimo supportato Windows 2000 Professional [solo app desktop]
Server minimo supportato Windows 2000 Server [solo app desktop]
Intestazione oledlg.h

Vedi anche

OLEUIPASTEENTRY

OLEUIPASTEFLAG

OleUIPasteSpecial