Classe di CScrollView
CView con le funzionalità di scorrimento.
class CScrollView : public CView
Membri
Costruttori protetti
Nome |
Descrizione |
---|---|
Costruisce un oggetto CScrollView. |
Metodi pubblici
Nome |
Descrizione |
---|---|
Indica se la visualizzazione a scorrimento ha senso orizzontale e barre di scorrimento verticale. |
|
Riempie l'area di visualizzazione all'area scorrente. |
|
Ottiene la posizione corrente di scorrimento in unità. |
|
Ottiene la modalità di mapping corrente, la dimensione totale e la linea e le dimensioni della pagina nella visualizzazione scorrevole.Le dimensioni sono espressi in unità. |
|
Ottiene la posizione corrente di scorrimento in unità logiche. |
|
Ottiene la dimensione totale di visualizzazione a scorrimento in unità logiche. |
|
Determina la dimensione della visualizzazione a dettare la dimensione del frame. |
|
Scorre la visualizzazione in un determinato punto, specificato in unità logiche. |
|
Inserisce la visualizzazione a scorrimento in modalità di scala da inserire. |
|
Imposta la modalità di mapping di visualizzazione a scorrimento, dimensione totale e lo scorrimento verticale e orizzontale ammonta. |
Note
È possibile gestire lo scorrimento standard manualmente in qualsiasi classe derivata da CView eseguendo l'override delle funzioni membro messaggio- si esegue il mapping OnVScroll e OnHScroll.Ma CScrollView aggiunte le funzionalità seguenti alle funzionalità CView :
Gestisce la finestra e dimensioni e modalità di mapping del riquadro di visualizzazione.
Scorre automaticamente in risposta ai messaggi della barra di scorrimento.
Scorre automaticamente in risposta ai messaggi della tastiera, un mouse non di scorrimento, o dalla rotellina di IntelliMouse.
Per scorrere automaticamente in risposta ai messaggi della tastiera, aggiungere un messaggio WM_KEYDOWN e di test per VK_DOWN, VK_PREV e la chiamata SetScrollPos.
È possibile gestire lo scorrimento della rotellina del mouse manualmente eseguendo l'override delle funzioni membro messaggio- si esegue il mapping OnRegisteredMouseWheel e OnMouseWheel.Quando vengono per CScrollView, queste funzioni membro supportano il comportamento consigliato per WM_MOUSEWHEEL, il messaggio di rotazione della rotellina.
Per sfruttare lo scorrimento automatico, derivare la classe di visualizzazione da CScrollView anziché da CView.Quando la visualizzazione viene creata, per calcolare la dimensione della visualizzazione di scorrimento in base alla dimensione del documento, chiamare la funzione membro SetScrollSizes dagli override CView::OnInitialUpdate o CView::OnUpdate.È necessario scrivere codice personalizzato per eseguire una query sulla dimensione del documento.Per un esempio, vedere scribacchi l'esempio).
La chiamata alla funzione membro SetScrollSizes imposta la modalità di mapping di visualizzazione, le dimensioni totali di visualizzazione a scorrimento e gli importi scorrono orizzontalmente e verticalmente.Tutte le dimensioni sono espressi in unità logiche.La dimensione logica della visualizzazione in genere viene calcolata dai dati archiviati nel documento, ma in alcuni casi potrebbe essere necessario specificare una dimensione fissa.Per esempi di entrambi gli approcci, vedere CScrollView::SetScrollSizes.
Specificare gli importi scorrono orizzontalmente e verticalmente in unità logiche.Per impostazione predefinita, se l'utente fa clic sull'asta cilindrica barra di scorrimento all'esterno della casella di scorrimento, CScrollView scorre "una pagina." Se l'utente fa clic sulla freccia di scorrimento sulla fine di una barra di scorrimento, CScrollView scorre "una riga". Per impostazione predefinita, una pagina viene 1/10 della dimensione totale di visualizzazione, una riga è 1/10 le dimensioni della pagina.Eseguire l'override di tali valori predefiniti passando le dimensioni personalizzate nella funzione membro SetScrollSizes.Ad esempio, è possibile impostare la dimensione orizzontale alla frazione della larghezza della dimensione totale e la dimensione verticale all'altezza di una riga nel carattere corrente.
Invece di scorrimento, CScrollView possibile ridimensionare automaticamente la visualizzazione alla dimensione corrente della finestra.In questa modalità, la visualizzazione non ha barre di scorrimento e la visualizzazione logica viene allungata o ridotta esattamente all'area client della finestra.Per utilizzare questa funzionalità di scala da inserire, chiamare CScrollView::SetScaleToFitSize.(Chiamare SetScaleToFitSize o SetScrollSizes, ma non entrambi.)
Prima che la funzione membro OnDraw della classe derivata di visualizzazione venga chiamata, CScrollView regola automaticamente l'origine del riquadro di visualizzazione per l'oggetto di contesto di dispositivo CPaintDC che passa a OnDraw.
Per modificare l'origine del riquadro di visualizzazione per la finestra scorrevole, CScrollView esegue l'override CView::OnPrepareDC.Questa modifica è automatica del contesto di dispositivo CPaintDC che CScrollView passa a OnDraw, ma è necessario chiamare CScrollView::OnPrepareDC a per tutti gli altri contesti di periferica utilizzata, come CClientDC.È possibile eseguire l'override CScrollView::OnPrepareDC per impostare la penna, il colore di sfondo e altri attributi di disegno, ma è possibile chiamare la classe base per eseguire la scala.
Le barre di scorrimento possono essere visualizzati in tre punti a una visualizzazione, come illustrato nei casi seguenti:
Le barre di scorrimento stile finestra standard possono essere impostate per la visualizzazione utilizzando WS_HSCROLL e WS_VSCROLLstili di Windows.
I controlli barra di scorrimento possono essere aggiunti anche al frame contenente la visualizzazione in questo caso, il framework viene attualmente WM_HSCROLL e messaggi WM_VSCROLL la finestra cornice nella visualizzazione correntemente attiva.
Il framework viene inoltra attualmente i messaggi di scorrimento di una barra di divisione CSplitterWnd - il riquadro attivo della barra di divisione (una visualizzazione.Una volta inserito in CSplitterWnd con le barre di scorrimento condivise, un oggetto CScrollView utilizzerà tali condivisi anziché creare il proprio.
Per ulteriori informazioni su l CScrollView, vedere L'architettura documento/visualizzazione e classi di visualizzazione derivate disponibili in MFC.
Gerarchia di ereditarietà
CScrollView
Requisiti
Intestazione: afxwin.h