![]() |
dynamisches popupmenu und ereignis
mit dem code unten fülle ich dynamisch ein popupmenü.
ich habe große probleme damit eine ereignisprozedur zur laufzeit zuzuweisen mit
Code:
weise ich allen items die gleiche prozedure zu.
NewItem.OnClick:=button5click;
die ereignisse müssen auch dynamisch bleiben, kann man dafür auch die ereignisse aus einer textdatei hinzuladen?
Code:
grüße horst
procedure TForm1.Button3Click(Sender: TObject);
var NewItem: TMenuItem; i: integer; f: textfile; zeile,s: string; begin; AssignFile(f, 'c:\text.txt'); {$I-} Reset(f); // Datei aus der gelesen wird {$I+} if ioResult <> 0 then halt; zeile := ''; while not eof(f) do begin readln(f, zeile); NewItem := TMenuItem.Create(Self); NewItem.Caption := (Zeile); //NewItem.OnClick := GenericReopenClick; popmnuTrayIcon.Items.Add(NewItem); end; closeFile(f); end; |
Re: dynamisches popupmenu und ereignis
Moin Horst
wenn GenericReopenClick eine Methode ist, die Du bereits im Programm hast, ist das kein Problem, aber aus einer Datei eine Methode laden geht so nicht. Schau dir doch mal diesen Thread ![]() an, vielleicht hilft Dir das weiter |
Re: dynamisches popupmenu und ereignis
moin christian
hmmm, ich werde nicht so ganz schlau aus dem thread ![]() mir ist es nicht so ganz klar wie ich den sender in der ereignisprozedur abfragen kann... |
Re: dynamisches popupmenu und ereignis
Moin Horst,
was willst Du mit dem Sender machen? Wie sieht Dein bisheriger Ansatz denn aus? |
Re: dynamisches popupmenu und ereignis
in jedes item des PopupMenus, sollen bestimmte größen (fenstergrössen)
das menü sieht so aus: 800x600 1024x786 usw... die fenstergrössen können halt manuel eingegeben werden. klicke ich nun auf 800x600 verkleinert/vergrößert sich das entsprechende (angeklickte) fenster... dazu verwende ich das:
Delphi-Quellcode:
unit Unit1;
interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, Menus, ExtCtrls, ComCtrls, StdCtrls; type TForm1 = class(TForm) Button1: TButton; Edit1: TEdit; Edit3: TEdit; Edit2: TEdit; procedure Button1Click(Sender: TObject); procedure ShowHwndAndClassName(CrPos: TPoint); procedure FormClose(Sender: TObject; var Action: TCloseAction); private { Private-Deklarationen } public { Public-Deklarationen } end; var hwnd: THandle; Form1: TForm1; JHook: THandle; Track: Boolean; hWndx: THandle; implementation {$R *.dfm} procedure Tform1.ShowHwndAndClassName(CrPos: TPoint); var Text: array[0..255] of char; begin hWndx := WindowFromPoint(CrPos); SendMessage(GetActiveWindow(), WM_GETTEXT, SizeOf(Text), integer(@Text)); Edit1.text := Text; end; function JournalProc(Code, wParam: Integer; var EventStrut: TEVENTMSG): Integer; stdcall; var Char1: PChar; rPos: TPoint; C: array[0..127] of Char; S: string; begin {this is the JournalRecordProc} Result := CallNextHookEx(JHook, Code, wParam, Longint(@EventStrut)); {the CallNextHookEX is not really needed for journal hook since it it not really in a hook chain, but it's standard for a Hook} if Code < 0 then Exit; {you should cancel operation if you get HC_SYSMODALON} if Code = HC_SYSMODALON then Exit; if Code = HC_ACTION then begin {the EventStrut record has the Information about the mouse or keyboard event. You said you just wanted the mouse button events so I get the mouse down and mouse up event messages} if EventStrut.message = WM_LBUTTONUP then begin if boolean(GetCursorPos(rPos)) then begin Form1.ShowHwndAndClassName(rPos); hwnd := FindWindowEx(0, 0, nil, PChar(form1.edit1.text)); //if (hwnd <> 0) then SetWindowPos(hwnd, 0, 0, 0, strtoint(Form1.edit2.text), strtoint(Form1.edit3.text), if (hwnd <> 0) then SetWindowPos(hwnd, 0, 0, 0, strtoint(Form1.edit2.text), strtoint(Form1.edit3.text), SWP_SHOWWINDOW); Track := False; UnhookWindowsHookEx(JHook); JHook := 0; end; end; end; end; procedure TForm1.Button1Click(Sender: TObject); begin if Track then begin ShowMessage('Mouse is already being Journaled, can not restart'); Exit; end; JHook := SetWindowsHookEx(WH_JOURNALRECORD, @JournalProc, hInstance, 0); {SetWindowsHookEx starts the Hook} if JHook > 0 then begin Track := True; end else ShowMessage('No Journal Hook availible'); end; procedure TForm1.FormClose(Sender: TObject; var Action: TCloseAction); begin UnhookWindowsHookEx(JHook); end; end. |
Re: dynamisches popupmenu und ereignis
Moin Horst,
mit Ansatz ging's mir eigentlich darum was in dem OnClick Event des MenuItems steht ;-) Um hier gezielt bestimmte Items unterscheiden zu können, kannst Du deren Eigenschaft Tag nutzen. Diese Eigenschaft ist frei nutzbar, so dass Du hier eine Kennung eintragen kannst. Im OnClick kannst Du dann einfach mit einer case Anweisung die verschiedenen Auflösungen ausführen:
Delphi-Quellcode:
// OnClick der Menu Items
if not (Sender is TMenuItem) then exit; case (Sender as TMenuItem).Tag of 1 : // hier z.B. 800x600 2 : // 1024x768 //... end; |
Re: dynamisches popupmenu und ereignis
achso...nun verstehe ich das endlich.
:coder: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:40 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