AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Klassennamen ändern

Ein Thema von Marco Steinebach · begonnen am 20. Aug 2024 · letzter Beitrag vom 27. Aug 2024
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.081 Beiträge
 
Delphi 12 Athens
 
#11

AW: Klassennamen ändern

  Alt 20. Aug 2024, 12:16
Prinzipiell kann man hier auch mit Alias arbeiten, wo entweder der VCL-Designer die Klasse anders benennt (TMyRichEdit als TRichEdit nutzt, wo das normale TRichEdit natürlich aus der Registrierung entfernt werden muß)
oder wo im Designer ein "normales" TRichEdit genutzt wird, aber zur Laufzeit dann das TMyRichEdit über den "gleichen" Namen TRichEdit verwendet wird.

Letzteres z.B. damals hier benutzt,
https://www.delphipraxis.net/141895-...phi-other.html
wo im FormDesigner ein normales TEdit platziert wurde, aber zur Laufzeit im Kompilat beim DFM-Laden das imbenannte TTntEdit anstatt dem TEdit geladen wurde
und im Quellcode zur DesignTime auch die Codevervollständigung die Property des TntEdit sieht. (entsprechend siehe hier Post #2 und #9)
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
Kas Ob.

Registriert seit: 3. Sep 2023
353 Beiträge
 
#12

AW: Klassennamen ändern

  Alt 20. Aug 2024, 14:15
Yes, interposer did the job, while keeping the Window Class name as TRichEdit, so Screen Reader or any inspector application will see that.

example
Code:
unit uMain;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants,
  System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.ComCtrls,
  Vcl.StdCtrls, uMyRichEdit;

type
  TForm10 = class(TForm)
    RichEdit1: TRichEdit;     // if uMyRichEdit not the last in uses clauses then "uMyRichEdit.TRichEdit" should be used
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form10: TForm10;

implementation

{$R *.dfm}

end.
Code:
unit uMyRichEdit;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants,
  System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs,
  Vcl.ComCtrls;

type
  //TMyRichEdit = class;                         // foreward declaration

  TRichEdit = class(Vcl.ComCtrls.TRichEdit)
  protected
    procedure KeyPress(var Key: Char); override;
  end;

  //TMyRichEdit = class(uMyRichEdit.TRichEdit);  // just naming override, will work for runtime creation only and for internal naming usage

implementation

{ TRichEdit }

procedure TRichEdit.KeyPress(var Key: Char);
begin
  Key := '*';
  inherited;
end;

end.
Kas
  Mit Zitat antworten Zitat
Marco Steinebach

Registriert seit: 4. Aug 2006
502 Beiträge
 
Delphi 5 Enterprise
 
#13

AW: Klassennamen ändern

  Alt 27. Aug 2024, 08:47
Hallo Himitsu,
Ich brauch bitte nochmal deine Hilfe!
Prinzipiell kann man hier auch mit Alias arbeiten, wo entweder der VCL-Designer die Klasse anders benennt (TMyRichEdit als TRichEdit nutzt, wo das normale TRichEdit natürlich aus der Registrierung entfernt werden muß)
Ich weiß nicht, ob mein D5 das kann, aber wie kriege ich eine Komponente aus der Registrierung????

... oder wo im Designer ein "normales" TRichEdit genutzt wird, aber zur Laufzeit dann das TMyRichEdit über den "gleichen" Namen TRichEdit verwendet wird.

Letzteres z.B. damals hier benutzt,
https://www.delphipraxis.net/141895-...phi-other.html
wo im FormDesigner ein normales TEdit platziert wurde, aber zur Laufzeit im Kompilat beim DFM-Laden das imbenannte TTntEdit anstatt dem TEdit geladen wurde
und im Quellcode zur DesignTime auch die Codevervollständigung die Property des TntEdit sieht. (entsprechend siehe hier Post #2 und #9)
Okay, hab mir, natürlich, deine TNTHacks angesehen, aber ich bin, und das passiert mir nicht oft, echt zu blöd.
Also:
Ich nehme in meiner Form ein stinknormales TRichEdit, kann die Eigenschaften also ganz normal über den Form-Designer setzen, das wäre ja schonmal schön.
Und nu? Wie kriege ich das mit dem Überschreiben hin?
Meine Klasse ist
Code:
TMSRichEdit = class (TRichEdit)
Kannst du mich bitte mal schupsen?

Es bedankt sich
Wandogau
Marco Steinebach
  Mit Zitat antworten Zitat
Marco Steinebach

Registriert seit: 4. Aug 2006
502 Beiträge
 
Delphi 5 Enterprise
 
#14

AW: Klassennamen ändern

  Alt 27. Aug 2024, 11:02
Huhu,
Da ich nix gefunden habe, um meinen vorigen Beitrag zu löschen...
Hat sich erledigt, einfach die Hack als letzte in die Uses einbinden, und alles ist schön.
Sorry!
Marco Steinebach
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.081 Beiträge
 
Delphi 12 Athens
 
#15

AW: Klassennamen ändern

  Alt 27. Aug 2024, 12:46
https://docwiki.embarcadero.com/RADS...nents_aufrufen

Delphi-Referenz durchsuchenRegisterClass
Delphi-Referenz durchsuchenRegisterClassAlias
Delphi-Referenz durchsuchenRegisterClasses

Delphi-Referenz durchsuchenRegisterComponents
Delphi-Referenz durchsuchenRegisterNoIcon
Delphi-Referenz durchsuchenRegisterNonActiveX

Delphi-Referenz durchsuchenUnRegisterClass
Delphi-Referenz durchsuchenUnRegisterClasses
Delphi-Referenz durchsuchenUnRegisterModuleClasses


Man kann seine Klassen auch ableiten
Delphi-Quellcode:
type
  TRichEdit = class(TMyRichEdit);
Diese Ableitung im Delphi registrieren und damit das originale TRichEdit überdecken.



Oder,
ich weiß zwar dass es geht, aber nicht wie.
Man kann für die DesignTime EINE Klasse registrieren, welche nur im FormDesigner genutzt wird,
aber so, dass im Code dann eine andere gleichnamige Runtime-Klasse eingefügt wird (inkl. der abweichenden Unit im USES).



Wie gesagt, wenn es im Designer reicht, wenn die originale TRichEdit dort vorkommt,
aber zur Laufzeit im Programm dann deine Ableitung, dann wurde ja schon gezeigt,
wie man in der selben Unit vor der Form-Klasse, oder als "letztes" im USES in einer Unit, dieses TRichEdit durch ein anderes ersetzt werden kann.

Letztes: die Unit mit dem originalen TRichEdit muß vor der Unit mit dem neuen TRichEdit stehen, oder halt nach dem USES direkt im Code das "neue" TRichEdit.
Das "Letzte", also was von unten nach oben als Erstes gefunden wird, das wird verwendet.





Zitat:
schubs
In der Form (DFM) befindet sich z.B. ein TRichEdit.
Im FormDesigner des Delphi liegt dieses TRichEdit auf der Form drauf.

In der DFM steht nur als String "TRichEdit".
In deiner TForm-Ableitung findet sich dazu eine "Variable" vom Typ TRichEdit (RichEdit1: TRichEdit; )
und dieser Typ ist das, was benutzt wird, um die Form-Instanz und draufbefindliche Komponenten zu erstellen.

Hier wurde nun einfach im Code diese TRichEdit-Typ, welchen der Compiler an "dieser" Stelle sieht, durch einen anderen ersetzt.
type TRichEdit = class(TMSRichEdit);
(entweder in selber Unit, oberhalb der Form, oder in einer Unit, welche möglichst als Letztes im USES steht)

Somit ist zwar im Designer die andere/originale Komponente auf der Form,
aber im laufenden Programm stattdessen dann eine Andere.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (27. Aug 2024 um 12:53 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:44 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz