Extending the IDE/sk

From Free Pascal wiki
Jump to: navigation, search

Deutsch (de) English (en) español (es) français (fr) 日本語 (ja) русский (ru) slovenčina (sk) 中文(中国大陆)‎ (zh_CN)

Rozširovanie IDE

Úvod

IDE podporuje niekoľko typov pluginov:

Komponenty 
Sú to položky Palety komponentov. Napríklad TButton môžete použiť na vytváranie tlačidiel.
Editory komponentov 
Tieto sú použité pri dvojkliku na komponent v návrhu alebo pridaním niektorých ďalších položiek do kontextového menu návrhu, ktoré vyvoláte pravým kliknutím na komponentu.
Editory vlastností 
Tieto sú použité riadkami v Inšpektorovi objektov (Object Inspector).
Experti 
Toto sú všetky ostatné typy.


Existujú dva spôsoby, ako pridať svoj vlastný plugin do IDE Lazarus:

  1. Napíšte balíček, nainštalujte ho a zaregistrujte svoj plugin v procedúre 'Register' jednotky.
  2. Rozšírte kód Lazarus a pošlite svoj CVS rozdiely do maillistu Lazarus.

Písanie komponentov

Vytvorte nový komponent pomocou Editora balíčkov.

Editory komponentov

Editory komponentov poskytované s Lazarus sú definované v jednotke componenteditors.pas. Editor komponentu je plugin použitý vývojárom na pridanie špeciálnych funkcií pre triedy komponentov.

Editor komponenty je vytvorený pre každý komponent, ktorý je vybratý v návrhu formulára a je založený na type komponentu (viz GetComponentEditor a RegisterComponentEditor). Pri dvojkliku na komponent je volaná metóda Edit. Pri vyvolaní kontextového menu komponentu, sú volané metódy GetVerbCount a GetVerb, ktoré vybudujú položky menu. Ak je niektorá položka vybratá, je volaná metóda ExecuteVerb. Metóda Paste je volaná vždy keď je komponent vložený do schránky.

Editor komponentu potrebujete vytvoriť len ak chcete pridať položku/y do kontextového menu, zmeniť predvolené správanie sa pri dvojkliku na komponent alebo pridať rozšírený formát schránky.

Predvolený editor komponentu (TDefaultEditor) implementuje metódu Edit na vyhľadávanie vlastností komponentu a generovanie (alebo navigádiu do) udalostí OnCreate, OnChanged alebo OnClick (ktorú nájde prvú). Vždy keď Editor komponentu modifikuje komponent, musí volať Designer.Modified na informovanie návrhára, že formulár bol modifikovaný. (Or else the user can not save the changes).

Všetky Editory komponentov sú odvodené od virtuálnej abstraktnej triedy TBaseComponentEditor.

Triedy Editorov komponentov

TDefaultComponentEditor
Editor, ktorý poskytuje predvolené správanie pre dvojkliknutie, ktoré opakovane prechádza vlastnosti, hľadajúc najvhodnejšiu metódu vlastnosti na editovanie.
TComponentEditor
Táto trieda poskytuje základnú implementáciu pre rozhranie IComponentEditor. Nie je podmienkou odvodiť váš Editor vlastností od tejto triedy. IDE vyžaduje len dediť od TBaseComponentEditor a implementovať IComponentEditor, táto trieda pomáha pri implementácii triedy, ktorá vyhovuje týmto podmienkam.
TNotebookComponentEditor
Predvolený editor komponentu pre TCustomNotebook.
TPageComponentEditor
Predvolený editor komponentu pre TCustomPage.
TStringGridComponentEditor
Predvolený editor komponentu pre TStringGrid.
TToolBarComponentEditor
Predvolený editor komponentu pre TToolBar.
TFileDialogComponentEditor
Predvolený editor komponentu pre TFileDialog.

Metódy k predefinovaniu

Na zmenu správania štandartného Editora vlastností môžete predefinovať tieto metódy:

Create(AComponent, ADesigner)
Konštruktor triedy je volaný na vytvorenie Editora komponentu. AComponent je komponent, ktorý má byť editovaný v editore. ADesigner je rozhranie pre nájdenie prvku a vytvorenie metód (často nie je použitý). Ak Editor komponentu akokoľvek modifikuje komponent, musí volať ADesigner.Modified.
Edit
Metóda je volaná pri dvojkliku na komponent. Editor komponenty môže vyvolať v tejto metóde napríkald vyvolať dialóg alebo nejaký typ návrhového experta. Ak je GetVerbCount väčší ako nula, Edit spustí obsluhu prvej položky (ExecuteVerb(0)).
ExecuteVerb(Index)
Je volaná vybratím položky kontextového menu, zvolená položka je udávaná pomocou Index. Jej správanie je určené Editorom komponentu.
GetVerb
Editor komponentu musí vrátiť reťazec, ktorý bude zobrazený v kontextovom menu. Editor komponentu je zodpovedný za vhodné umiestnenie znaku & a znakov '...'.
GetVerbCount
Počet platných indexov pre GetVerb a ExecuteVerb. Index začína nulou (tj. 0..GetVerbCount - 1).
PrepareItem
Pri vytváraní kontextového menu je pre každú položku volaná PrepareItem. Editor komponentu môže vhodne prispôsobovať položky menu, vrátane pridávania podpoložiek. Ak niektorú položku nechcete zobraziť, neuvoľňujte ju, jednoducho nastavte vlastnosť Visible na False.
Copy
Je volaná pri kopírovaní komponentu do schránky. Aj obrázok komponentu je vložený do schránky. Poskytuje možnosť Editoru komponentu vložiť iný typ formátu, ktorý je ignorovaný v Designer, ale môže byť podporovaný inou aplikáciou.
IsInInlined
Určuje či je komponent v Designer, ktorý ho vlastní. V podstate, komponenty nemôžu byť pridané do inštancie Frame (collections are fine though) tak táto funkcia určuje, či aktuálne vybratý komponent je nvútri inštancie Frame alebo nie.
GetComponent
Vracia editovaný komponent.
GetDesigner
Vracia aktuálny Designer formulára vlastniaceho komponent.

Registrácia Editora komponentu

Aby IDE vedelo, ktorý Editor komponentu má použiť, je nutné ho registrovať. Pre toto je v jednotke componenteditors.pas definovaný procedurálny typ:

type
  TRegisterComponentEditorProc 
    = procedure (ComponentClass: TComponentClass; ComponentEditor: TComponentEditorClass);
var
  RegisterComponentEditorProc: TRegisterComponentEditorProc;

a jedna procedúra a jedna funkcia:

 procedure RegisterComponentEditor(ComponentClass: TComponentClass; ComponentEditor: TComponentEditorClass);
 function GetComponentEditor(Component: TComponent; const Designer: TComponentEditorDesigner): TBaseComponentEditor;

Registráciu Editora komponentu urobíte jednoducho volaním funkcie RegisterComponentEditor, pričom do ComponentClass zadáte triedu komponentu a do ComponentEditor zadáte triedu Editora komponentu, napr.:

 RegisterComponentEditor(TCustomNotebook, TNotebookComponentEditor);

Čím je zaregistrovaný Editor kompentu TNotebookComponentEditor pre komponenty typu TCustomNotebook.

Editory vlastností

Editory vlastností sú používané v Object Inspectore, pre editáciu jednotlivých vlastností. Sú vlastne rozhraním medzi riadkymi Inšpektora Objektov a vlastnosťou v RTTI. V jednotke propedits.pp je definovaných niekoľko základných Editorov vlastností, ktorých základom je TPropertyEditor.

Trieda TPropertyEditor

Edituje vlastnosť komponentu alebo zoznamu komponentov, vybratú v Inšpektore objektov. Príslušný Editor vlastnosti je vytvorený v závislosti na type editovanej vlastnosti, ktorý je určený registrácii Editora vlastností pomocou RegisterPropertyEditor. Inšpektor objektov používa TPropertyEditor pre všetky modifikácie vlastnosti. GetName a GetValue sú volané na zobrazenie mena a hodnoty vlastnosti. SetValue je volaná vždy, keď užívateľ požaduje zmeniť hodnotu vlastnosti. Edit je volaná keď užívateľ dvojklikne na vlastnosť v Inšpektore objektov. GetValues je volaná pri zobrazení rozbaľovacieho zoznamu. GetProperties pri rozbalení vlastnosti pre zobrazenie pod-vlastností. AllEqual je volané na určenie, či bude zobrazená hodnota vlastnosti prei výbere viac ako jedného komponentu.

Nasledujúce metódy môžu byť predefinované na zmenu správania Editora vlastnosti:

Activate
Je volaná keď sa vlastnosť v Inšpektore objektov stáva vybratou. Je užitočná na povolenie určitých atribútov vlastnosti určených len keď je vlastnosť vybratá v Inšpektore objektov. Len paSubProperties a paMultiSelect, vrátené z GetAttributes, je vyžadované pred volaním tejto metódy.
Deactivate
Je volaná, keď vlastnosť v Inšpektore objektov prestáva byť vybratá.
AllEqual
Je volaná, keď je vybratý viac ako jeden komponent. Ak táto metóda vracia True, je volaná GetValue, inak je v Inšpektore objektov zobrazené prázdne políčko. Je volaná, len ak GetAttributes vracia paMultiSelect.
AutoFill
Je volaná na určenie či hodnoty vrátené pomocou GetValues môžu byť prírastkovo vybraté v Inšpektore objektov. Je volaná len keď GetAttributes vracia paValueList.
Edit
Je volaná pri stlačení tlačítka '...' alebo dvojkliku na vlastnosť. Môže, napríklad, vyvolať dialóg na editovanie komponentu v nejakom výstižnejšom štýle ako je textový (napr. vlastnosť Font).
GetAttributes
Vracia informáciu, ktorú Inšpektor objektov používa na zobrazenie príslušných nástrojov. GetAttributes vracia množinu typu TPropertyAttributes:
    • paValueList: Editor vlastnosti môže vrátiť vymenovaný zoznam hodnôt pre vlastnosť. Ak GetValues volá Proc s hodnotami, potom musí byť tento atribút nastavený. Táto hodnota spôsobuje zobrazenie tlačítka rozbaľovacieho zoznamu na pravej strane vlastnosti v Inšpektore objektov.
    • paSortList: Inšpektor objektov zotriedi hodnoty vrátené z GetValues.
    • paSubProperties: Editor vlastnosti má sub-vlastnosti, ktoré budú zobrazené odsadené pod aktuálnou vlastnosťou v štandartnom formáte. Ak GetProperties bude generovať objektové vlastnosti, potom musí byť tento atribút nastavený.
    • paDynamicSubProps: Sub-vlastnosti možno zmeniť. Všetky návrhové nástroje (tj. Editory vlastností, Editory komponentov), ktoré zmenia zoznam, musia volať UpdateListPropertyEditors, aby Inšpektor objektov znova načítal sub-vlastnosti.
    • paDialog: Udáva, že metóda Edit vyvolá dialóg, tým bude zobrazené tlačítko '...' na pravej strane vlastnosti v Inšpektore objektov.
    • paMultiSelect: Dovoľuje zobrazenie vlastnosti, keď je vybratý viac ako jeden komponent. Niektoré vlastnosti nie sú vhodné pre viacnásobný výber (napr. vlastnosť Name).
    • paAutoUpdate: Spôsobuje volanie metódy SetValue pri každej zmenu, čím sa prejaví v editore, narozdiel od volania po zmene (napr. vlastnosť Caption).
    • paReadOnly: Hodnota nemôže byť menená, ale ak je nastavené paDialog môže hodnotu meniť dialóg. Táto voľba zakazuje len zmenu v políčku Inšpektora objektov.
    • paRevertable: Umožňuje vrátiť hodnotu vlastnosti na pôvodnú hodnotu. Návrat k pôvodnej hodnote nie je možný pre vnorené vlastnosti (ako Fonts) a prvky zložených vlastností, ako množina hodnôt prvkov.
    • paFullWidthName: Vraví Inšpektoru objektov, že hodnotu nie je treba poskytovať a ako také meno môže byť poskytnuté na celú šírku Inšpektora.
    • paVolatileSubProperties: Všetky zmeny hodnoty vlastnosti spôsobia znovazostavenie sub-vlastností.
    • paDisableSubProperties: Všetky sub-vlastnosti sú len na čítanie (ani pomocou dialógu).
    • paReference: Vlastnosť obsahujúca odkaz na niečo iné. Pri použití spolu s paSubProperties môže byť odkazovaný objekt zobrazený ako sub-vlastnosti tejto vlastnosti.
    • paNotNestable: Indikuje, že vlastnosť nie je bezpečné zobrazovať pri zobrazení vlastností rozbaleného odkazu.
GetComponent 
Vracia Index-tý komponent, ktorý je editovaný Editorom vlastností. Je použitá na získanie komponentu. Editor vlastností môže odkazovať na viac komponentov len ak GetAttributes vracia paMultiSelect.
GetEditLimit 
Vracia počet znakov, ktoré môže užívateľ zadať ako hodnotu. Príslušný editor Inšpektora objektov bude potrebovať obmedzenie pre svoj text nastavený na vrátenú hodnotu. Predvolený limit je 255.
GetName 
Vracia meno vlastnosti. Predvolená hodnota je získaná z typovej informácie so všetkými podtržítkami '_' nahradenými medzerami. Táto metóda môže byť predefinovaná ak meno vlastnosti nie je menom, ktoré sa má objaviť v Inšpektore objektov.
GetProperties 
Môže byť prepísaná na volanie PropertyProc pre každú sub-vlastnosť (alebo vnorenú vlastnosť) editovanej vlastnosti a poslaním nového TPropertyEdtior pre každú sub-vlastnosť. Predvolene nie je PropertyProc volaná a nie sú predpokladané sub-vlastnosti. TClassPropertyEditor pošle nový Editor vlastnosti pre každú publikovanú vlastnosť triedy. TSetPropertyEditor posiela nový editor pre každý prvok množiny.
GetPropType 
Vracia ukazovateľ typovej informácie editovanej vlastnosti.
GetValue 
Vracia reťazcovú hodnotu vlasntosti. Predvolene vracia '(unknown)'. Musí byť prepísaná, aby vracala príslušnú hodnotu.
GetValues 
Je volaná keď GetAttributes vrátila paValueList. Musí volať Proc pre každú hodnotu, ktorá je akceptovateľná pre túto vlastnosť. TEnumPropertyEditor budeposielať každý vymenovaný prvok.
Initialize 
Je volaná po vytvorení Editora vlastnosti, ale pred jeho prvým použitím. Veľakrát sú Editory vlastností vytvorené a pretože nemajú spoločnú vlastnosť vo výbere, sú vytvorené zbytočne. Initialize je volaná po určení, že Editor vlastností má byť použitý Inšpektorom objektov a nie zbytočne.
SetValue(Value) 
Je volaná na nastavenie hodnoty vlastnosti. Editor vlastnosti nusí byť schopný preložiť reťazec a volať jednu z metód SetXxxValue. Ak reťazec nemá správny formát alebo má nepovolenú hodnotu, Editor vlastnosti musí generovať výnimku popisujúcu problém. SetValue môže ignorovať všetky zmeny a dovoliť všetky úpravy vlastnosti urobené pomocou metódy Edit (napr. vlastnosť Picture).
ListMeasureWidth(Value,Canvas,AWidth) 
Je volaná počas výpočtu šírky rozbaľovacieho zoznamu.
ListMeasureHeight(Value,Canvas,AHeight) 
Je volaná počas výpočtu výšky položky/hodnoty rozbaľovacieho zoznamu. Je veľmi podobná OnMeasureItem triedy TListBox, len s inými parametrami.
ListDrawValue(Value,Canvas,Rect,Selected) 
Je volaná počas poskytovania položky/hodnoty rozbaľovacieho zoznamu. Je veľmi podobná OnDrawItem triedy TListBox, len s inými parametrami.
PropMeasureHeight(Value,Canvas,AHeight) 
Je volaná počas výpočtu výšky položky/vlastnosti riadku Inšpektora objektov. Je veľmi podobná OnMeasureItem triedy TListBox, len s inými parametrami.
PropDrawName(Canvas,Rect,Selected) 
Je volaná počas poskytovania stĺpca mena zoznamu vlastností. Je veľmi podobná OnDrawItem triedy TListBox, len s inými parametrami.
PropDrawValue(Canvas,Rect,Selected) 
Je volaná počas poskytovania stĺpca hodnôt zoznamu vlastností. Je veľmi podobná PropDrawName. Ak sú zvolené viaceré položky a ich hodnoty sú rôzne, táto procedúra posiela prázdnu hodnotu.

Vlastnosti a metódy užitočné pri vytváraní nových tried TPropertyEditor:

property Name 
Vracia meno vlastnosti vrátené z GetName.
property PrivateEditory 
TKonfiguračný adresár Lazarus. Ak Editor vlastnosti potrebuje pomocné alebo stavové súbory (šablóny, príklady, atď.) môžu byť uložené tu.
property Value 
Aktuálny hodnota, v reťazcovom formáte, vlastnosti vrátená z GetValue.
Modified 
Volaná na indikovanie, že hodnota vlastnosti bola zmenená. Je volaná automaticky z metódy SetXxxValue, ak voláte metódu SetXxxValue priamo, musíte volať aj Modified.
GetXxxValue 
Vracia hodnotu prvej vlastnosti vo vlastnosti Properties. Volajte príslušnú metódu GetXxxValue na získanie hodnoty.
SetXxxValue 
Nastavuje hodnotu všetkých vlastností vo vlastnosti Properties. Volajte príslušné metódy SetXxxxValue na nastavenie hodnoty.
GetVisualValue 
Funkcia vráti zobraziteľnú hodnotu vlastnosti. Ak je vybratá len jedna položka alebo všetky položky viacnásobného výberu majú rovnakú hodnotu, potom táto funkcia vráti aktuálnu hodnotu vlastnosti. Inak vracia prázdny reťazec.

Registrovanie obslúh udalostí

V IDE je niekoľko udalostí, pre ktoré môže plugin pridať svoju vlastnú obsluhu. V súbore propedits.pp sa nachádza objekt GlobalDesignHook", ktorý obsluhuje neikoľko udalostí pre navrhovanie. Každá udalosť volá zoznam obslúh. Predvolené obsluhy sú pridané samotným IDE. Svoje vlastné obsluhy môžete pridať pomocou metód AddHandlerXXX a RemoveHandlerXXX. Tieto budú volané pred predvolenými obsluhami.

Príklady:

 Pridanie svojej obsluhy (toto by mal vykonať konštruktor vášho objektu):
   GlobalDesignHook.AddHandlerComponentAdded(@YourOnComponentAdded);
 Odstránenie vašej obsluhy:
   GlobalDesignHook.RemoveHandlerComponentAdded(@YourOnComponentAdded);
 Môžete odstrániť všetky obsluhy naraz. Napríklad, je vhodé pridať do deštruktora objektu tentor riadok:
   GlobalDesignHook.RemoveAllHandlersForObject(Self);

Obsluhy GlobalDesignHook:

 // lookup root
 ChangeLookupRoot
   Je volaná pri zmene "LookupRoot". "LookupRoot" je vlastník objektu aktuálne vybratého komponentu. Zvyčajne to je TForm.
 // methods
 CreateMethod
 GetMethodName
 GetMethods
 MethodExists
 RenameMethod
 ShowMethod
 MethodFromAncestor
 ChainCall
 // components
 GetComponent
 GetComponentName
 GetComponentNames
 GetRootClassName
 ComponentRenamed
   Volaná pri premenovaní komponentu
 ComponentAdded
   Volaná pri priradní komponentu do LookupRoot
 ComponentDeleting
   VOlaná pred uvoľnením komponentu.
 DeleteComponent
   VOlaná pri odstráenní komponentu pomocou IDE.
 GetSelectedComponents
   Vracia aktuálny výber komponentov.
 // persistent objects
 GetObject
 GetObjectName
 GetObjectNames
 // modifing
 Modified
 Revert
 RefreshPropertyValues


Spolupracovníci a zmeny

This page has been converted from the epikwiki version.

This document was authored by Mattias Gaertner Initial import and formatted for Lazarus-CCR - VlxAdmin 9/26/2003

  • Prvotný preklad - Slavko 02:24, 26 Mar 2005 (PST)
  • Doplnený preklad kapitoly Editory vlastností a komponentov - Slavko 10:54, 1 Apr 2005 (PST)