AGB  ·  Datenschutz  ·  Impressum  







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

editorfunktionen

Ein Thema von toredo · begonnen am 1. Sep 2006 · letzter Beitrag vom 2. Sep 2006
 
Benutzerbild von Mackhack
Mackhack

Registriert seit: 29. Nov 2003
Ort: San Diego, CA/USA
1.446 Beiträge
 
Delphi 2006 Architect
 
#4

Re: editorfunktionen

  Alt 2. Sep 2006, 01:50
Hi,

ich habe auch mal sowas aehndliches geschrieben wie den Delphi-Editor zu Testzwecken.

Hier der Quellcode:

Delphi-Quellcode:
  private
    { Private declarations }
    CodeList : TListBox;
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.CodeListClick(Sender: TObject);
Var
  CurLine : Integer;
begin
  if CodeList.ItemIndex <> -1 then
  begin
    CurLine := Editor.CaretPos.Y;
    Editor.Lines[CurLine] := Editor.Lines[CurLine] + CodeList.Items[CodeList.ItemIndex];
  end;
  CodeList.Visible := False;
  Editor.SetFocus;
end;

procedure TForm1.FormCreate(Sender: TObject);
begin
  CodeList := TListBox.Create(Self);
  CodeList.Parent := Editor;
  CodeList.Visible := False;
  CodeList.Width := 200;
  CodeList.Height := 100;
  CodeList.Items.Add('Caption');
  CodeList.Items.Add('Top');
  CodeList.Items.Add('Left');
  CodeList.OnClick := CodeListClick;
  CodeList.OnKeyDown := CodeListKeyDown;
end;

procedure TForm1.CodeListKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState);
Var
  CurLine : Integer;
begin
  case Key of
  13 : begin
         if CodeList.ItemIndex <> -1 then
         begin
           CurLine := Editor.CaretPos.Y;
           Editor.Lines[CurLine] := Editor.Lines[CurLine] + CodeList.Items[CodeList.ItemIndex];
         end;
       end;
  end;
  CodeList.Visible := False;
  Editor.SetFocus;
end;

procedure TForm1.EditorKeyPress(Sender: TObject; var Key: Char);
Var
  CliPos : TPoint;
  ListX, ListY : Integer;
begin
  if Key = '.then
  begin
    GetCaretPos(CliPos);
    ListX := CliPos.X;
    ListY := CliPos.Y + CodeList.Canvas.TextHeight('W') + 4;
    if ListX + CodeList.Width >= Editor.Width then
      ListX := Editor.Width - CodeList.Width - 20;
    if ListY + CodeList.Height >= Editor.Height then
      ListY := Editor.Height - CodeList.Height - 20;
    with CodeList do
    Begin
      Top := ListY;
      Left := ListX;
      ItemIndex := 0;
      Visible := True;
      SetFocus;
    end;
  end
  else
    CodeList.Visible := False;
end;

end.
Um etwas Neues zu schaffen muss man seine Ohren vor den Nein-sagern verschliessen um seinen Geist öffnen zu können.
(George Lukas)
  Mit Zitat antworten Zitat
 


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 19:51 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