![]() |
MpuAboutWnd
Liste der Anhänge anzeigen (Anzahl: 3)
Ihr habt eventuell mitbekommen, dass ich heute kräftig an einem About-Dialog gearbeitet habe. Und mit der Hilfe von NicoDE und xarmox ist es mir dann auch gelungen das ganze zu meiner vollsten Zufriedenheit fertig zu stellen.
Ich wollte schon immer einen About-Dialog haben, der hübsch anzusehen und im Quellcode leicht zu handhaben ist. Früher habe ich MessageBoxen benutzt. Aber selbst meine benuterspezifischen MessageBoxen waren mir dann irgendwann mal etwas zu langweilig. Also habe ich mich heute mal hingesetzt und habe mir die Arbeit gemacht und einen About-Dialog geschrieben, der meinen Wünschen entspricht. Es war zwar ein gutes Stück Arbeit und ich musste einige Hindernisse überwinden, aber letztendlich hat sich für mich dann doch die Arbeit gelohnt. Ich will euch natürlich das Ergebnis meines Schaffens nicht vorenthalten und stellen ihn hiermit der Allgmeinheit zur Verfügung. Sourcecode und Screenshot im Anhang.
Delphi-Quellcode:
Was noh fehlt ist ein kleines Tool, was das Byte-Array für das Icon erzeugt und eventuell das ändern des Mauscursors in eine Hnad, wenn man über den Link fährt mit der Maus.
(*
* * How to use: * 1.) Fill out the Fileversion properties: * - FileDescription * - FileVersion * - LegalCopyRight * - Productname * because these properties will be displayed in the dialog. * * 2.) Adjust the value of the constant URI. * 3.) Replace the IconByteArray with the IconByteArray of your icon. * 4.) Call the class procedure ShowAboutWnd: * TAboutWnd.ShowAboutWnd(Handle); * 5.) Enjoy the dialog. ;) * * * Special thanks go to NicoDE and xarmox for their help. * *) {* * If you wonder why... * Why don't use the VCL and formulars or at least a Dialog resource? * I wanted a nice About-Dialog that is easy to handle. I used to use * MessageBoxes and even customized MessageBoxes. But they are boring. * So I decided to roll up my sleeves and write a piece of code that * satisfies my needs: Nice to look at and easy to handle: * Just add the unit and call the dialog. If you use the VCL you always * have the dfm file that holds the formular. If you use dialog resource * you have the resource file and you have to include the resource * file into your source code. Now even the icon is in the sourcecode * you don't have a resource file for the icon. * *} Über Kommentare und Kritik (auch am Code würde ich mich freuen). Nachtrag: Hier noch das versprochene Tool, um ein Icon in ein Delphi Byte Array zu konvertieren. Der Quelltext landet in einer Textdatei. (Mit einem einzigen Icon in einer Icon-Datei hat es funktioniert.) |
Re: MpuAboutWnd
Schick :)
Vielleicht wäre es interessant, die Versionsnummer direkt aus dem Projekt auszulesen. |
Re: MpuAboutWnd
Hi,
isch galube da muss an Stelle von DWORD ein Integer hin:
Delphi-Quellcode:
sonst kommt bei
function LinkStcWndProc(hLinkStc, uMsg, wParam, lParam: DWORD): DWORD; stdcall;
Delphi-Quellcode:
ein Fehler bei Bereichsprüfung.
Result := CallWindowProc(OldStcWndProc, hLinkStc, uMsg, wParam, lParam);
|
Re: MpuAboutWnd
Zitat:
|
Re: MpuAboutWnd
Er möchte, dass dein Dialog die Versionsinformationen die als Resource in dein Programm eingebunden werden können benutzt.
|
Re: MpuAboutWnd
Tut es doch: FileVersion. Ich vermute eher, er meint Versionsinformationen, die er als Kommentar im Datei-Header benutzt.
Neue Version hochgeladen: - Es wurden nicht alle Objekte freigegeben. - Code kommentiert. |
Re: MpuAboutWnd
Klasse !
Funktioniert alles ohne Probleme, auch dein BinToHexArray. Aber warum liest du nicht einfach das Icon der binary aus ? |
Re: MpuAboutWnd
Könnte ich auch machen, aber wenn man im Dialog ein anderes Icon haben will, hat man ein Problem. ;) Ich will zum Beispiel im About-Dialog mein persönliches Icon haben und nicht das von der Anwendung.
Aber dass es so gut funktioniert freut mich. :P |
Re: MpuAboutWnd
Zitat:
Daran habe ich jetzt nicht gedacht. |
Re: MpuAboutWnd
Hallo,
mein Nick lautet "xaromz", nicht "xarmox"! Obwohl der auch gut wäre. Ansonsten: Thumbs up! Gruß xaromz |
Re: MpuAboutWnd
Willkommen in der Steinzeit.
|
Re: MpuAboutWnd
Zitat:
Zitat:
|
Re: MpuAboutWnd
Ich seh' leider immer nur den rechts unteren Teile des Fensters und durchblicke auch den Code nicht. An welcher Stelle definiere ich denn die Platzierung des about-Fensters?
Gruß Calculon -- |
Re: MpuAboutWnd
in der funktion wndproc unter wm_create, die ersten zeilen sind für die plazierung zuständig, sollte aber automatisch in der bildschirm mitte plaziert werden...
wieso denn steinzeit??? ich find das besser als mit vcl, macht mehr spass und progs laufen besser, ist natürlich auch mehr arbeit... p.s. wozu steht vor den function das class??? |
Re: MpuAboutWnd
Zitat:
D.h. du kannst seine About Box ohne Instanz zu erzeugen direkt so aufrufen:
Delphi-Quellcode:
TAboutWnd.ShowAboutWnd(Handle);
|
Re: MpuAboutWnd
aso danke, hatte mich gewundert hab ich vorher noch nie gesehen in solch einer form, zumindest nicht mehr woran ich mich erinnere???
das hätte ich eigentlich schon öfter mal gebrauchen können gut das ich das jetzt weiß p.s. wohn auch in hro ;-) |
Re: MpuAboutWnd
Also, ich find das Teil klasse. Habe aber dennoch einen Fehler gefunden, aber nur wenn man es unter der VCL tested. Beim Mouseover ueber die URL kömmt ein Berichsdingsfehler.
Bis jetzt hab ich den Fehler noch nicht desinfizieren können. |
Re: MpuAboutWnd
Das Fenster wird nicht in der Bildschirmmitte zentriert, sondern über dem aufrufenden Fenster. Eventuell hast du ein ungültiges Handle oder das falsche Handle angegeben.
@turboPascal: Ich hatte es eigentlich unter einem VCL Programm entwickelt. :gruebel: |
Re: MpuAboutWnd
Zitat:
Das einzigste was mir aufgefallen ist, dass die Schrift größer wird, sie sich aber nicht mehr verkleinert. Könnte man das noch ändern ? Zitat:
|
Re: MpuAboutWnd
hm, das muss ich nochmal am nächsten WE genauer ansehen, vill mach ich ja einen Fehler. ;)
|
Re: MpuAboutWnd
Zitat:
Zitat:
|
Re: MpuAboutWnd
Zitat:
:gruebel: Kannst du uns allen auch mal das hier erklären?:
Code:
Mir erschließt sich im Moment nämlich nicht, wieso du bei jedem Mal einen neuen Font erstellst und den alten überschreibst ohne vorher das Handle freizugeben ...
case uMsg of
WM_MOUSELEAVE: if WindowHover then begin // reset state WindowHover := False; // create and set font [color=red]LinkFontHover := CreateFont(-MulDiv(LINKFONTSIZE, GetDeviceCaps(GetDC(hLinkStc), LOGPIXELSY), 72), 0, 0, 0, 400, 0, 0, 0, ANSI_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH, LINKFONTNAME);[/color] if LinkFontHover <> 0 then begin // save handle as a window property [color=red]SetProp(hLinkStc, 'LinkFontHover', LinkFontHover); SendMessage(hLinkStc, WM_SETFONT, Integer(LinkFontHover), Integer(true));[/color] end; end; WM_MOUSEMOVE: if not WindowHover then begin // save state WindowHover := True; // create and set font [color=red]LinkFontNonHover := CreateFont(-MulDiv(LINKFONTSIZE, GetDeviceCaps(GetDC(hLinkStc), LOGPIXELSY), 72), 0, 0, 0, 400, 0, 1, 0, ANSI_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH, LINKFONTNAME);[/color] if LinkFontNonHover <> 0 then begin // save the handle as a window property [color=red]SetProp(hLinkStc, 'LinkFontNonHover', LinkFontNonHover); SendMessage(hLinkStc, WM_SETFONT, Integer(LinkFontNonHover), Integer(true));[/color] end; // track WM_MOUSELEAVE EventTrack.cbSize := SizeOf(EventTrack); EventTrack.dwFlags := TME_LEAVE; EventTrack.hwndTrack := hLinkStc; EventTrack.dwHoverTime := HOVER_DEFAULT; TrackMouseEvent(EventTrack); end; Da wäre noch einiges zu kommentieren, habe ich aber im Moment weder Zeit noch Lust zu ... ewige Dunkelheit macht depressiv. |
Re: MpuAboutWnd
Hm, jetzt, wo du es sagst.
Ess Schokolade, dass macht glücklich. |
Re: MpuAboutWnd
Zitat:
Zitat:
Davon habe ich noch nie etwas gehört. (Hab es halt mit AboutWnd.ShowAboutWnd(Application.Handle);) gemacht. |
Re: MpuAboutWnd
Zitat:
|
Re: MpuAboutWnd
Zitat:
|
Re: MpuAboutWnd
Ja, nur ging ich davon aus, das ich das Handle der Anwenung bekomme nicht von irgend ner Form.
|
Re: MpuAboutWnd
Ich wollte es jetzt so machen:
Delphi-Quellcode:
Aber ich bekomme kein WM_CREATE. :gruebel:
WM_CREATE:
begin // create fonts LinkFontHover := CreateFont(-MulDiv(LINKFONTSIZE, GetDeviceCaps(GetDC(hLinkStc), LOGPIXELSY), 72), 0, 0, 0, 400, 0, 1, 0, ANSI_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH, LINKFONTNAME); // save handle as a window property SetProp(hLinkStc, 'LinkFontHover', LinkFontHover); LinkFontNonHover := CreateFont(-MulDiv(LINKFONTSIZE, GetDeviceCaps(GetDC(hLinkStc), LOGPIXELSY), 72), 0, 0, 0, 400, 0, 0, 0, ANSI_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH, LINKFONTNAME); // save the handle as a window property SetProp(hLinkStc, 'LinkFontNonHover', LinkFontNonHover); end; WM_MOUSELEAVE: begin if WindowHover then begin // reset state WindowHover := False; // set font SendMessage(hLinkStc, WM_SETFONT, GetProp(hLinkStc, 'LinkFontNonHover'), Integer(true)); end; end; WM_MOUSEMOVE: if not WindowHover then begin // save state WindowHover := True; // set font SendMessage(hLinkStc, WM_SETFONT, GetProp(hLinkStc, 'LinkFontHover'), Integer(true)); // track WM_MOUSELEAVE EventTrack.cbSize := SizeOf(EventTrack); EventTrack.dwFlags := TME_LEAVE; EventTrack.hwndTrack := hLinkStc; EventTrack.dwHoverTime := HOVER_DEFAULT; TrackMouseEvent(EventTrack); end; WM_DESTROY: begin // delete objects and remove properties from the window property list DeleteObject(GetProp(hLinkStc, 'LinkFontNonHover')); RemoveProp(hLinkStc, 'LinkFontNonHover'); DeleteObject(GetProp(hLinkStc, 'LinkFontHover')); RemoveProp(hLinkStc, 'LinkFontHover'); end; Ich habe die Font Handles erstmal global gemacht, damit der Fehler zumindest raus ist. |
Re: MpuAboutWnd
Also, das mit dem Anzeigen funktioniert jetzt bei mir. Hatte tatsächlich ein falsches Handle zugewiesen. Ich find's sehr gut. Eines finde ich noch etwas störend:
Wenn ich in der File-Description einen etwas längeren Text einfüge, wird ab einer gewissen Zeilenanzahl der Text überdeckt. :gruebel: Ich werde mal im trial and error Verfahren versuchen, ob ich die Passage im Quelltext finde. Gruß Calculon -- |
Re: MpuAboutWnd
Zitat:
Delphi-Quellcode:
Wenn man jetzt noch die Literale als Konstanten deklariert, hat man sogar die Namen der Properties definitiv nur einmal in der EXE/DLL/wasauchimmer.
case uMsg of
WM_MOUSELEAVE: if WindowHover then begin // reset state WindowHover := False; LinkFontHover := GetProp(hLinkStc, 'LinkFontHover'); if LinkFontHover = 0 then begin // create and set font LinkFontHover := CreateFont(-MulDiv(LINKFONTSIZE, GetDeviceCaps(GetDC(hLinkStc), LOGPIXELSY), 72), 0, 0, 0, 400, 0, 0, 0, ANSI_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH, LINKFONTNAME); // save handle as a window property SetProp(hLinkStc, 'LinkFontHover', LinkFontHover); end; SendMessage(hLinkStc, WM_SETFONT, Integer(LinkFontHover), Integer(true)); end; WM_MOUSEMOVE: if not WindowHover then begin // save state WindowHover := True; LinkFontNonHover := GetProp(hLinkStc, 'LinkFontNonHover'); if LinkFontNonHover = 0 then begin // create and set font LinkFontNonHover := CreateFont(-MulDiv(LINKFONTSIZE, GetDeviceCaps(GetDC(hLinkStc), LOGPIXELSY), 72), 0, 0, 0, 400, 0, 1, 0, ANSI_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH, LINKFONTNAME); // save the handle as a window property SetProp(hLinkStc, 'LinkFontNonHover', LinkFontNonHover); end; SendMessage(hLinkStc, WM_SETFONT, Integer(LinkFontNonHover), Integer(true)); // track WM_MOUSELEAVE EventTrack.cbSize := SizeOf(EventTrack); EventTrack.dwFlags := TME_LEAVE; EventTrack.hwndTrack := hLinkStc; EventTrack.dwHoverTime := HOVER_DEFAULT; TrackMouseEvent(EventTrack); end; |
Re: MpuAboutWnd
Liste der Anhänge anzeigen (Anzahl: 1)
Ich hab' eine Einstellung gefunden, die für 3 zeilenlange File-Descriptions wie ich finde schöne Ergebnisse liefert (siehe Anhang).
Delphi-Quellcode:
const
WINDOWWIDTH = 300; WINDOWHEIGHT = 224; // product name CreateWindowEx(0, 'STATIC', '', WS_CHILD or WS_VISIBLE or SS_CENTER, 17, 10, 285, 24, hWnd, ID_STC_PRODUCTNAME, HInstance, nil); // description, version and copyright CreateWindowEx(0, 'STATIC', '', WS_CHILD or WS_VISIBLE or SS_CENTER, 10, 44, 280, 130, hWnd, ID_STC_DESCRIPTION, HInstance, nil); // "Link" static CreateWindowEx(0, 'STATIC', PCHar(URI), WS_CHILD or WS_VISIBLE or SS_NOTIFY or SS_CENTER, 5, 135, 285, 15, hWnd, ID_STC_WEB, HInstance, nil); // devider CreateWindowEx(0, 'STATIC', '', WS_CHILD or WS_VISIBLE or SS_SUNKEN, 0, 128, 300, 8, hWnd, 0, HInstance, nil); // OK button CreateWindowEx(0, 'BUTTON', 'OK', WS_CHILD or WS_VISIBLE or BS_DEFPUSHBUTTON, 210, 155, 75, 24, hWnd, ID_BTN_OK, HInstance, nil); |
Re: MpuAboutWnd
Zitat:
@calculon: Du hast einfach nur die Fenster größer gemacht? Dabei sind dir aber ein paar Fenster durcheinander geraten. ;) |
Re: MpuAboutWnd
Zitat:
Also danke für die Unit. Die werde ich mit Sicherheit mal brauchen! Gruß Calculon -- |
Re: MpuAboutWnd
Liste der Anhänge anzeigen (Anzahl: 1)
So, endlich den Fehler gefunden der bei deinem MpuAboutWnd den Rangecheck Error verursacht:
Code:
So sollte es sein damit auch die LinkStcWndProc mit der CallWindowProc übereinstimmt:
function LinkStcWndProc(hLinkStc, uMsg, wParam, lParam: [color=#ff0000]DWORD[/color]): [color=#ff0000]DWORD[/color]; stdcall;
Delphi-Quellcode:
und dann noch:
function LinkStcWndProc(hLinkStc, uMsg: DWORD; wParam, lParam: integer): LRESULT; stdcall;
Code:
Integer ist kein Word.
WM_CTLCOLORSTATIC:
begin // set textcolor of "Link" tatic if lParam = Integer(GetDlgItem(hWnd, ID_STC_WEB)) then begin [color=#ff0000]SetTextColor(wParam, RGB(0, 0, 255)); SetBkColor(wParam, GetSysColor(COLOR_BTNFACE));[/color] Brush := GetSysColorBrush(COLOR_BTNFACE); // save brush as a window property SetProp(hWnd, PROP_BRUSH, Brush); // return brush Result := Brush; end //... Sollte so aussehen:
Delphi-Quellcode:
Dazu habe ich dann für den Link noch ein passenden Cursor eingebaut ohne viel Tamtam im Quelltext.
WM_CTLCOLORSTATIC:
begin // set textcolor of "Link" tatic if lParam = Integer(GetDlgItem(hWnd, ID_STC_WEB)) then begin SetTextColor(DWORD(wParam), RGB(0, 0, 255)); SetBkColor(DWORD(wParam), GetSysColor(COLOR_BTNFACE)); Brush := GetSysColorBrush(COLOR_BTNFACE); // save brush as a window property SetProp(hWnd, PROP_BRUSH, Brush); // return brush Result := Brush; end //...
Delphi-Quellcode:
// "Link" static
hstcWeb := CreateWindowEx(0, 'STATIC', PCHar(URL), WS_CHILD or WS_VISIBLE or SS_NOTIFY or SS_CENTER, 5, 97, WINDOWWIDTH - 15, 18, hWnd, ID_STC_WEB, HInstance, nil); SetClassLong(hstcWeb, GCL_HCURSOR, LoadCursor(0, IDC_HAND)); Dann habe ich mir erlaubt das Iconarray zu entfernen im es durch ein Res.-Icon zu ersetzen. Ein Aufruf sieht dann zB. so aus.:
Delphi-Quellcode:
Überlauf und Bereichsprüfung sind bei meinem Delphi immer an! :stupid:
procedure IrgendWieIrgendWoIrgendWann;
begin MpuAboutWnd.URL := 'http://www.michael-puff.de'; MpuAboutWnd.ICON_ID := 1; TAboutWnd.ShowAboutWnd(hDlg); end; Done. :mrgreen: |
Re: MpuAboutWnd
Hallo,
danke für deine Mühe, ich werde meinen Code entsprechend korrigieren. Zitat:
|
Re: MpuAboutWnd
kann ich es auch irgendwie verwirklichen, den link der hompage in das edit zu verfrachten???
|
Re: MpuAboutWnd
In welches Edit? Ersetz den Klassennamen "STATIC" durch "EDIT" und du hast ein Edit-Kontrol.
|
Re: MpuAboutWnd
ach sorry hatte ganz vergessen das hab ich ja eingefügt das war ja gar kein standart ;-) na ich hab noch nen edit eingefügt als richedit 2.0 und in dem steht halt noch sonn kleiner text, in diesem wollte ich dann dierekt den link darstellen!!!
|
Re: MpuAboutWnd
Na das sind aber schon größere Modifikationen, die mit meinem Code eigentlich nichts mehr gemeinsam haben. Wie man mit Links in RichEdits umgeht, kannst du, glaube ich, in meinen
![]() |
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:47 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz