![]() |
AW: Eigene Ereignisse auslösen
Zitat:
|
AW: Eigene Ereignisse auslösen
Reden wir aneinander vorbei? Den Setter kann man nicht umgehen, es handelt sich doch um eine globale Version des Records. Oder wird die komplette Record-Variable überschrieben?
|
AW: Eigene Ereignisse auslösen
Zitat:
Delphi-Quellcode:
machen wie du möchtest, sie werden trotzdem ohne den Setter zu benutzen geändert.
strict private
|
AW: Eigene Ereignisse auslösen
Ja aber an irgendeiner Stelle muss ja der Record belegt werden, ob jetzt dann oder davor. In dem Moment fliegt dann das Event.
Delphi-Quellcode:
Aber das hilft jetzt glaube ich nicht wirklich dem Suchenden
TMyRec = record
strict private FNichtBeschreibbar: Boolean; procedure SetNichtBeschreibbar(const Value: Boolean); public property NichtBeschreibbar : Boolean read FNichtBeschreibbar write SetNichtBeschreibbar; end; var Form1: TForm1; implementation {$R *.dfm} { bla } procedure TMyRec.SetNichtBeschreibbar(const Value: Boolean); begin FNichtBeschreibbar := Value; end; procedure TForm1.FormCreate(Sender: TObject); var MyRec : TMyRec; MyRec2 : TMyRec; begin MyRec.NichtBeschreibbar := True; MyRec2.NichtBeschreibbar := False; // dann halt hier MyRec := MyRec2; // und nicht hier end; |
AW: Eigene Ereignisse auslösen
Hallo Sir Rufo
Danke für Dein Vorschlag, etwas ist mir nicht ganz klar. Zitat:
(// Warten auf ein Empfangs-Signal resp. // Irgendwie den Status empfangen) Nur taucht da ein anderes Problem auf. Von der CNC kommt nicht nur Status, sondern auch andere Meldungen mit unterschiedliche länge, die müssen dann in den etsprechenden Records gespeichert werden (für spätere Anzeige) wobei dies natürlich auch im Hintergund soll ablaufen. Die Reihenfolge der Meldungen ist beliebig ! Gruss Anton |
AW: Eigene Ereignisse auslösen
Zitat:
|
AW: Eigene Ereignisse auslösen
akurka, poste doch mal bitte wo du den Record befüllst, wenn das möglich ist.
Ich empfehle dir nochmals (weil es eine wirklich durchdachte Implementation ist) einen Blick in die AsyncPro Bibliothek zu werfen (speziell Datapackages). Es gibt auch eine gute Dokumentation dazu. |
AW: Eigene Ereignisse auslösen
Zitat:
Wenn du dem Record einen Event spendierst und dann den Record aus einem Stream lädst, dann ist auch die Zuweisung für den Event entweder leer (im besten Fall) oder der Event zeigt irgendwo ins Nirwana und die Hütte fliegt dir um die Ohren. Betrachte einen Record so, wie du einen einfachen Typen wie z.B. ![]() |
AW: Eigene Ereignisse auslösen
@akurka
Im OOP-Geschäft muss man etwas abstrakter denken (damit das auch Sinn macht und das Leben vereinfacht). z.B. Die Komponente für den Com-Port sorgt für den Datenaustausch (Protokoll) und nicht mehr. Sie weiß, wie groß die Pakete sind (ist Bestandteil des Protokolls) und übergibt diese Pakete an eine weitere Instanz, die weiß, wie man aus diesen Paketen (eine Handvoll Bytes) sinnvolle Strukturen erzeugt. Etwas Ähnliches (mit Klassen) gibt es hier ![]()
Delphi-Quellcode:
In die andere Richtung geht es genauso (nur umgekehrt).
unit BaseDataFactory;
interface uses System.Generics.Collections, System.Classes, System.SysUtils, BaseData; type TBaseDataClass = class of TBaseData; TBaseDataFactory = class private class var _Types : TDictionary<Byte, TBaseDataClass>; protected class constructor Create; class destructor Destroy; public class function CreateFromStream( AStream : TStream ) : TBaseData; class procedure RegisterType( AType : Byte; AClass : TBaseDataClass ); end; implementation { TBaseDataFactory } class constructor TBaseDataFactory.Create; begin _Types := TDictionary<Byte, TBaseDataClass>.Create; end; class function TBaseDataFactory.CreateFromStream( AStream : TStream ) : TBaseData; var LType : Byte; LSize : Byte; LData : TBytes; LClass : TBaseDataClass; begin AStream.Read( LType, SizeOf( LType ) ); AStream.Read( LSize, SizeOf( LSize ) ); SetLength( LData, LSize ); AStream.Read( LData, LSize ); LClass := _Types[LType]; // Bei einem unbekannten Typen wird hier eine Exception geworfen Result := LClass.Create( LData ); end; class destructor TBaseDataFactory.Destroy; begin _Types.Free; end; class procedure TBaseDataFactory.RegisterType( AType : Byte; AClass : TBaseDataClass ); begin _Types.AddOrSetValue( AType, AClass ); end; end. Einer weiß, wie man aus einer Informationsstruktur (z.B. ein Record) eine Byte-Folge machen kann, übergibt diese Byte-Folge an jemand anderes, der Byte-Folgen versenden kann, der wiederum weiß, dass das über den Com-Port erfolgen muss. |
AW: Eigene Ereignisse auslösen
Okay vielleicht fällt es mir auch nur zu schwer, mich da in etwas hineinzudenken was ich nicht sehe :) In dem was du sagst stimme ich zu.
akurka, schau einmal hier in den Guide. In der Sektion Datapackages. ![]() Diese Bibliothek ist so mächtig das der serielle Stream vor ihr erzittert :] |
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:11 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