Süsteemi salve Delphi rakendus

Heitke pilk oma tegumiribale. Vaadake piirkonda, kus kellaaeg asub? Kas seal on muid ikoone? Selle koha nimi on Windowsi süsteemisalv. Kas soovite oma Delphi rakenduse ikoon seal? Kas soovite, et see ikoon oleks animeeritud või kajastaks teie rakenduse olekut?

See oleks kasulik nende programmide jaoks, mis jäetakse pikaks ajaks tööle ilma kasutaja sekkumiseta (taustaülesanded, mida tavaliselt kasutate arvutis kogu päeva).

Mida saate teha, on see, et teie Delphi-rakendused näeksid välja nii, nagu nad minimeeriksid salve (mitte asemel) Tegumiriba paremale nupule Win Start), asetades salve ikooni ja tehes samal ajal oma vormi (d) nähtamatu.

Jälgime seda

Õnneks on süsteemisalves töötava rakenduse loomine üsna lihtne - ülesande täitmiseks on vaja ainult ühte (API) funktsiooni, Shell_NotifyIcon.

Funktsioon on määratletud jaotises ShellAPI üksus ja nõuab kahte parameetrit. Esimene on lipp, mis näitab, kas ikooni lisatakse, muudetakse või eemaldatakse, ja teine ​​on osutus TNotifyIconData struktuurile, mis sisaldab ikooni puudutavat teavet. See hõlmab kuvatava ikooni käepidet, teksti näpunäidet, kui hiir on ikooni kohal, akna käepide, mis võtab vastu ikooni teateid, ja teate tüüp, mille ikoon sellele saadab aken.

instagram viewer

Esiteks pange oma põhivormi jaotisse Privaatne rida reale:
TrayIconData: TNotifyIconData;

tüüp
TMainForm = klass(TForm)
protseduur FormCreate (saatja: TObject);
privaatne
TrayIconData: TNotifyIconData;
{Eradeklaratsioonid}avalik{Avalikud deklaratsioonid}lõpp;

Siis oma põhivormis OnCreate lähtestage TrayIconData andmestruktuur ja helistage Shell_NotifyIcon funktsioonile:

koos TrayIconData dobegin
cbSize: = SizeOf (TrayIconData);
Wnd: = Käepide;
uID: = 0;
uFlags: = NIF_MESSAGE + NIF_ICON + NIF_TIP;
uCallbackMessage: = WM_ICONTRAY;
hIcon: = rakendus. Ikoon. Käepide;
StrPCopy (szTip, rakendus. Pealkiri);
lõpp;
Shell_NotifyIcon (NIM_ADD, @TrayIconData);

TrayIconData struktuuri parameeter Wnd osutab aknale, mis võtab vastu ikooniga seotud teateteateid.

Spikker osutab ikoonile, mille tahame salve lisada - sel juhul kasutatakse rakenduste peaikooni.
SzTip hoiab ikooni kuvamiseks tööriistavihje teksti - meie puhul rakenduse pealkirja. SzTip mahutab kuni 64 tähemärki.
Parameeter uFlags on seadistatud nii, et ikoon käsib rakendussõnumeid töödelda, kasutada rakenduse ikooni ja selle otsa. uCallbackMessage osutab rakenduse määratletud sõnumi identifikaatorile. Süsteem kasutab määratud identifikaatorit teatesõnumite jaoks, mille ta saadab Wndi poolt tuvastatud aknasse, kui ikooni piirduvas ristkülikus toimub hiire sündmus. See parameeter on seatud vormi WM_ICONTRAY konstandile, mis on määratletud vormiühiku liideseosas, ja võrdub: WM_USER + 1;

Lisate ikooni salve, kutsudes Shell_NotifyIcon API funktsiooni. Esimene parameeter "NIM_ADD" lisab salve alale ikooni. Ülejäänud kahte võimalikku väärtust, NIM_DELETE ja NIM_MODIFY, kasutatakse salve ikooni kustutamiseks või muutmiseks - näeme hiljem selles artiklis. Teine parameeter, mille saadame Shell_NotifyIconile, on TrayIconData initsialiseeritud struktuur.

Võtke üks

Kui käivitate projekti nüüd, näete salve kella lähedal ikooni. Pange tähele kolme asja.

1) Esiteks ei juhtu midagi, kui klõpsate salve asetatud ikoonil (või teete hiirega midagi muud) - me pole veel protseduuri (sõnumikäitleja) loonud.
2) teiseks on tegumiribal nupp (me ilmselgelt ei taha seda sinna).
3) Kolmandaks, rakenduse sulgedes jääb ikoon salve.

Võtke kaks

Lahendame selle tagurpidi. Ikooni eemaldamiseks salvest rakendusest väljumisel peate uuesti helistama Shell_NotifyIconile, kuid esimese parameetrina peaks olema NIM_DELETE. Teete seda veebisaidil OnDestroy sündmuste käitleja põhivormi jaoks.

protseduur TMainForm. FormDestroy (saatja: TObject);
alustada
Shell_NotifyIcon (NIM_DELETE, @TrayIconData);
lõpp;

Rakenduse (rakenduse nupu) peitmiseks tegumiriba eest kasutame lihtsat trikki. Lisage projektide lähtekoodi järgmine rida: Rakendus. ShowMainForm: = Vale; enne taotlust. CreateForm (TMainForm, MainForm); E.g las see näeb välja selline:

...
alustada
Rakendus. Alusta;
Rakendus. ShowMainForm: = Vale;
Rakendus. CreateForm (TMainForm, MainForm);
Rakendus. Jooksma;
lõpp.

Ja lõpuks, et meie salveikoon reageeriks hiire sündmustele, peame looma sõnumite käitlemise protseduuri. Esiteks kuulutame vormideklaratsiooni avalikus osas teadete töötlemise protseduuri: protseduur TrayMessage (var Msg: TMessage); teade WM_ICONTRAY; Teiseks näeb selle protseduuri määratlus välja järgmine:

protseduur TMainForm. TrayMessage (var Msg: TMessage);
algustäht Msg.lParam of
WM_LBUTTONDOWN:
alustada
ShowMessage (vasakklõps vasakul nupul
- NÄIDAKE VORMI! ');
MainForm. Näita;
lõpp;
WM_RBUTTONDOWN:
alustada
ShowMessage ('Klõps paremale nupule
- varjakem vormi! ");
MainForm. Peida;
lõpp;
lõpp;
lõpp;

Selle protseduuri eesmärk on käsitleda ainult meie sõnumit WM_ICONTRAY. LParami väärtus võetakse sõnumi struktuurilt, mis annab protseduuri aktiveerimisel meile hiire oleku. Lihtsuse huvides käsitleme ainult vasakut hiirt alla (WM_LBUTTONDOWN) ja paremat hiirt alla (WM_RBUTTONDOWN). Kui hiire vasak nupp on ikooni all, kuvame põhivormi, siis kui paremat nuppu vajutatakse, peidame selle. Muidugi on ka muid hiire sisestussõnumeid, millega saate protseduuris hakkama saada, nt nupp üles, nupu topeltklõps jne.

See selleks. Kiire ja lihtne. Järgmisena näete, kuidas salve ikooni animeerida ja kuidas see ikoon kajastaks teie rakenduse olekut. Veelgi enam näete, kuidas kuvada ikooni lähedal hüpikmenüüd.