Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Transparent Edit (https://www.delphipraxis.net/169945-transparent-edit.html)

himitsu 22. Aug 2012 09:50

AW: Transparent Edit
 
Zitat:

Zitat von mkinzler (Beitrag 1179276)
In neueren Delphiversionen schon.

Noch ... wer weiß wann wir UCS4 bekommen. :roll:

Zitat:

Delphi-Quellcode:
GetMem(Text, sizeof(Text) + 1);

Ein bissl wenig Speicher?

Delphi-Quellcode:
TextLength * SizeOf(WideChar)
oder
Delphi-Quellcode:
(TextLength + 1) * SizeOf(WideChar)
, jenachdem ob die #0 in TextLength schon mit enthalten ist :!:

EWeiss 22. Aug 2012 09:59

AW: Transparent Edit
 
Zitat:

Zitat von himitsu (Beitrag 1179294)
Zitat:

Zitat von mkinzler (Beitrag 1179276)
In neueren Delphiversionen schon.

Noch ... wer weiß wann wir UCS4 bekommen. :roll:

Zitat:

Delphi-Quellcode:
GetMem(Text, sizeof(Text) + 1);

Ein bissl wenig Speicher?

Delphi-Quellcode:
TextLength * SizeOf(WideChar)
oder
Delphi-Quellcode:
(TextLength + 1) * SizeOf(WideChar)
, jenachdem ob die #0 in TextLength schon mit enthalten ist :!:

Hmm SizeOf(WideChar). Ich hatte es so von Assarbad interpretiert das er SizeOf(Text) meinte.
Das man aber direkt SizeOf(WideChar) verwenden kann/muss war mir neu.

Wieder was dazu gelernt.
Habe es geändert.

Danke.

gruss

DeddyH 22. Aug 2012 10:06

AW: Transparent Edit
 
Ich persönlich habe mir angewöhnt, alle API-Funktionen, die mit Strings arbeiten, sicherheitshalber im MSDN nachzuschlagen. Teilweise erwarten sie die Textlänge, teilweise hingegen die Größe in Byte. Das spielt bei ANSI ja keine Rolle, bei Unicode hingegen schon, da man dann ggf. mit SizeOf(Char) multiplizieren muss, sofern man die Typen String, PChar und Char benutzt.

EWeiss 22. Aug 2012 10:11

AW: Transparent Edit
 
Zitat:

Zitat von DeddyH (Beitrag 1179303)
Ich persönlich habe mir angewöhnt, alle API-Funktionen, die mit Strings arbeiten, sicherheitshalber im MSDN nachzuschlagen. Teilweise erwarten sie die Textlänge, teilweise hingegen die Größe in Byte. Das spielt bei ANSI ja keine Rolle, bei Unicode hingegen schon, da man dann ggf. mit SizeOf(Char) multiplizieren muss, sofern man die Typen String, PChar und Char benutzt.

Ist eine alternative zum Forum denn alles kann man nicht wissen.
Unicode ist auch nicht so mein Ding auch wenn ich versuche zwangsmäßig bedingt durch D2010 alles dahingehend umzusetzen.
Aber so recht will das auch nicht zumindest nicht was die koreanische Sprache angeht.

gruss

himitsu 22. Aug 2012 10:29

AW: Transparent Edit
 
Zitat:

Zitat von EWeiss (Beitrag 1179300)
Das man aber direkt SizeOf(WideChar) verwenden kann/muss war mir neu.

GetMem will Bytes und wenn du darin x WideChars abspeichern willst, dann muß das "Chars" in "Bytes" umgerechnet werden,

Also entweder mit
Delphi-Quellcode:
Chars * SizeOf(EinZeichen)
oder, da man hier direkt weiß, daß es nur WideChar sein kann, direkt mit
Delphi-Quellcode:
Chars * 2
,
aber da es dem Compiler egal ist und er aus Beidem das Selbe macht ... ich finde nur, daß SizeOf(WideChar) eben genau zeigt, was man eigentlich rechnen will, wobei man bei der 2 schon nachdenken muß, was das soll.

EWeiss 22. Aug 2012 10:40

AW: Transparent Edit
 
Zitat:

Zitat von himitsu (Beitrag 1179309)
Zitat:

Zitat von EWeiss (Beitrag 1179300)
Das man aber direkt SizeOf(WideChar) verwenden kann/muss war mir neu.

GetMem will Bytes und wenn du darin x WideChars abspeichern willst, dann muß das "Chars" in "Bytes" umgerechnet werden,

Also entweder mit
Delphi-Quellcode:
Chars * SizeOf(EinZeichen)
oder, da man hier direkt weiß, daß es nur WideChar sein kann, direkt mit
Delphi-Quellcode:
Chars * 2
,
aber da es dem Compiler egal ist und er aus Beidem das Selbe macht ... ich finde nur, daß SizeOf(WideChar) eben genau zeigt, was man eigentlich rechnen will, wobei man bei der 2 schon nachdenken muß, was das soll.

Das ist verständlich war mir nur so nicht geläufig.

gruss

Bernhard Geyer 22. Aug 2012 10:42

AW: Transparent Edit
 
Zitat:

Zitat von himitsu (Beitrag 1179294)
Zitat:

Zitat von mkinzler (Beitrag 1179276)
In neueren Delphiversionen schon.

Noch ... wer weiß wann wir UCS4 bekommen. :roll:

Ich Tipp auf: Niemals! Die ganze Welt (.NET/Java/Windows/...) hat sich auf UTF-16 eingeschossen (Ok, Ich weiß es gibt eine kleine Enklave die UTF-8 als das native Format für Strings im Speicher auserkoren hat). Der Vorteil von UCS4 des einfachen Zeichenzugriffs ist nicht mehr so groß als das MS/Apple/Oracle/... anfangen würden eine UCS4-API aufzubauen welche Jahre parallel zur UTF-16-API bestehen würde.

EWeiss 22. Aug 2012 21:30

AW: Transparent Edit
 
Hab doch noch ein probleme bzg. des Subclassing.

Delphi-Quellcode:
constructor TSkinEdit.Create(hOwner: HWND; Visible: Bool; x, y, xW, yH, EditID: Integer);
begin

  if Visible then
  begin
    LStyle := WS_VISIBLE or WS_CHILD or ES_NOHIDESEL;
  end else
  LStyle := WS_CHILD or ES_NOHIDESEL;

  FHEdit := CreateWindowEx(WS_EX_TRANSPARENT or WS_EX_CLIENTEDGE, 'EDIT',
    'Was nun? Nur ein Test!', LStyle, x, y, xW, yH, hOwner, EditID,
    hInstance, nil);

  if FHEdit <> 0 then
  begin
    SubClass(Handle);

  end;
end;
Delphi-Quellcode:
procedure TSkinEdit.SubClass(WinHandle: HWND);
begin

  FClientInstance := MakeObjectInstance(ClientWndProc);

  FPrevClientProc := Pointer(GetWindowLong(WinHandle, GWL_WNDPROC));
  SetWindowLong(WinHandle, GWL_WNDPROC, Integer(FClientInstance));
end;

Messagen die zur zeit GeSubclassed werden

Delphi-Quellcode:
procedure TSkinEdit.ClientWndProc(var Message: TMessage);
begin
  with Message do
  begin
    case Msg of
      WM_ERASEBKGND:
        Result := EditProc(Handle, integer(Msg), Message.WParam, Message.LParam);
      WM_PAINT:
        Result := EditProc(Handle, integer(Msg), Message.WParam, Message.LParam);
      WM_GETTEXT:
        Result := EditProc(Handle, integer(Msg), Message.WParam, Message.LParam);
      WM_GETTEXTLENGTH:
        Result := EditProc(Handle, integer(Msg), Message.WParam, Message.LParam);
    end;
  end;
end;
Probleme die ich nun habe
1. Kein Focus auf das Edit
2. Kein Rechter Mausclick wird ausgelöst
3. Edit läßt sich nicht editieren

Deaktiviere ich die Subclass dann sind alle die genannten Functionen so wie sie sein sollen.
Dann ist sie allerdings nicht mehr transparent und ohne OwnerdrawText.

Was fehlt?
Hab mich im NET mal dumm und dusselig gesucht finde nicht die
passenden WM Messagen oder was auch immer um die probleme zu beheben.

Edit:
Ok werde wohl mal ne Standard Edit mit Winspector überwachen.
Und prüfen welche Messagen ausgelöst werden.

gruss

EWeiss 23. Aug 2012 11:14

AW: Transparent Edit
 
Alle Messagen geprüft
mit keiner kann ich die letzten geposteten Probleme beheben.

Jemand ne idee?

gruss

EWeiss 27. Aug 2012 20:48

AW: Transparent Edit
 
Oh nein sollte das jetzt doch noch funktionieren ;)

Thema erledigt problem gelößt.

gruss


Alle Zeitangaben in WEZ +1. Es ist jetzt 22:42 Uhr.
Seite 2 von 2     12   

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