AGB  ·  Datenschutz  ·  Impressum  







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

Design Problem (Shapes)

Ein Thema von Bjoerk · begonnen am 15. Apr 2014 · letzter Beitrag vom 15. Apr 2014
Antwort Antwort
Seite 1 von 2  1 2      
Bjoerk

Registriert seit: 28. Feb 2011
Ort: Mannheim
1.384 Beiträge
 
Delphi 10.4 Sydney
 
#1

Design Problem (Shapes)

  Alt 15. Apr 2014, 10:39
Ich hab ein Design Problem. Ich hab 44 Typen von Shapes. Aus den 44 werden wohl mal im Laufe der Zeit mal 144 werden. Ich hab zwei Varianten des Quellcodes. Einmal als separate Klassen mit override Methoden und einmal alles in einer Klasse. Beides ist irgendwie Mist weil beides ziemlich unübersichtlich. Liegt das in der Natur der Sache oder gibt’s generell auch noch andere Möglichkeiten diesen Quellcode aufzusetzen?
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.475 Beiträge
 
Delphi 12 Athens
 
#2

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 10:56
Das kommt ganz auf deine Anforderungen an, die wir aber jetzt nicht kennen.

Eventuell bietet sich hier auch das Strategy-Pattern an. Ein Beispiel kann ich aber ohne weitere Code-Kenntnis schlecht geben.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Bjoerk

Registriert seit: 28. Feb 2011
Ort: Mannheim
1.384 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 11:38
Von der Struktur her so:

Delphi-Quellcode:
type
  TBaseObject = class
  protected
    vars;
    getter, setter; virtual;
  public
    methods; virtual;
    methods; virtual; abstract;
    properties;
  end;


  TObject1..N = class(TBaseObject)
  private
    more vars;
  protected
    more vars;
    more getter, setter;
    getter, setter; override;
  public
    methods;
    methods; override;
    properties;
  end;
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.475 Beiträge
 
Delphi 12 Athens
 
#4

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 13:40
Da sich das Verhalten der 44-144 Shapes per Definition unterscheidet, kommst du um eine entsprechende Menge Code nicht herum. Das jetzt alles in eine Klasse zu packen widerstrebt mir persönlich schon sehr, ist aber durchaus ein möglicher Ansatz. Einzelne Klassen mit einer passenden Vererbungshierarchie sind mir da schon lieber - aber das ist meine persönliche Meinung.

Wenn du allerdings feststellst, daß du wiederkehrende oder ähnliche Code-Teile hast, sollte man über einen besseren Ansatz nachdenken. Da fallen mir spontan noch Anonyme Methoden und Generics ein, aber für einen fundierten Rat müsste man schon mehr sehen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#5

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 14:42
Du kannst deine 144 Shapes ruhig so umsetzen, solltest Du sogar, wenn Du OOP machen willst.

Um elegant das richtige Shape zu instantiieren, bietet sich eine Factory an. Entweder haben die Klassen alle irgend einen Namen/Enum-Wert, oder du kannst sie klassifizieren. Mögliche Schnittstelle der ShapeFactory:

Delphi-Quellcode:
myShape := ShapeFactory.Create(shapeBigCircle); // via Enum
myShape := ShapeFactory.Create(TBigCircle); // by class, fast so wie direktes Create, aber mit mehr Möglichkeiten

// oder vielleicht mit einer ShapeFactoryFactory:
myFactory := ShapeFactoryFactory.CreateFactory(shapesCircles);
myShape := myFactory.Create(circleBig);
Ordnung bringt hier im Übrigen nur eine stringente Nomenklatur und Dokumentation. Mit einer Factory hast Du eine Dokumentation geschaffen, denn alle Shapes sind zentral (in der Factory) erfasst. Dort lässt sich auch die Nomenklatur überprüfen, einfach, weil in der Registrierung ja eh alle Namen stehen und da fällt es schon auf, wenn man bei der Benennung der Klassen geschludert hat.
Delphi-Quellcode:
Procedure TShapeFactory.Register;
Begin
  RegisterShape (TBigCircle, shapesBigCircle);
  RegisterShape (TKleinerKreis, shapesSmallCircle); // <-- Möööp
...

Geändert von Dejan Vu (15. Apr 2014 um 14:45 Uhr)
  Mit Zitat antworten Zitat
Bjoerk

Registriert seit: 28. Feb 2011
Ort: Mannheim
1.384 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 15:55
Ok. Tanx. Von Factorys hab ich keinen Plan? Anonyme Methoden und Generics sind halt auch etwas ungünstig bei D2007.

Wenn das TShape von Delphi nicht 6 sondern 60 Typen hätte, wie wäre das denn programmiert worden, wenn man eine ellenlange Paint hätte vermeiden wollen und auch nicht 60 verschiedene Klassen hätte haben wollen?

Delphi-Quellcode:
procedure TShape.Paint;
begin
  case FTyp of
    Typ1:

    Typ2:

    Typ3:

    Typ4:

    Typ5:

    ..

    TypN:
  end;
end;
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#7

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 16:16
Delphi-Quellcode:
procedure TShape.Paint;
begin
  case FTyp of
    Typ1:
      PaintTyp1;
    Typ2:
      PaintTyp2;
    Typ3:
      PaintTyp3;
    Typ4:
      PaintTyp4;
    Typ5:
      PaintTyp5;
    ..

    TypN:
  end;
end;

procedure TShape.PaintTyp1;
begin
  ...
end;

procedure TShape.PaintTyp2;
begin
  ...
end;

//usw. usf.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Bjoerk

Registriert seit: 28. Feb 2011
Ort: Mannheim
1.384 Beiträge
 
Delphi 10.4 Sydney
 
#8

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 16:19
Jenau.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#9

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 16:33
Wenn du das flexibel erweitern möchtest, dann nimm eine Shape-Klasse und eine ShapeStrategy-Klasse.
Hier mal skizziert, wie das geht:
Delphi-Quellcode:
type
  TShapeStrategy = class abstract
  protected
    procedure Paint( ACanvas : TCanvas ); virtual; abstract;
  end;

  TShapeStrategyClass = class of TShapeStrategy;

  TShape = class( TGraphicControl )
  private
    FStrategyName : string;
    FStrategy : TShapeStrategy;
    procedure SetStrategyName( const Value : string );
  protected
    procedure Paint; override;
  public
    class procedure RegisterStrategy( const AName : string; AStrategy : TShapeStrategyClass );
  published
    property StrategyName : string read FStrategyName write SetStrategyName;
  end;

procedure TShape.Paint;
begin
  if Assigned( FStrategy ) then
    FStrategy.Paint( Canvas );
end;
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#10

AW: Design Problem (Shapes)

  Alt 15. Apr 2014, 17:29
Ok. Tanx. Von Factorys hab ich keinen Plan? Anonyme Methoden und Generics sind halt auch etwas ungünstig bei D2007.
Da sind keine Generics oder anonyme Methoden im Spiel, das ist richtig billig und schnell gebaut. Und Factories gibts im Wiki für lau zum anschauen.
Delphi-Quellcode:
procedure TShape.Paint;
begin
  case FTyp of
    Typ1:

    Typ2:

    Typ3:
...
Das ist -mit Verlaub- nicht weitsichtig. Es verstößt gegen das OCP und ist auch so nicht sonderlich flexibel, denn jedes Shape hat ja u.U. individuelle Parameter oder unterscheidet sich im Verhalten (Stichwort Collisiondetection). Du legst dich bei diesem Pattern sofort darauf fest, das sich die Shapes nur im Aussehen unterscheiden.

Ring dich dazu durch, individuelle Klassen zu erstellen. Es ist mehr Tipparbeit, aber im Endeffekt machst Du das nur 1x, während Du bei der 'Case'-Variante (Non OOP) eh irgendwann refaktorisieren musst, weil das Design Quark ist.

Die Strategy-Idee von Sir Rufo löst das Paint-Case-Problem auf sehr elegante Weise und sollte dann verwendet werden, wenn in einer Klasse eine bestimmte Funktion flexibel änderbar sein sollte. Bezüglich der eventuell unterschiedlichen Eigenschaften (Höhe/Breite vs. Radius vs. Elipsenradien vs. äh... Schuhgröße) wirst Du mit dem Pattern dann nicht weit kommen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 02:42 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