![]() |
AW: proceduren (Events) aus Interface
Dann macht auch die VCL-Methodensignatur für deine Methoden keinen Sinn. Das müsstest du dann ja erst zusammenbauen wie es sonst die VCL tut.
Du könntest die Parameter selbst auslesen und in geeigneter Form aufbereiten. Sprich die Parameter selbst neu definieren. |
AW: proceduren (Events) aus Interface
Zitat:
Wenn ich dann ein Event bekomme ist es gut ansonsten .. na mal sehn.
Delphi-Quellcode:
Ich hab jetzt ne Classe erstellt dort kann ich dann die Messagen wie unter VCL einbinden.
{$REGION 'TMainApp'}
type TMainApp = class(TComponent) private { Private declarations } FHandle: HWND; lRes: integer; Background: PWideChar; sFileName: string; gBlinkCount: integer; UseState: integer; gColor: array [1 .. 33] of integer; gPeak: array [1 .. 100, 1 .. 2] of integer; // Vis xPos: integer; stepX: integer; C0, CB1, CB2, CB3, CG1, CG2, CG3: integer; nTick: integer; OkL, OkR: integer; FPScount, nFPScount: Cardinal; ShowMode: integer; hPlgRadioButton: integer; hSubSkinMenu: HMenu; Restart: BOOL; h_Instance: HINST; newItem: string; PaintDC: HDC; procedure DeleteResource; function GetHandle: HWND; procedure SetHandle(const Value: HWND); protected // public { Public declarations } procedure SplitRGB(Col: COLORREF; var R: Byte; var G: Byte; var b: Byte); procedure DrawOscillo(WinHandle: HWND; pInteger: TWaveData); procedure PlayListPlay(hList: HWND; nCount: integer); procedure RenderVis(WinHandle: HWND); procedure CheckPluginVisibility(nRedraw: integer); procedure ResizeWindow(WinHandle: HWND; ChangeBackground: integer); procedure ButtonBlink(ID: integer; nStop: boolean); procedure MovePluginButton(Offset: integer); procedure CheckVisiblePanel(hCtrl: HWND); procedure DetectBackground; procedure ColorInit; procedure WMEnterSizeMove(var Msg: TMessage); message WM_ENTERSIZEMOVE; procedure WMSizing(var Msg: TMessage); message WM_SIZING; procedure WMMoving(var Msg: TMessage); message WM_MOVING; procedure WMExitSizeMove(var Msg: TMessage); message WM_EXITSIZEMOVE; procedure WMSysCommand(var Msg: TMessage); message WM_SYSCOMMAND; procedure WMCommand(var Msg: TMessage); message WM_COMMAND; function SetRGB(colorRGB: DWORD): integer; function LevelColr(nLevel: integer): integer; function PaintCapture(WinHandle: HWND; DC: Cardinal; Action: TCaptureAction): integer; function SolvePeak(nValue: integer; nTotal: integer): integer; function FileSize(FileName: PWideChar): integer; function ListShuffle(hList: HWND): integer; function ARGBToColorRef(Color: ARGB): COLORREF; function GetMenuTxt(ItemId: integer; var Img: Cardinal; var ImgItem: Cardinal; var ImgSep: Cardinal; var SideBarImg: Cardinal): WideString; property Handle: HWND read GetHandle write SetHandle; end; {$ENDREGION} Nun gut bisher haben sie nicht gefeuert.. LOL Wenn es dann geht muss ich mal sehn wie ich das mit dem Interface auf die reihe kriege. So übergebe ich dann die Messagen, wie gesagt wenn es funktioniert
Delphi-Quellcode:
Nochmal Danke für deine Informationen.
{$REGION 'procedure WMEnterSizeMove'}
procedure TMainApp.WMEnterSizeMove(var Msg: TMessage); begin inherited; if Assigned(MagneticWndProc) then MagneticWndProc(Self.Handle, WM_ENTERSIZEMOVE, Msg, dummyHandled); end; gruss |
AW: proceduren (Events) aus Interface
Zitat:
|
AW: proceduren (Events) aus Interface
Zitat:
Ich kann nicht aus meiner Winproc bei WM_EnterSizeMove die Message übergeben das geht schief.. in so etwa Beispiel:
Delphi-Quellcode:
Von was musste ich denn meine Classe ableiten damit WMEnterSizeMove automatisch abfeuert?
var
Message_: TMessage; --------------- WM_EnterSizeMove: begin Message_.WParam := wP; Message_.LParam := lP; Message_.Result := 0; MainApp.WMEnterSizeMove(Message_); Result := DefWindowProc(WinHandle, Msg, wP, lP); exit; end; Ich habe eigentlich gedacht das TMainApp = class(TComponent) ausreicht. gruss |
AW: proceduren (Events) aus Interface
Ich habe mal auf die schnelle das Sample von Luckie angepasst das die TMagnetic Unit verwendet.
Das erste Sample ist Original im Window Folder Das zweite mit TMagnetic. Die Unit selbst funktioniert einwandfrei mit VCL aber nicht mit NonVcl. Das Hauptfenster wird blockiert nach dem öffnen des zweiten Window das erste lässt sich dann nicht mehr schließen. EDIT: Ok jetzt geht soweit alles wenn ich die TMagnetic normal einbinde ohne Interface. Damit werde ich mich jetzt beschäftigen. gruss |
AW: proceduren (Events) aus Interface
Liste der Anhänge anzeigen (Anzahl: 1)
Habe mir mal Deine Sourcen angeschaut.
Für das was Du erreichen willst benötigts Du kein Interface. Dazu reicht eine function. Habe das spasseshalber mal geändert, so das es funktioniert. Schau es Dir mal an. |
AW: proceduren (Events) aus Interface
Zitat:
Das Problem das es beim mir nicht Funktioniert ist gerade der umbau zum Interface. Hast du mal versucht wenn du nun mit der TMagnetic bsp.. 10 VCL Formen startest die alle gegenseitig an die Parentform andocken und sich damit verschieben lassen.. das ganze noch funktioniert? Danke für das reinschauen.. ;) gruss |
AW: proceduren (Events) aus Interface
Mein Problem ist halt nur das du die TMAgnetic Formatiert hast..
Dadurch kann ich sie nicht vergleichen und die geänderten Funktionen identifizieren. Was nicht geht das du die TMagnetic in der TMagnetic selbst erstellst. Auch die setter und getter sollten von außen gesetzt werden.
Delphi-Quellcode:
Der Anwender soll festlegen ab welcher weite das Window andockt.
if MagneticWnd = nil then
begin MagneticWnd := TMagnetic.Create; MagneticWnd.SnapWidth := 15; end; result := MagneticWnd.AddWindow(Handle, hWndParent) Hingegen der Ansatz die TSubClass_Proc umzuleiten sieht sehr gut aus. :thumb: Werde damit mal etwas experimentieren. Danke! EDIT: Bin das jetzt nochmal durchgegangen habe die angesprochenen dinge zurück gesetzt. Funktioniert ohne Interface recht gut. (Das ist aber mein Problem was ich noch ändern muss DLL bedingt). ;) Zitat:
EDIT2: Interface implementiert und funktioniert jetzt alles. Jetzt kann ich mein Spectragram Window mit ziehen und muss da nicht immer von Hand nachhelfen. Danke für eure Hilfe. gruss |
AW: proceduren (Events) aus Interface
Zitat:
|
AW: proceduren (Events) aus Interface
etwas OT: (werden die meisten eh wissen, aber vielleicht nicht jeder)
Word hat auch eine sehr gute Vergleichsfunktion (mit optional Leerzeichen und Leerzeilen ignorieren usw.). Also wenn man Quelltexte nicht einheitlich formatieren kann und Word verfügbar hat ist das durchaus nutzbar. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:07 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