CMFCDesktopAlertWnd – třída
Třída CMFCDesktopAlertWnd
implementuje funkce bezmodální dialogové okno, které se zobrazí na obrazovce, aby informoval uživatele o události.
Další podrobnosti najdete ve zdrojovém kódu ve složce VC\atlmfc\src\mfc instalace sady Visual Studio.
Syntaxe
class CMFCDesktopAlertWnd : public CWnd
Členové
Veřejné metody
Název | Popis |
---|---|
CMFCDesktopAlertWnd::Create | Vytvoří a inicializuje okno upozornění na ploše. |
CMFCDesktopAlertWnd::GetAnimationSpeed | Vrátí rychlost animace. |
CMFCDesktopAlertWnd::GetAnimationType | Vrátí typ animace. |
CMFCDesktopAlertWnd::GetAutoCloseTime | Vrátí časový limit automatického uzavření. |
CMFCDesktopAlertWnd::GetCaptionHeight | Vrátí výšku titulku. |
CMFCDesktopAlertWnd::GetDialogSize | |
CMFCDesktopAlertWnd::GetLastPos | Vrátí poslední platnou pozici okna upozornění na ploše na obrazovce. |
CMFCDesktopAlertWnd::GetTransparency | Vrátí úroveň průhlednosti. |
CMFCDesktopAlertWnd::HasSmallCaption | Určuje, jestli se okno upozornění na ploše zobrazí s malým titulkem. |
CMFCDesktopAlertWnd::OnBeforeShow | |
CMFCDesktopAlertWnd::OnClickLinkButton | Volá se rozhraním, když uživatel klikne na tlačítko odkazu umístěné v nabídce upozornění na ploše. |
CMFCDesktopAlertWnd::OnCommand | Architektura volá tuto členovou funkci, když uživatel vybere položku z nabídky, když podřízený ovládací prvek odešle zprávu s oznámením nebo při přeložení klávesové zkratky. (Přepsání CWnd::OnCommand.) |
CMFCDesktopAlertWnd::OnDraw | |
CMFCDesktopAlertWnd::P rocessCommand | |
CMFCDesktopAlertWnd::SetAnimationSpeed | Nastaví novou rychlost animace. |
CMFCDesktopAlertWnd::SetAnimationType | Nastaví typ animace. |
CMFCDesktopAlertWnd::SetAutoCloseTime | Nastaví časový limit automatického uzavření. |
CMFCDesktopAlertWnd::SetSmallCaption | Přepíná mezi malými a normálními titulky. |
CMFCDesktopAlertWnd::SetTransparency | Nastaví úroveň průhlednosti. |
Poznámky
Okno upozornění na ploše může být průhledné, může se zobrazit s animačními efekty a může zmizet (po zadaném zpoždění nebo když ho uživatel zavře kliknutím na tlačítko Zavřít).
Okno upozornění na ploše může obsahovat také výchozí dialogové okno, které zase obsahuje ikonu, text zprávy (popisek) a odkaz. Případně okno upozornění na ploše může obsahovat vlastní dialogové okno z prostředků aplikace.
Okno upozornění na ploše vytvoříte ve dvou krocích. Nejprve zavolejte konstruktor pro sestavení objektu CMFCDesktopAlertWnd
. Za druhé, volání CMFCDesktopAlertWnd::Create člen funkce vytvořit okno a připojit ho k objektu CMFCDesktopAlertWnd
.
Objekt CMFCDesktopAlertWnd
vytvoří speciální podřízené dialogové okno, které vyplní klientskou oblast okna upozornění na ploše. Dialogové okno vlastní všechny ovládací prvky, které jsou na něm umístěné.
Pokud chcete zobrazit vlastní dialogové okno v místním okně, postupujte takto:
Odvození třídy z
CMFCDesktopAlertDialog
.V prostředcích vytvořte podřízenou šablonu dialogového okna.
Volání CMFCDesktopAlertWnd::Create pomocí ID prostředku šablony dialogového okna a ukazatele na informace třídy modulu runtime odvozené třídy.
Naprogramujte vlastní dialogové okno pro zpracování všech oznámení pocházejících z hostovaných ovládacích prvků nebo naprogramujte hostované ovládací prvky pro zpracování těchto oznámení přímo.
Pomocí následujících funkcí můžete řídit chování okna upozornění na ploše:
Nastavte typ animace voláním CMFCDesktopAlertWnd::SetAnimationType. Mezi platné možnosti patří rozbalte, snímek a prolnutí.
Nastavte rychlost animačního rámce voláním CMFCDesktopAlertWnd::SetAnimationSpeed.
Nastavte úroveň průhlednosti voláním CMFCDesktopAlertWnd::SetTransparency.
Změňte velikost titulku na malý voláním CMFCDesktopAlertWnd::SetSmallCaption. Malý titulek je vysoký 7 pixelů.
Příklad
Následující příklad ukazuje, jak použít různé metody ve CMFCDesktopAlertWnd
třídě ke konfiguraci objektu CMFCDesktopAlertWnd
. Příklad ukazuje, jak nastavit typ animace, nastavit průhlednost automaticky otevíraného okna, určit, že okno upozornění zobrazí malý titulek, a nastavit čas, který uplynou před automatickým zavřeným oknem upozornění. Příklad také ukazuje, jak vytvořit a inicializovat okno upozornění na ploše. Tento fragment kódu je součástí ukázky ukázky upozornění na ploše.
CMFCDesktopAlertWnd *pPopup = new CMFCDesktopAlertWnd;
// int m_nAnimation
pPopup->SetAnimationType((CMFCPopupMenu::ANIMATION_TYPE)m_nAnimation);
// int m_nAnimationSpeed
pPopup->SetAnimationSpeed(m_nAnimationSpeed);
// int m_nTransparency
pPopup->SetTransparency((BYTE)m_nTransparency);
// BOOL m_bSmallCaption
pPopup->SetSmallCaption(m_bSmallCaption);
// BOOL m_bAutoClose, int m_nAutoCloseTime
pPopup->SetAutoCloseTime(m_bAutoClose ? m_nAutoCloseTime * 1000 : 0);
// int m_nPopupSource
if (m_nPopupSource == 0)
{
// int m_nVisualMngr
// CPoint m_ptPopup
// The this pointer points to a CDesktopAlertDemoDlg class which extends the CDialogEx class.
if (m_nVisualMngr == 5) // MSN-style
{
pPopup->Create(this, IDD_DIALOG2, NULL,
m_ptPopup, RUNTIME_CLASS(CMSNDlg));
}
else
{
pPopup->Create(this, IDD_DIALOG1,
m_menuPopup.GetSubMenu(0)->GetSafeHmenu(),
m_ptPopup, RUNTIME_CLASS(CMyPopupDlg));
}
}
Hierarchie dědičnosti
Požadavky
Hlavička: afxDesktopAlertWnd.h
CMFCDesktopAlertWnd::Create
Vytvoří a inicializuje okno upozornění na ploše.
virtual BOOL Create(
CWnd* pWndOwner,
UINT uiDlgResID,
HMENU hMenu = NULL,
CPoint ptPos = CPoint(-1,-1),
CRuntimeClass* pRTIDlgBar = RUNTIME_CLASS(CMFCDesktopAlertDialog));
virtual BOOL Create(
CWnd* pWndOwner,
CMFCDesktopAlertWndInfo& params,
HMENU hMenu = NULL,
CPoint ptPos = CPoint(-1,-1));
Parametry
pWndOwner
[in, out] Určuje vlastníka okna upozornění. Tento vlastník pak obdrží všechna oznámení pro okno upozornění na ploše. Tato hodnota nemůže být NULL.
uiDlgResID
[v] Určuje ID prostředku okna upozornění.
hMenu
[v] Určuje nabídku, která se zobrazí, když uživatel klikne na tlačítko nabídky. Pokud je hodnota NULL, tlačítko nabídky se nezobrazí.
ptPos
[v] Určuje počáteční pozici, kde se zobrazí okno výstrahy pomocí souřadnic obrazovky. Pokud je tento parametr (-1, -1), zobrazí se okno upozornění v pravém dolním rohu obrazovky.
pRTIDlgBar
[v] Informace o třídě modulu runtime pro vlastní třídu dialogového okna, která pokrývá oblast klienta okna výstrahy.
params
[v] Určuje parametry, které se používají k vytvoření okna upozornění.
Návratová hodnota
TRUE, pokud se okno upozornění úspěšně vytvořilo; jinak NEPRAVDA.
Poznámky
Voláním této metody vytvořte okno upozornění. Klientská oblast okna výstrahy obsahuje podřízené dialogové okno, které je hostitelem všech ovládacích prvků zobrazených uživateli.
První přetížení metody vytvoří okno výstrahy, které obsahuje podřízené dialogové okno načtené z prostředků aplikace. První přetížení metody může také zadat informace o třídě modulu runtime pro vlastní třídu dialogového okna.
Druhé přetížení metody vytvoří okno upozornění, které obsahuje výchozí ovládací prvky. Můžete určit, které ovládací prvky se mají zobrazit úpravou CMFCDesktopAlertWndInfo Třída.
CMFCDesktopAlertWnd::GetAnimationSpeed
Vrátí rychlost animace.
UINT GetAnimationSpeed() const;
Návratová hodnota
Rychlost animace okna upozornění v milisekundách
Poznámky
Rychlost animace popisuje, jak rychle se otevře a zavře okno upozornění.
CMFCDesktopAlertWnd::GetAnimationType
Vrátí typ animace.
CMFCPopupMenu::ANIMATION_TYPE GetAnimationType();
Návratová hodnota
Jeden z následujících typů animací:
NO_ANIMATION
ROZVINOUT
KLOUZAT
VADNOUT
SYSTEM_DEFAULT_ANIMATION
CMFCDesktopAlertWnd::GetAutoCloseTime
Vrátí časový limit automatického uzavření.
int GetAutoCloseTime() const;
Návratová hodnota
Čas v milisekundách, po kterém se okno výstrahy automaticky zavře.
Poznámky
Tuto metodu použijte k určení, kolik času by mělo uplynout, než se okno upozornění automaticky zavře.
CMFCDesktopAlertWnd::GetCaptionHeight
Vrátí výšku titulku.
virtual int GetCaptionHeight();
Návratová hodnota
Výška titulku v pixelech.
Poznámky
Tuto metodu lze přepsat v odvozené třídě. Výchozí implementace buď: vrátí hodnotu malé výšky titulku (7 pixelů), pokud by se automaticky otevírané okno mělo zobrazit malý titulek, nebo hodnotu získanou z funkce GetSystemMetrics(SM_CYSMCAPTION)
rozhraní API systému Windows .
CMFCDesktopAlertWnd::GetLastPos
Vrátí poslední pozici okna upozornění na ploše na obrazovce.
CPoint GetLastPos() const;
Návratová hodnota
Bod v souřadnicích obrazovky.
Poznámky
Tato metoda vrátí poslední platnou pozici okna upozornění na obrazovce.
CMFCDesktopAlertWnd::GetTransparency
Vrátí úroveň průhlednosti.
BYTE GetTransparency() const;
Návratová hodnota
Úroveň transparentnosti mezi 0 a 255, včetně. Čím větší je hodnota, tím více neprůsadnější okno.
Poznámky
Tuto metodu použijte k načtení aktuální úrovně průhlednosti okna upozornění.
CMFCDesktopAlertWnd::HasSmallCaption
Určuje, jestli má okno upozornění na ploše malý titulek nebo titulek s normální velikostí.
BOOL HasSmallCaption() const;
Návratová hodnota
TRUE, pokud se automaticky otevírané okno zobrazí s malým titulkem; NEPRAVDA, pokud se automaticky otevírané okno zobrazí s titulkem v normální velikosti.
Poznámky
Tuto metodu použijte k určení, jestli má automaticky otevírané okno malý titulek nebo titulek s normální velikostí. Ve výchozím nastavení má malý titulek výšku 7 pixelů. Výšku titulku s normální velikostí můžete získat voláním funkce GetSystemMetrics(SM_CYCAPTION)
rozhraní API systému Windows .
CMFCDesktopAlertWnd::OnBeforeShow
virtual BOOL OnBeforeShow(CPoint&);
Parametry
[v] CPoint &.
Návratová hodnota
Poznámky
CMFCDesktopAlertWnd::OnClickLinkButton
Volá se rozhraním, když uživatel klikne na tlačítko odkazu umístěné v nabídce upozornění na ploše.
virtual BOOL OnClickLinkButton(UINT uiCmdID);
Parametry
uiCmdID
[v] Tento parametr se nepoužívá.
Návratová hodnota
Vždy NEPRAVDA.
Poznámky
Tuto metodu přepište v odvozené třídě, pokud chcete být upozorněni, když uživatel klikne na odkaz v okně upozornění.
CMFCDesktopAlertWnd::OnCommand
virtual BOOL OnCommand(
WPARAM wParam,
LPARAM lParam);
Parametry
[v] wParam
[v] lParam
Návratová hodnota
Poznámky
CMFCDesktopAlertWnd::OnDraw
virtual void OnDraw(CDC* pDC);
Parametry
[v] pDC
Poznámky
CMFCDesktopAlertWnd::P rocessCommand
BOOL ProcessCommand(HWND hwnd);
Parametry
[v] hwnd
Návratová hodnota
Poznámky
CMFCDesktopAlertWnd::SetAnimationSpeed
Nastaví novou rychlost animace.
void SetAnimationSpeed(UINT nSpeed);
Parametry
nSpeed
[v] Určuje novou rychlost animace v milisekundách.
Poznámky
Voláním této metody nastavíte rychlost animace pro okno upozornění. Výchozí rychlost animace je 30 milisekund.
CMFCDesktopAlertWnd::SetAnimationType
Nastaví typ animace.
void SetAnimationType(CMFCPopupMenu::ANIMATION_TYPE type);
Parametry
type
[v] Určuje typ animace.
Poznámky
Voláním této metody nastavíte typ animace. Můžete určit jednu z následujících hodnot:
NO_ANIMATION
ROZVINOUT
KLOUZAT
VADNOUT
SYSTEM_DEFAULT_ANIMATION
CMFCDesktopAlertWnd::SetAutoCloseTime
Nastaví časový limit automatického uzavření.
void SetAutoCloseTime(int nTime);
Parametry
nTime
[v] Čas v milisekundách, který uplyne před tím, než se okno upozornění automaticky zavře.
Poznámky
Okno upozornění se automaticky zavře po zadaném čase, pokud uživatel s oknem nebude pracovat.
CMFCDesktopAlertWnd::SetSmallCaption
Přepíná mezi malými a běžnými titulky.
void SetSmallCaption(BOOL bSmallCaption = TRUE);
Parametry
bSmallCaption
[v] PRAVDA, aby bylo možné určit, že okno výstrahy zobrazí malý titulek; jinak nePRAVDA určuje, že okno výstrahy zobrazuje titulek s normální velikostí.
Poznámky
Voláním této metody zobrazíte malý nebo běžný titulek. Ve výchozím nastavení má malý titulek výšku 7 pixelů. Velikost běžného titulku můžete získat voláním funkce GetSystemMetrics(SM_CYCAPTION)
rozhraní API systému Windows .
CMFCDesktopAlertWnd::SetTransparency
Nastaví úroveň průhlednosti automaticky otevíraného okna.
void SetTransparency(BYTE nTransparency);
Parametry
nTransparency
[v] Určuje úroveň průhlednosti. Tato hodnota musí být v rozmezí od 0 do 255 včetně. Čím větší je hodnota, tím více neprůsadnější okno.
Poznámky
Voláním této funkce nastavíte úroveň průhlednosti automaticky otevíraného okna.
CMFCDesktopAlertWnd::GetDialogSize
virtual CSize GetDialogSize();
Návratová hodnota
Poznámky
Viz také
Graf hierarchie
Třídy
CMFCDesktopAlertWndInfo – třída
CMFCDesktopAlertDialog – třída
CWnd – třída