Difference between revisions of "Lazarus Tutorial/fi"

From Free Pascal wiki
Jump to navigationJump to search
(Remove Main menu/fi transclusion; add page link)
 
(10 intermediate revisions by 3 users not shown)
Line 2: Line 2:
  
 
''Tästä alkaa Lazarus Tutorial. Voit vapaasti parantaa sitä.''
 
''Tästä alkaa Lazarus Tutorial. Voit vapaasti parantaa sitä.''
 +
 +
__TOC__
  
 
== Yleistä ==
 
== Yleistä ==
Lazarus on vapaa avoimeen lähdekoodiin perustuva ohjelmankehitysympäristö joka pohjautuu FreePascal Compiler (object pascal), Joka on myös vapaa ja avointa lähdekoodia. Lazarus käyttöliittymä {[[Screenshots| kuvakaappaus]]) on vakaa ja ominaisuuksiltaan monipuolinen ohjelman kehitysympäristö jolla voi tehdä itsenäisiä graafisia ja komentorivillä toimivia sovelluksia. Se toimii Linux:ssa, FreeBSD:ssä, Win32:ssa, Mac:ssa ja on varustettu customoitavalla lähdekoodieditorilla ja visuaalisella lomakkeen muotoilulla jossa mukana komponenttipakettienhallinta, virheenjäljitin ja täydellinen  graafinen käyttöliittymäkomponentit integoroituna FreePascal kääntäjään.
+
Lazarus on vapaa avoimeen lähdekoodiin perustuva ohjelmankehitysympäristö joka pohjautuu [[FPC/fi|FreePascal Compiler]] (object pascal), Joka on myös vapaa ja avointa lähdekoodia. Lazaruksen [[IDE/fi|käyttöliittymä]] ([[Screenshots| kuvakaappauksia]]) on vakaa ja ominaisuuksiltaan monipuolinen ohjelman kehitysympäristö jolla voi tehdä itsenäisiä [[Graphical_User_Interface/fi|graafisia]] ja [[Command-line_interface/fi|komentorivillä]] toimivia sovelluksia. Se toimii Linux:ssa, [[FreeBSD]]:ssä, Win32:ssa, Mac:ssa ja on varustettu customoitavalla lähdekoodieditorilla ja visuaalisella lomakkeen muotoilulla jossa mukana komponenttipakettienhallinta, [[Debugger/fi|virheenjäljitin]] ja täydelliset graafiset käyttöliittymäkomponentit integroituna FreePascal [[Compiler/fi|kääntäjään]].
  
 
== Aloittaminen ==
 
== Aloittaminen ==
Line 10: Line 12:
 
Hanki, [[Installing Lazarus|asenna]] ja käynnistä Lazarus jossa pitää olla Free Pascal Compiler mukana.
 
Hanki, [[Installing Lazarus|asenna]] ja käynnistä Lazarus jossa pitää olla Free Pascal Compiler mukana.
  
{{Note| Ainakin Linux Ubuntu, Lasaruksen käynnistyskomento on konsolissa (päätteessä) "startlazarus". Jos olet asentanut Lazaruksen Debianin pakettina, niin Lazarus pitäisi olla valikkokohdan  Sovellus / ohjelmointi alla. (Huomaa: Debian ja Ubuntu tärkeimmät binary ja paketti on nimeltään "Lazarus-ide", koska on myös "TCT" paketti jossa mukana tulee apuohjelma nimeltä "Lazarus").}}
+
{{Note| Ainakin Linux Ubuntussa, Lazaruksen käynnistyskomento on konsolissa (päätteessä) "startlazarus". Jos olet asentanut Lazaruksen Debianin pakettina, niin Lazarus pitäisi olla valikkokohdan  Sovellus / ohjelmointi alla. (Huomaa: Debian ja Ubuntu tärkeimmät binary ja paketti on nimeltään "Lazarus-ide", koska on myös "TCT" paketti jossa mukana tulee apuohjelma nimeltä "Lazarus").}}
  
 
===  Ensimmäinen Lazarus ohjelma! ===
 
===  Ensimmäinen Lazarus ohjelma! ===
  
Päävalikosta valitsemalla Projekti-Uusi projekti-Sovellus (tai: Tiedosto-Uusi-projekti-Sovellus)niin uusi graafinen sovellus luodaan, katso myös [[Form Tutorial|Form opetusohjelma]] .
+
Päävalikosta valitsemalla Projekti-Uusi projekti-Sovellus (tai: Tiedosto-Uusi-projekti-Sovellus) niin uusi graafinen sovellus luodaan, katso myös [[Form Tutorial|Form opetusohjelma]] .
  
Useita ikkunoita ilmestyy työpöydälle: Päävalikkoikkuna yläreunassa, Komponenttimuokkain on vasemmalla, "Lähdekoodieditori" täyttää työpöydän ja valmis lomake "Form1" on omassa ikkunassa ([[TForm|Form1]] ) Lähdekoodieditorin päällä.  
+
Useita ikkunoita ilmestyy työpöydälle: Päävalikkoikkuna yläreunassa, Komponenttimuokkain on vasemmalla, "Lähdekoodieditori" täyttää työpöydän ja valmis lomake "Form1" on omassa ikkunassa ([[TForm/fi|Form1]] ) Lähdekoodieditorin päällä.  
  
Jos halutaan sijoittaa painike lomakkeelle: Päävalikkoikkunan alaosassa on välilehtirivi. Jos "[[Standard tab/fi|Standard]]" välilehti ei ole jo valittu, valitse se klikkaamalla hiirellä. Sen jälkeen etsii [[TButton/fi|Button]]  kuvakkeen (suorakulmio jossa on "OK"-teksti) ja klikkaa sitä hiirellä. Sitten Form1 ikkunassa klikataan jonnekin keskilinjan vasemmalla puolen. Varjostettu "Button1"-tekstillä merkitty suorakulmio ilmestyy siihen. Klikkaa jälleen Button kuvaketta  Standard -välilehdellä ja klikkaa Form1-ikkunassa jonnekin oikealle keskelle: toinen "Button2"-tekstillä merkitty suorakulmio ilmestyy.
+
Jos halutaan sijoittaa painike lomakkeelle: Päävalikkoikkunan alaosassa on välilehtirivi. Jos "[[Standard tab/fi|Standard]]" välilehti ei ole jo valittu, valitse se klikkaamalla hiirellä. Sen jälkeen etsii [[TButton/fi|Button]]  kuvakkeen ([[image:tbutton.png]] eli suorakulmio jossa on "OK"-teksti) ja klikkaa sitä hiirellä. Sitten Form1 ikkunassa klikataan jonnekin keskilinjan vasemmalla puolen. Varjostettu "Button1"-tekstillä merkitty suorakulmio ilmestyy siihen. Klikkaa jälleen Button kuvaketta  Standard -välilehdellä ja klikkaa Form1-ikkunassa jonnekin oikealle keskelle: toinen "Button2"-tekstillä merkitty suorakulmio ilmestyy.
  
 
Nyt klikkaa Button1 jotta se valitaan. Komponenttimuokkainikkuna näyttää nyt kohteen Button1-ominaisuudet. Yläosassa on ominaisuus nimeltä 'Caption', jossa näytetään arvo "Button1". Klikkaa kyseistä kohtaa (ruudukkoa) ja muuta teksti "Button1" muotoon "Press". Jos painat {{keypress|ENTER}} tai klikkaat toista ruutua näet että Form1-lomakkella ensimmäisen painikkeen teksti muuttuu "Press":ksi. Nyt klikkaat Tapahtumat -välilehteä komponenttimuokkaimessa niin näet erilaisia tapahtumia, jotka voivat liittyä tähän Button1-painikkeeseen. Näitä ovat onClick, OnEnter, OnExit jne. Valitse onClick oikealla puolella oleva ruutu. Tällöin siihen ilmestyy pienempi laatikko kolmella pisteellä (...). Kun klikkaat tätä, se otetaan automaattisesti osaksi lähdekoodieditorissa ja kursorin sijoitetaan koodinpätkän keskelle:
 
Nyt klikkaa Button1 jotta se valitaan. Komponenttimuokkainikkuna näyttää nyt kohteen Button1-ominaisuudet. Yläosassa on ominaisuus nimeltä 'Caption', jossa näytetään arvo "Button1". Klikkaa kyseistä kohtaa (ruudukkoa) ja muuta teksti "Button1" muotoon "Press". Jos painat {{keypress|ENTER}} tai klikkaat toista ruutua näet että Form1-lomakkella ensimmäisen painikkeen teksti muuttuu "Press":ksi. Nyt klikkaat Tapahtumat -välilehteä komponenttimuokkaimessa niin näet erilaisia tapahtumia, jotka voivat liittyä tähän Button1-painikkeeseen. Näitä ovat onClick, OnEnter, OnExit jne. Valitse onClick oikealla puolella oleva ruutu. Tällöin siihen ilmestyy pienempi laatikko kolmella pisteellä (...). Kun klikkaat tätä, se otetaan automaattisesti osaksi lähdekoodieditorissa ja kursorin sijoitetaan koodinpätkän keskelle:
  
<syntaxhighlight>
+
<syntaxhighlight lang="pascal">
 
procedure TForm1.Button1Click(Sender: TObject);
 
procedure TForm1.Button1Click(Sender: TObject);
 
begin
 
begin
Line 34: Line 36:
 
Painamalla {{keypress|F12}} nähdään lähdekoodieditorin sijasta lomakkeen Form1 ikkuna.
 
Painamalla {{keypress|F12}} nähdään lähdekoodieditorin sijasta lomakkeen Form1 ikkuna.
  
Nyt muokataan Button2 ominaisuuksia : klikkaa Button2 jotta nähdään sen ominaisuuksia komponenttimuokkaimessa. Muuta sen Caption omainaisuuteen "Button2" tekstin tilalle "Exit". Valitse tapahtumat-välilehti ja klikkaa onClick. Klikkaa kolme pistettä (...) ja sen jälkeen ollaan lähdekoodieditorissa, keskellä toisen Button2:n aliohjelmaa:
+
Nyt muokataan Button2 ominaisuuksia : klikkaa Button2 jotta nähdään sen ominaisuuksia komponenttimuokkaimessa. Muuta sen Caption [[Property|ominaisuuteen (property)]] "Button2" tekstin tilalle "Exit". Valitse tapahtumat-välilehti ja klikkaa onClick. Klikkaa kolmea pistettä (...) ja sen jälkeen ollaan lähdekoodieditorissa, keskellä toisen Button2:n [[Procedure/fi|aliohjelmaa]]:
  
<syntaxhighlight>
+
<syntaxhighlight lang="pascal">
 
procedure TForm1.Button2Click(Sender: TObject);
 
procedure TForm1.Button2Click(Sender: TObject);
 
begin
 
begin
Line 46: Line 48:
  
 
Painamalla {{keypress|F12}} nähdään lomakkeen Form1 ikkuna uudelleen. Tallenna nyt työsi (ja muista tehdä se usein !!)
 
Painamalla {{keypress|F12}} nähdään lomakkeen Form1 ikkuna uudelleen. Tallenna nyt työsi (ja muista tehdä se usein !!)
valitsemalla päävalikosta Projekti-Tallenna projekti nimellä> sinun_valitsemalla_tiedosto_nimellä. Talletettavana on kaksi erilaista tiedostonimipäätettä (*.pas ja *.lpi). Valitse näille eri nimet. Jos molemmat ovat samannimisiä niin saat "duplicate identifier" käännösvirheen (katso luku "The Lazarus tiedostot" lopussa tämän aiheen lopussa).
+
valitsemalla päävalikosta Projekti-Tallenna projekti nimellä > sinun_valitsemalla_tiedosto_nimellä. Talletettavana on kaksi erilaista [[File_extension/fi|tiedostonimipäätettä]] (*.pas ja *.lpi). Valitse näille eri nimet. Jos molemmat ovat samannimisiä niin saat "duplicate identifier" [[compile-time error/fi|käännösvirheen]] (katso luku "The Lazarus tiedostot" lopussa tämän aiheen lopussa).
  
 
Voit nyt yrittää kääntää. Yksinkertaisin tapa tehdä on valita "Suorita" päävalikon yläreunasta ja sitten "Suorita" vaihtoehto alivalikosta. Vaihtoehtoisesti voit yksinkertaisesti painaa {{keypress|F9}}. Tämä ensin kääntää ja sitten (jos kaikki on hyvin) linkittää sekä suorittaa kyseisen ohjelman.
 
Voit nyt yrittää kääntää. Yksinkertaisin tapa tehdä on valita "Suorita" päävalikon yläreunasta ja sitten "Suorita" vaihtoehto alivalikosta. Vaihtoehtoisesti voit yksinkertaisesti painaa {{keypress|F9}}. Tämä ensin kääntää ja sitten (jos kaikki on hyvin) linkittää sekä suorittaa kyseisen ohjelman.
Line 58: Line 60:
 
=== Muokkaa ohjelmaa ===
 
=== Muokkaa ohjelmaa ===
  
Uudelleen avaa tallennettu projekti. Sen Form1 ikkunassa klikkaa "Press" painiketta (Button1) valitseksesi se. Valitse "Tapahtumat" -välilehti komponenttimuokkaimessa, klikkaa onClick:n oikealla puolella olevaa ruutua, klikkaa kolme pistettä (...), jolloin  siirryt oikeaan kohtaan lähdekoodieditorissa.
+
Uudelleen avaa tallennettu projekti. Sen Form1 ikkunassa klikkaa "Press" painiketta (Button1) valitseksesi se. Valitse "Tapahtumat" -välilehti komponenttimuokkaimessa, klikkaa onClick:n oikealla puolella olevaa ruutua, klikkaa kolmea pistettä (...), jolloin  siirryt oikeaan kohtaan lähdekoodieditorissa.
  
 
Muokkaa kyseinen kohta koodia seuraavanlaiseksi:  
 
Muokkaa kyseinen kohta koodia seuraavanlaiseksi:  
  
<syntaxhighlight>
+
<syntaxhighlight lang="pascal">
 
procedure TForm1.Button1Click(Sender: TObject);
 
procedure TForm1.Button1Click(Sender: TObject);
 
{Hyödynnetään Tag ominaisuutta, se saa arvot 0 tai 1}
 
{Hyödynnetään Tag ominaisuutta, se saa arvot 0 tai 1}
Line 82: Line 84:
 
Loput on sinusta kiinni!
 
Loput on sinusta kiinni!
  
Jos haluat kirjoittaa konsoli(pääte)- tai tekstipohjaisia Pascal ohjelmia (esimerkiksi jos seuraavana on perustiedot Pascal ohjelmoinnista kurssi tai täytyy kirjoittaa ohjelmia joita käytetään eräajona tai järjestelmäohjelmointia), voit silti käyttää Lazarus muokkaamaan , kääntämään ja ajamaan ohjelmia. Katso [[Console Mode Pascal]].
+
Jos haluat kirjoittaa konsoli(pääte)- tai tekstipohjaisia Pascal ohjelmia (esimerkiksi jos seuraavana on perustiedot Pascal ohjelmoinnista kurssi tai täytyy kirjoittaa ohjelmia joita käytetään eräajona tai järjestelmäohjelmointia), voit silti käyttää Lazarus muokkaamaan , kääntämään ja ajamaan ohjelmia. Katso [[Console Mode Pascal/fi|Komentoriviohjelmointi Pascalilla]].
  
  
Line 89: Line 91:
 
Kun käynnistää Lazarus ensimmäistä kertaa niin joukko erillisiä irti olevia tai "kelluvia" ikkunoita näkyy työpöydällä.
 
Kun käynnistää Lazarus ensimmäistä kertaa niin joukko erillisiä irti olevia tai "kelluvia" ikkunoita näkyy työpöydällä.
  
Ensimmäinen, oikealla yläreunassa pitkittäin on otsikoitu "project1 - Lazarus IDE vXXXXXX" (jonka nimi muuttuu vastaamaan nimiä parhaillaan auki olevasta projektista). Tämä on tärkein ikkunan ja se sisältää mm päävalikon ja komponenttipaletin.
+
Ensimmäinen, oikealla yläreunassa pitkittäin on otsikoitu "project1 - Lazarus IDE vXXXXXX" (jonka nimi muuttuu vastaamaan nimiä parhaillaan auki olevasta projektista). Tämä on tärkein ikkuna ja se sisältää mm päävalikon ja [[Component Palette/fi|komponenttipaletin]].
  
 
<center>[[Image:Lazarus-IDE.jpg]]</center>
 
<center>[[Image:Lazarus-IDE.jpg]]</center>
Line 105: Line 107:
  
 
Päävalikko sisältää seuraavat nimikkeet:
 
Päävalikko sisältää seuraavat nimikkeet:
Tiedosto, Muokkaa, Etsi, Näytä, Lähdekoodi, Projekti, Suorita, Paketti, Työkalut, Ikkunat ja Ohje.
+
 
 +
'''<u>T</u>iedosto &nbsp; <u>M</u>uokkaa &nbsp; <u>E</u>tsi &nbsp; <u>N</u>äytä &nbsp; <u>L</u>ähdekoodi &nbsp; <u>P</u>rojekti &nbsp; <u>S</u>uorita-valikko &nbsp; <u>P</u>aketti &nbsp; <u>T</u>yökalut &nbsp; <u>I</u>kkunat &nbsp; <u>O</u>hje'''
  
 
Kuten tavallista, vaihtoehdot voidaan valita joko asettamalla hiiren osoitin valikkokohdan ja klikkaamalla hiiren vasenta painiketta.
 
Kuten tavallista, vaihtoehdot voidaan valita joko asettamalla hiiren osoitin valikkokohdan ja klikkaamalla hiiren vasenta painiketta.
  
==== Tiedosto-valikko ====
+
Lisätietoja saat ottamalla yhteyttä [[Main menu/fi]].
 
 
<div class="floatright"> [[Image:FileMenu.jpg]] </div>
 
* '''Uusi käännösyksikkö''': Luo uuden käännösyksikön (unit)tiedoston  (Pascal koodi).
 
* '''Uusi lomake''': Luo uuden lomakkeen: siis molemmat visuaalinen lomakkeen ja siihen liittyvän käännösyksikön.
 
* '''Uusi ...''': Tarjoaa pop-up-valikon, jolla on mahdollista luoda erilaisia uusia dokumenttityyppejä.
 
* '''Avaa''': Tarjoaa pop-up-valintaikkunan, jolla voidaan navigoida tiedostojärjestelmässä ja valita olemassa tiedosto joka avataan.
 
* '''Palauta''': Hylkää muokatut muutokset ja palauttaa tiedoston sen alkuperäiseen tilaan.
 
* '''Avaa esillä ollut''': Tarjoaa luettelon äskettäin muokattuja tiedostoja ja niistä on mahdollisuus valita yksi.
 
* '''Tallenna''': Tallentaa nykyisen tiedoston käyttäen alkuperäistä tiedostonimeä. Jos sillä ei ole nimeä, järjestelmä kysyy nimeä (kuten Tallenna nimellä).
 
* '''Tallenna nimellä''': Voidaan valita kansio ja tiedostonimi kun tallentaa käytettävän tiedoston.
 
* '''Tallenna kaikki''': Tallentaa kaikki lähdekoodieditorin tiedostot, ei vain yhtä.
 
* '''Vie HTML:nä''': Vie nykyisen tiedoston sisällön uuteen tiedostoon HTML-muodossa.
 
* '''Sulje välilehti''': Sulkee nykyisen tiedoston, varmistaen että tallennetaako kaikki editorin muutokset.
 
* '''Sulje kaikki''': Sulkee kaikki editorin tiedostot. Kysyy tallennetaanko jos jossakin niistä on tallentamatta muutoksia.
 
* '''Siivoa hakemisto''': Tarjoaa dialogin jossa on joukko muokattavissa olevia suodattimia tiedostojen poistamiseksi hakemistossa. Hyödyllisiä *.bak tiedostojen poistoon  ja entisten Delphi projektien jäänteiden poistoon.
 
* '''Tulosta''': Käyttää järjestelmän tulostinta tulostaessa valittua tiedostoa. Tämä valinta ei ehkä näy oletusarvoisesti, jos et käytä windowsia. Jos ei näy niin  sitten täytyy asentaa $Lazdir/components/printers/design/printers4lazide.pas ja kääntää lazarus kehitysympäristö uudelleen.
 
* '''Käynnistä Lazarus uudelleen''': Käynnistää Lazaruksen - hyödyllinen jos tiedostot ovat menneet toivottoman sekaiseksi!
 
* '''Lopeta''': Lopettaa Lazaruksen käytön , varmistaen että kaikki muokatut tiedostot tallennetaan.
 
<div style="clear:both;"></div>
 
 
 
==== Muokkaa-valikko ====
 
 
 
<div class="floatright"> [[Image:EditMenu.jpg]] </div>
 
* '''Kumoa''':  Kumoa viimeisin muokkaus toiminto, jättäen editorin tilaan joka oli juuri ennen viimeistä toimintaa.
 
* '''Tee uudelleen''': Tekee uudelleen viimeisen toiminnon, joka purettiin kumoa valinnalla.
 
* '''Leikkaa''': Poistaa valitun tekstin tai muun kohteen ja asetaa sen leikepöydälle.
 
* '''Kopioi''': Tekee kopion valitusta tekstistä, jättää alkuperäisen paikalleen ja asettamalla kopion leikepöydälle.
 
* '''Liitä''': Asettaa sisällön leikepöydältä osoittimen kohdalle. Jos valittua tekstiä on osoittimen kohdalla, leikepöydän sisältö korvaa valitun tekstin.
 
* '''Valitse''': Mahdollistaa valita tekstilohkoja. Vaihtoehtoja ovat Valitse kaikki, Valitse sulkuun asti, Valitse koodilohko, Valitse sana, Valitse rivi tai Valitse kappale.
 
* '''Sisennä valinta''': Siirrä valittua tekstiä oikealle määrällä joka on määritelty Työkalut -> Asetukset... -> Editori -> Yleistä -> Tab ja sisennys. Tämä ominaisuus on hyödyllinen kun muotoillaan Pascal lähdekoodin lohkorakennetta.
 
* '''Poista valinnan sisennys''':  Poistaa yksi tasoa sisennystä, siirtämällä tekstiä vasemmalle ennalta valitulla määrällä.
 
* '''Valinta isoiksi kirjaimiksi''': Muuntaa valitun tekstin isoiksi kirjaimiksi.
 
* '''Valinta pieniksi kirjaimiksi''': Muuntaa valitun tekstin pieniksi kirjaimiksi.
 
* '''Käännä kirjainten koko valinnassa''': Kääntää valitun tekstin pienet kirjaimet isoiksi ja isot pieniksi.
 
* '''[[IDE_Window:_Sort_selection/fi|Järjestä valinta]]''': Lajittelee rivit (tai sanoja tai kappaleista) aakkosjärjestykseen; vaihtoehtoja nouseva tai laskeva järjestys, kirjainkoko huomioiden tai jätetään huomioitta. Keskellä ohjelman lähdekoodia, ei tietenkään,  ole järkevää, mutta jos on jokin luettelo joka täytyy olla järjestetty niin silloin.
 
* '''Muuta tabit välilyönneiksi valinnassa''': Korvaa valitun tekstin kaikki tabit tietyllä määrällä välilyöntejä joka on määritelty Työkalut -> Asetukset... -> Editori -> Yleistä -> Tab ja sisennys.
 
* '''Rivitä valinta uudelleen''': Jos valitun tekstin rivit ovat pidempiä kuin 80 merkkiä tai luvun joka määritetty kohdassa Työkalut -> Asetukset... -> Editori -> Yleistä -> Näkymä -> Marginaali ja reunapalkki olevan merkkimäärän niin loppurivi jatkuu seuraavalla rivillä .
 
* '''Lisää merkkitaulukosta''': Mahdollistaa näppäimistöltä löytymättömien , kuten aksenttimerkkien, merkkien lisäämisen. Merkki poimitaan "pop-up" ikkunan merkkikartalta.
 
 
 
<div style="clear:both;"></div>
 
 
 
==== Etsi-valikko ====
 
 
 
<div class="floatright"> [[Image:SearchMenu.jpg]] </div>
 
* '''[[IDE_Window:_Find/fi|Etsi]]''': Samanlainen ominaisuus kuin lähes kaikissa graafisissa editoreissa: pop-up valintaikkuna mahdollistaa  merkkijonon etsimisen erilaisilla vaihtoehdoilla, kuten sama kirjaisinkoko, merkkijonon pitää olla kokonainen sana, etsinnän lähtöpiste, etsinnän laajuus ja etsintäsuunta.
 
* '''Etsi seuraava, Etsi edellinen''': Etsii uudelleen aiemmin kirjoitetun merkkijonon, määrättyyn suuntaan.
 
* '''[[IDE_Window:_Find_in_files/fi|Etsi tiedostoista]]''':  Etsii merkkijonon tiedostoista: pop-up dialogi tarjoaa vaihtoehtoja kaikki avoimet tiedostot, kaikki projektin tiedostot tai kaikki hakemistot; läpikäytävien tiedostotyyppien valitsemiseksi voidaan antaa maskeja.
 
* '''Etsi ja korvaa''': Samanlainen kuin '''Etsi'''; näyttää ponnahdusvalintaikkunan jossa on paikka etsittävälle merkkijonolle ja sen korvaavalle merkkijonolle. Etsintää voi rajata erilaisilla vaihtoehdoilla kuten sama kirjaisinkoko, merkkijonon pitää olla kokonainen sana, etsinnän lähtöpiste, etsinnän laajuus ja etsintäsuunta.
 
* '''Etsi kirjain kerrallaan''':Etsii merkkijonon, sitä mukaa kuin kirjoittaa hakusanan. Esimerkki: kun valitset "Etsi kirjain kerrallaan" jos painat "l" ensimmäinen "l" on korostettu. Jos sitten painat "a" niin löydetään seuraavaksi "la" ja niin edelleen.
 
* '''Mene riville''': Siirtää kohdistimen määritellylle tiedoston riville.
 
* '''Hyppää takaisin''': Siirtyy edelliseen paikkaan. Jokakerta kun hyppätään virheeseen tai etsitään määrittely niin kehitysympäristö tallentaa kyseisen paikan. Tämän toiminnon avulla voidaan palata takaisin siihen missä oltiin aikaisemmin.
 
* '''Hyppää eteenpäin''': Siirtyy seuraavaan paikkaan. Kumoaa hyppää takaisin toiminnan.
 
* '''Lisää hyppypiste historiaan''': Lisää tämän hetkisen paikan hyppyhistoriatietoihin.
 
* '''Hyppää seuraavaan virheeseen''', '''Hyppää edelliseen virheeseen''': Hyppää lähdekooditiedoston seuraavaan tai edelliseen raportoituun virheeseen.
 
* '''Aseta vapaa kirjanmerkki''': Merkitse nykyinen rivi jossa kursori sijaitsee seuraavaksi saatavilla (vapaana) olevalla kirjanmerkillä ja lisää tämä kirjanmerkkiluetteloon.  Huomaa, että ponnahdusvalikossa (saadaan klikkaamalla hiiren oikealla näppäimellä lähdekoodieditorissa) on mahdollisesti suurempi joukko kirjanmerkkivalintoja, jolloin kirjanmerkin numeroa on täsmennettävä, tai joiden avulla käyttäjä voi siirtyä numeroituun kirjanmerkkiin, ei vain seuraavan tai aiemmat.
 
* '''Siirry seuraavaan kirjainmerkkiin''', '''Siirry edelliseen kirjainmerkkiin''':  Siirtyy seuraavaan tai edelliseen kirjanmerkkiin numerojärjestyksessä.
 
* '''Etsi koodilohkon toinen pää''':  Jos sijaitaan varatun sanan '''begin''' kohdalla etsitään sitä vastaavaa '''end''':iä tai päinvastoin.
 
* '''Etsi koodilohkon alku''': Siirtyy kyseisen aliohjelman tai funktion varattuun sanaan '''begin''' missä kursori sijaitsee.
 
* '''Etsi määrittely''': Etsii paikkaa, jossa valittu tunniste on määritelty. Tämä voi olla samassa tiedostossa tai toisessa,  editorissa jo avoinna olevassa tiedostossa ja jos tiedosto ei ole auki, se avataan (joten jos aliohjelma tai funktio on esitelty, esimerkiksi tiedostossa <u>classesh.inc</u> niin tämä avataan editoriin). ([[Lazarus_IDE_Tools#Find_Declaration| katso lisätietoa]]).
 
* '''Avaa kursorin osoittama tiedosto''': Avataan tiedosto, jonka nimi on valittu kursoriin. Hyödyllinen kun katsotaan <u>Include </u>  tiedostoja tai tiedostoja, jotka sisältävät projektin muita käännösyksikköjä (<u>Unit </u>) joita siinä on käytetty.
 
* '''Siirry Include määrittelyyn'''':Jos kursori sijaitsee tiedostossa joka sisälletty (<u>Included</u>) toiseen tiedostoon
 
niin se siirtyy tähän tiedostoon missä on tämä <u>Include</u> kutsu.
 
* '''[[IDE_Window:_Find_or_Rename_identifier/fi|Etsi viittauksia tunnisteihin]]''': Tuottaa luettelon kaikista nykyisen tiedoston, nykyisen projektin tai kaikista liitetiedostojen riveistä jossa tunniste on mainittu.
 
* '''Aliohjelma luettelo''': Tuottaa luettelon kaikista aliohjelmista (procedure)ja funktioista (function) rivinumeroineen missä ne on määritelty jotka ovat nykyisessä tiedostossa.
 
<div style="clear:both;"></div>
 
 
 
 
 
==== Näytä-valikko ====
 
 
 
<div class="floatright"> [[Image:ViewMenu.jpg]] </div>
 
Ohjaa näytön eri ikkunoita ja paneeleita ruudulla.
 
 
 
* '''Siirry lomakkeen ja käännösyksikön välillä F12''': Vaihtaa lähdekoodieditorin ja nykyisen lomakkeen välillä ja sijoittaa sen työpöydän pintakerrokseen päällimmäiseksi ja valitsee sen aktiiviseksi. Jos lähdekoodieditori tuli valituksi niin voidaan muokata lähdekoodia; Jos lomake tuli valituksi niin voidaan muokata komponentteja ja muokata lomakkeen muotoa. Helpoin tapa vaihtaa lähdekoodieditorin ja lomakkeen välillä on käyttää F12-näppäintä, mutta sama vaikutus saadaan valitsemalla tämä vaihtoehto päävalikosta.
 
 
 
* '''Komponenttimuokkain''': Ikkuna joka yleensä on työpöydän vasemmalla puolella, näyttää lomakkeen(Form) ominaisuudet joka on työpöydällä. Klikkaamalla hiirellä mitä tahansa komponenttia lomakkeella se aiheuttaa komponentin yksityiskohtien näytön komponenttimuokkaimessa. Yläosassa on paneeli, joka esittää projektin rakenteen puumaisena myös komponentit voidaan valita tässä paneelissa: tämän seurauksena myös vastaavat yksityiskohdat näytetään komponenttimuokkaimessa. Alemman paneelin tärkein asia on kaksi välilehteä, jotka näyttävät '''Ominaisuudet''' ja '''Tapahtumat''' välilehdet. Valitsemalla Ominaisuudet-välilehti niin nähdään ominaisuuksia, kuten nimi, väri, kuvateksti, fontti, koko jne. Siinä näytetään kaksi saraketta, vasenmpi näyttää ominaisuutta ja oikea osoittaa siihen liittyvän arvon. Myös välilehti '''Tapahtumat''' näyttää kaksi saraketta: vasenmalla luetellaan mahdolliset tapahtumat kuten MouseClick tai KeyDown jotka liittyvät kyseiseen komponenttiin. Oikealla näkyy toiminta, joka on kytketty kyseisen tapahtumaan. Jos ei ole toimintaa määritetty, niin se voidaan valita valitsemalla soveltuva kohta tai painamalla {{keypress|...}}-painiketta. Painikkeen {{keypress|...}} aiheuttaa sen että siirrytään lähdekoodieditoriin  ja kohdistin sijoitettu tyhjän aliohjelman (Procedure) sisälle odottamaan tapahtuman määrittelevän koodin kirjoittamista. Kyseiselle aliohjelmalle on tehty kaikki muut vaadittavat määrittelyt.
 
 
 
* '''Lähdekoodieditori''': Pääikkuna, jossa lähdekoodia muokataan. Sen käyttäminen on samantapaista kuin muiden graafisten tekstieditorien: kursorin voi siirtää hiirellä tekstiin, klikkaamalla hiiren vasenta painiketta, vetämällä hiirellä voidaan valita ja korostaa tekstiä. Klikkaamalla hiiren oikeaa painiketta niin näytetään ponnahdusvalikko. Se sisältää mm tavalliset muokkaustoiminnot: leikkaa, kopioi ja liitä. Niiden lisäksi muita toimintoja kuten: Etsi määrittely ja Avaa tiedosto. Lähdekoodieditorin yläosassa on useita välilehtiä, jotka vastaavat tiedostoja, jotka ovat avoinna nykyisessä projektissa. Klikkaamalla välilehteä tuodaan kyseinen tiedosto näkyviin. Näin voidaan siirtyä helposti tiedostosta toiseen, kopioida tiedostojen välillä ja suorittaa suurimman osan normaalista muokkaustoimintoja. Lähdekoodieditori on värillinen koodin syntaksin korostus, jossa tuodaan erivärisenä välimerkit, kommentit, merkkijonovakiot jne. Se myös ylläpitää samaa sisennystä kun kirjoittaessa koodia siirrytään riviltä toiselle. Lähdekoodieditorin toiminnot ja ulkonäkö ovat hyvin monipuolisesti muokattavissa valitsemalla päävalikosta Työkalut->Asetukset -> Editori.
 
 
 
* '''Kääntäjän viestit''': ikkuna, joka näyttää kääntäjän viestejä osoittaa kääntämisen edistymistä onnistuen tai luetellen havaittuja virheitä.
 
 
 
* '''Koodin tutkija''': Ikkuna oletusarvoisesti sijoitettu työpyödän oikealla puolella, se näyttää käytettävän käännösyksikön tai ohjelman koodin rakenteen puun muodossa. Se avautuu yleensä vain näyttäen käännösyksikön nimen ja Interface ja Implementation lohkot, mutta klikkaamalla pientä kolmiota vasemmalla niin avautuu se enemmän ja tarkemmin, kunnes yksittäiset vakiot ja muuttujat näkyvät sekä aliohjelma että funktiomäärittelyt. Jos muutetaan tiedostoa lähdekoodieditorissa, niin täytyy klikata Päivitä-painiketta jotta koodin tutkija näyttää muutetun tiedoston uuden rakenteen.
 
 
 
* '''Näytä käännösyksikön riippuvuudet''': Avaa ikkunan, joka näyttää puumaisella tavalla  avoinna käännösyksikön rakenteen riippuvuudet. Useimmilla lueteltuilla tiedostoilla on riippuvuuksia. Näillä on omat "laajennuskolmiot"
 
jotka näyttävät riippuvuudet. Yksitäistä tiedostoa tutkittaessa, riippuvuudet tulee esiin usein hyvin rekursiivisella tavalla.
 
 
 
* '''Hakutulokset''': ikkuna, joka näyttää tiedostoista haun tulokset.
 
 
 
* '''Virheenjäljitysikkunat''': Avaa ponnahdusvalikonjossa useita vaihtoehtoja virheenjäljittimen käyttöön ja konfigurointiin. Katso [[#Virheenjäljitys]]kappaletta.
 
<div style="clear:both;"></div>
 
 
 
==== Lähdekoodi-valikko ====
 
<div class="floatright"> [[Image:SourceMenu.jpg]] </div>
 
* '''Kommentoi valinta''': Kommentoi valitun tekstin.
 
* '''Poista valinnan kommentti''': Poistaa valitun tekstin kommentointi.
 
* '''Valinnan kommentti päälle/pois''':Kommentoi tai poistaa valitun tekstin kommentoinnin.
 
 
 
* '''Kapseloi valinta...''': Kapseloi valitun tekstin valitun rakenteen sisään kuten esimerkiksi Try...Finally.
 
* '''Kapseloi $IFDEF:n sisään...''': Kapseloi valitun tekstin  IFDEF (Ehdollinen määrittely) rakenteen sisään.
 
* '''täydennä koodi''':
 
* '''Lisää käännösyksikkö uses-lauseeseen...''': Lisää yhden tai useamman käännösyksikön uses-lauseeseen.
 
* '''Järjestele uudelleen''': Avaa järjestele uudelleen alavalikon.
 
* '''Nopea kieliopin tarkistus''': Suorittaa nopean kieliopin tarkistuksen.
 
* '''Arvaa sulkematta jäänyt lohko''': Antaa editorin lopettaa suljettu lohko, kuten puuttuva "End" käytettäessä "If" lausetta. 
 
* '''Arvaa väärinsijoitettu IFDEF/ENDIF''': Antaa editorin korjata puuttuva ehdollinen määrittely.
 
* '''Liitä CVS-sana...''': Liittää  CVS-avainsanan, kuten "Author" tai "Date".
 
* '''Liitä kenttiä''': Liittää yleisiä arvoja kuten "GPL ilmoitus".
 
* '''Lisää tiedoston koko nimi...''': Valitaan tiedosto jonka nimi polkuineen lisätään.
 
* '''Lisää ToDo-merkintä''': Lisää ToDo-kommentin.
 
* '''Käännösyksikön tietoja...''': Näyttää tietoja käännösyksiköstä.
 
* '''JEDI Code Format''': Näyttää JEDI Code Format optiot projektista.
 
 
 
==== Projekti-valikko ====
 
<div class="floatright"> [[Image:ProjectMenu.jpg]] </div>
 
 
 
* '''Uusi projekti''': Luo uuden projektin. Ponnahdusikkuna avautuu josta valitaan minkä tyyppinen projekti on.
 
 
 
* '''Luo uusi projekti tiedostosta''':  Navigation valintaikkuna avautuu, sallien valita tiedoston, josta luodaan uusi projekti.
 
 
 
* '''Avaa projekti''' Avaa projektin, joka on jo luotu ja tallennettu. Valintaikkuna näkyy luettelona kyseisen kansion Lazarus Project Information (.lpi) tiedostoja, joista projekti voidaan valita.
 
* '''Avaa esillä ollut Projekti''': Näyttää pop-up luettelon viimeaikaisista projekteista, joita on aikaisemmin avattu Lazaruksessa ja mahdollistaa valinta yhden näistä.
 
* '''Sulje projekti''' Sulkee avoinna olevan projektin.
 
* '''Tallenna projekti''': Samanlainen kuin Tiedosto -> Tallenna: kaikki avoinna olevan projektin tiedostot tallennetaan; jos niitä ei ole aiemmin tallennettu, kysytään tiedostonimi - samanlailla kuin "Tallenna projekti nimellä..." .
 
* '''Tallenna projekti nimellä...''': Kysyy projektin tiedostonimeä jolla se tallennetaan . Oletuksena tiedostonimi on Project1.lpi, mutta olisi parempi valita sovellusta kuvaavampi tiedostonimi. Lazarus ei salli että käytettäisiin samaa nimeä projektin ja käännösyksikön tiedostoniminä (katso [[Lazarus Tutorial/fi#Lazarus_tiedostot| alla ]]).
 
 
 
* '''Julkaise projekti...''':  Luo kopion koko projektista. Jos haluat lähettää jollekin vain lähdekoodin ja kääntäjän asetukset, tämä toiminto on ystäväsi. Normaali projektikansio sisältää paljon tietoa. Suurinta osaa siitä ei tarvitse julkaista: Tällä .lpi tiedosto sisältää istunnon tiedot (kuten kursorin asema ja suljettujen käännösyksikköjen kirjaimerkit) ja projektikansio sisältää paljon .ppu, .o tiedostoja ja ajettavan tiedoston. "Julkaise projektin" luomma lpi tiedosto sisältää  vain perustietoa ja  lähdekoodia sekä alikansioita. Dialogissa voidaan asettaa sulkevan poistosuodattimen ja sisältävän lisäyssuodattimen ja komennolla "komento jälkeen" voit pakata tuotoksen yhdeksi arkistotiedostoksi. Katso [[Lazarus_IDE_Tools/fi|Lazarus IDE Työkalut]]
 
* '''[[IDE_Window:_Project_Inspector/fi|Projektin hallinta]]''':  Avaa ikkunan jossa puumainen näyttö projektin tiedostoista. Voidaan lisätä, poistaa tai avata valittuja tiedostoja tai siirtyä muuttamaan projektin asetuksia.
 
* '''[[IDE_Window:_Project_Options/fi|Projektikohtaiset asetukset ...]]''': Avaa ikkunan jossa voi asettaa projektin asetuksia tai kääntäjän asetuksia. Asetus mahdollisuuksia on monia: sovellus (nimi, kuvake), lomakkeet (josta voidaan valita käytettävissä olevista lomakkeista ovatko ne sovelluksen alussa automaattisesti luotavia) ja istunto ( mitä istuntokohtaisia tietoja tallennetaan).  Kääntäjän asetukset sisältävät: Hakupolut joka mahdollistaa määritellä hakupolkuja käännösyksikköille, include tiedostoille, kirjastoille jne. Jäsennys joka mahdollistaa valinnan sääntöjä lähdekoodin jäsentämiseen. Käännös ja linkitys joka mahdollistaa valinnan koodin optimointiin: nopeammin tai pienempiä ohjelmia, keon ja pinon kokoa jne. Virheenjäljitys mahdollistaa päätettäväksi, miten käyttää virheenjäljitystä.
 
* '''Lisää aktiivinen tiedosto projektiin''': Lisää muokattavan tiedoston projektiin.
 
* '''Poista projektista''': Avaan Luettelo projektin kaikista käännösyksiköistä joita voi poistaa.
 
* '''Käännösyksiköt...''': Luettelo projektin kaikista käännösyksiköistä.
 
* '''Lomakkeet...''': Luettelo projektin kaikista lomakkeista.
 
* '''Näytä projektin lähdekoodi''': Ei ole väliä mitä tiedostoa muokataan vaan siirrytään pääohjelman lähdekooditiedostoon (yleensä .lpr tai sitten .pas tiedosto).
 
 
 
==== Suorita-valikko ====
 
<div class="floatright"> [[Image:RunMenu.jpg]] </div>
 
* '''Käännä''': Kääntää projektin kaikki tiedostot.
 
* '''Kokoa''': Kokoaa projektin kaikki tiedostot.
 
* '''Nopea käännös''': Kääntää projektin ne tiedostot jotka ovat muuttuneet.
 
* '''[[IDE_Window:_Clean_up_build_files_dialog|Siivoa ja kokoa...]]'''
 
* '''Keskeytä kokoaminen''': Keskeyttää kokoamisen, käytetään kun se on käynnissä silloin kuin olet muistanut, että teit jotain typerää ja haluat lopettaa kokoamisen tai järjestelmä näyttää ottavan liian kauan aikaa ja jotain on selvästi väärin.
 
* '''Suorita''': Tämä on tavanomainen tapa käynnistää kääntäjä ja jos kokoaminen onnistuu se käynnistää sovelluksen suorittamisen. Se mitä todella tapahtuu on, että Lazarus tallentaa tiedostot, alkaa sitten kääntämään ja lopuksi linkkaa, kun ne suoritettu niin käynnistää juuri nyt käännetyn ohjelman.
 
* '''Keskeytä''': Keskeyttää käynnissä olevan ohjelman suorituksen. Tämä saattaa mahdollistaa tarkastaa kaikki joka on luot output virtaan,  suoritusta voidaan jatkaa valitsemalla Suorita uudelleen.
 
* '''Näytä suorituspiste''': Näyttää nykyisen suorituksen kohdan.
 
* '''Askella sisään''': Käytetään virheenjäljityksen yhteydessä, aiheuttaa ohjelman toteuttamisen yksi askel kerrallaan  kirjanmerkittyyn kohtaan lähdekoodissa.
 
* '''Askella yli''':Aiheuttaa vaiheittaisen toteutuksen, ohittaa alatason toteutuksen jossa suoritus jatkuu normaalilla nopeudella. Hyödyllinen yrittäessä paikantaa lausetta jossa on looginen virhe.
 
* '''Askella ulos''': Nousee lohkotasolla ylöspäin.
 
 
 
* '''Jatka kursorin kohtaan''': Etenee ohjelmassa normaalilla nopeudella (eli ei yksi lause kerrallaan), kunnes kohta on saavutettu, missä kohdistin sijaitsee tai nykyisestä aliohjelmasta poistutaan; sitten pysähtyy. Ei pysähdy, jos sijainti on saavutettu rekursion aikana. Suoritusta voidaan jatkaa normaalinopeudella valitsemalla '''Suorita'''.
 
* '''Pysäytä''':  Lopettaa käynnissä olevan ohjelmaan suorituksen. Ei voida jatkaa valitsemalla '''Suorita''', Tämä käynnistää ohjelman uudelleen alusta (ja tekee uudelleen kokoamiseen tarvittaessa).
 
* '''[[IDE_Window:_Run_parameters|Suoritus parametrit]]''':
 
Avaa monisivuisen ikkunan, jonka avulla komentorivivalitsimia ja parametrejä välitetään ohjelman suoritettavaksi; mahdollistaa näytön valinnan missä ohjelma ajetaan (esim etäkäyttöinen X-pääte voidaan käyttää Linuxissa); joitakin järjestelmän ympäristömuuttujia voidaan ohittaa. Yksi tärkeä käyttö tässä alivalikossa on aktivoida pääteikkunaa jossa tavanomainen Pascal konsolin (päätteen) input / output näytetään. Jos kehitetään konsoli-tilassa toimivia Pascal ohjelmia (eli sellaisia jotka eivät käytä graafista käyttöliittymää ja sen lomakkeita, painikkeita ja laatikoita) sitten sinun pitäisi tarkistaa valintaruutu "Käytä käynnistävää ohjelmaa". Kun ensimmäisen kerran tehdä tämän ja yrittää "Käännä / Suorita" komentojensarjaa, saanet todennäköisesti "töykeän" viestin:
 
"xterm: Can't execvp /usr/share/lazarus//tools/runwait.sh: Permission denied". 
 
Jos näin tapahtuu, niin täytyy muuttaa tiedoston käyttöoikeuksia sopivaksi (esimerkiksi käyttämällä chmod + x ''tiedostonimi'' tai Windowsin apuohjelmaa käyttöoikeuksien muuttamista); ehkä tämä täytyy tehdä root oikeuksilla. Tämän jälkeen joka kerta kun käynnistää ohjelman, konsoli aukeaa ja kaikki teksti I / O (readln, writeln ym) ilmestyy siihen.
 
Kun ohjelma on päättynyt suorituksen, viesti "Press Enter" ilmestyy näyttöön. Niinpä mikä tahansa ohjelmalla luotu ulostulo pysyy näytöllä, kunnes olet ehtinyt lukea sen; kun painat {{keypress|Enter}} niin konsoli-ikkuna sulkeutuu.
 
Katso erillinen opetusohjelma[[Console Mode Pascal| Pascal ohjelmointi päätetilassa]].
 
 
* '''Nollaa virheenjäljitin''':  Palauttaa virheenjäjittimen alkuperäiseen tilaansa, niin että raja-arvot ja muuttujien arvot jne unohdetaan.
 
 
 
* '''Kokoa tiedosto''': Kokoaa tiedoston, joka on editorissa avoinna.
 
* '''Suorita tiedosto''': Kääntää, linkittää ja ajaa tiedoston, joka on editorissa avoinna.
 
 
 
* '''[[IDE_Window:_Configure_Build_file|Konfiguroi kokoa + Suorita tiedosto]]''': Avaa monisivuisen välilehtiä sisältävän ikkunan jossa on vaihtoehtoja, joita käytetään kun valitaan kokoa tiedosto tai suorita tiedosto valinta. Muun muuassa mahdollistaa työkansion valinnan, voidaan käyttää erilaisia makroja jne. Sitten rakentaa ja suorittaa tiedosto .
 
 
 
Näillä kolmella viimeisellä vaihtoehdon avulla voidaan avata (ja ylläpitää) testausprojektia. Käytä Tiedosto -> Avaa avata .lpr tiedosto painamalla peru ja seuraava dialogi avaa tiedoston "normaalina" lähdekooditiedostona.
 
 
 
* '''Tutki...''': Tutkii arvon, kun ohjelma on keskeytetty.
 
* '''Arvioi/Muuta...''': Arvioi tai muuttaa lausekkeen tai arvon, kun ohjelma on keskeytetty.
 
* '''Lisää vahti...''':  Lisää muuttuja tarkkailuluetteloon.
 
* '''Lisää keskeytyskohta...''': Lisää keskeytyskohdan, joka keskeyttää ohjelman suorituksen kyseisellä koodirivillä.
 
 
 
<div style="clear:both;"></div>
 
 
 
==== Paketti-valikko ====
 
 
 
<div class="floatright"> [[Image:PackageMenu.jpg]] </div>
 
* '''[[IDE_Window:_Package_Editor|Uusi paketti...]]''': Luo uuden paketin.
 
* '''Avaa jo ladattu paketti...''': Avaa yhden valitun paketin tiedostot.
 
* '''Avaa pakettitiedosto (.lpk)...''':Avaa valitun pakettitiedoston (.lpk) ja siirtyy [[IDE_Window:_Package_Editor/fi|Pakettimuokkaimeen]]
 
* '''Avaa aktiivisen käännösyksikön paketti''':Avaa aktiivisen käännösyksikön paketin ja siirtyy [[IDE_Window:_Package_Editor/fi|Pakettimuokkaimeen]].
 
* '''Avaa esillä ollut paketti''': Avaa paketin joka avattiin hiljattain.
 
* '''Lisää aktiivinen tiedosto pakettiin...''': Aseta tiedosto (joka on tällä hetkellä editorissa) pakettiin.
 
* '''Uusi Komponentti''': Luo uuden komponentin.
 
* '''[[IDE_Window:_Package_Graph|Pakettikuvaaja...]]''': Näyttää osoittaen pakkausten suhteet  jotka ovat tällä hetkellä käytössä (jos et käytä muita paketteja, Lazarus paketti ja FCL sekä LCL näytetään).
 
* '''[[IDE_Window:_Installed_Packages|Asenna/Poista Paketteja...]]''': Asentaa/Poistaa yhden tai useamman paketin.
 
 
 
==== Työkalut-valikko ====
 
<div class="floatright"> [[Image:ToolsMenu.jpg]] </div>
 
* '''[[IDE_Window:_IDE_Options_Dialog|Asetukset...]]''': Näyttää ja muuttaa eri vaihtoehtoja ja asetuksia Lazarus kehitysympäristössä.
 
* '''Lue uudelleen FPC-lähdekoodit''' käy uudelleen hakemiston lävitse. Lazarus käyttää FPC lähdekoodia tuottaakseen oikeat tapahtumankäsittelijät ja etsiessään määrittelyitä. Jos joku muuttaa hakemistoa käyttöympäristöasetuksissa, niin tämä hakemisto on skannattava uudelleen, varmistamaab että Lazarus käyttää sitä versiota jota säilytetään kyseisessä paikassa. Mutta jos tämä hakemisto on muuttunut ilman että Lazarus huomaa sen, niin voidaan saada joitakin virheitä suunniteltaessa lomakkeita tai tehtäessä "Etsi määrittely" etsintä. Jos tulee tällainen virhe niin voidaan tehdä kaksi asiaa:
 
*# Tarkistaa FPC lähdehakemisto asetus käyttöympäristöasetuksissa.
 
*# Lue uudelleen FPC-lähdekoodit.
 
* '''[[IDE_Window:_Code_Templates|Koodimallit...]]''': Näyttää koodimalleja, jotka ovat käytettävissä.
 
* '''CodeTools määritysten muokkain...''': Muokkaa CodeTools määrityksiä.
 
* '''[[Project_Templates|Project templates options...]]''': Asettaa project templates vaihtoehdot.
 
* '''[[IDE_Window:_External_Tools|Muokkaa ulkoisia työkaluja''':  Käyttäjä voi lisätä erilaisia ulkoisia työkaluja (yleensä makroja)
 
* '''Esimerkki projektit...''': Näyttää esimerkki projektit, jotka ovat käytettävissä.
 
* '''Vertaa tiedostoja''': Mahdollistaa kahden tiedoston vertailun (tai, tavallisesti, kahta eri versiota samasta tiedostosta) jotta nähdään niiden  erot.  Vaihtoehtoina on mmm jättää huomioimatta erilaiset välilyöntien määrät rivin alussa tai lopussa tai rivin päättymisen eroista: CR + LF vs. LF.    Hyödyllinen kun tarkistaa, jos on tapahtunut muutoksia viime versiohallinnan päivityksen jälkeen jne.
 
* '''[[IDE_Window:_Change_Encoding_Dialog|Muunna projektin/ paketin merkistökoodaus...]]''':
 
* '''Tarkista edistorissa oleva LFM tiedosto''': Mahdollistaa tarkastaa LFM tiedosto, joka sisältää asetuksia, jotka määritelty nyt valitulla lomakkeella.
 
* '''Delphi muunnos''': sisältää alivalikon. Katso [[Lazarus For Delphi Users]] ja [[Code Conversion Guide]].
 
** '''Muunna Delphi käännösyksikkö Lazarukselle'''
 
** '''Muunna Delphi projekti Lazarukselle'''
 
** '''Muunna Delphi Paketti Lazarukselle''':
 
** '''Muunna binaarinen DFM-tiedosto teksti-LFM:ksi ja tarkista kielioppi'''
 
* '''Kokoa Lazarus käyttäen profiilia: Normaali IDE''':  Aloittaa uudelleen rakentamaan Lasaruksen viimeksi ladatuista tai päivitetyistä SVN tiedostoista. Paina nappia ja istu katsomaan mitä tapahtuu! (prosessin seuraaminen onnistuu Viestit-ikkunassa).
 
* '''Konfiguroi "Lazaruksen kokoaminen"''': Sallii käyttäjän määrittää, mitkä Lazarus osat uudelleen rakennetaan ja miten. Esimerkiksi, voidaan valita että vain LCL uudelleen rakennetaan, tai rakennetaan kaikki paitsi esimerkkit; voidaan valita mitä rajapintaa LCL käyttää (eli mitä joukkoa widgettejä) ja voidaan valita kohde käyttöjärjestelmä ja määrittää eri kohdekansio.
 
<div style="clear:both;"></div>
 
 
 
==== Ikkunat-valikko ====
 
<div class="floatright"> [[Image:WindowMenu.jpg]] </div>
 
Sisältää luettelon tällä hetkellä avattujen tiedostojen ja käytettävissä olevia ikkunoita kuten lähekoodieditori, komponenttimuokkain ja projektin hallinta. Klikkaamalla yhden ikkunan nimeä niin tuo sen edustalle ja laittaa sen aktiiviseksi.
 
<div style="clear:both;"></div>
 
 
 
==== Ohje-valikko ====
 
<div class="floatright"> [[Image:HelpMenu.jpg]] </div>
 
* '''Mukana oleva avustus''' joka nykyisin avaa selainikkunan, joka sisältää kuvan juoksevasta gepardista ja muutamia linkkejä Lazarus, Free Pascal ja Wiki sivustoille
 
* '''Virheen raportointi''' Avaa  [[How_do_I_create_a_bug_report|wiki sivun]], joka kuvaa kuinka tehdään virheraportointi
 
* '''Tietoja Lazaruksesta''' Näyttää ikkunassa joitakin tietoja  Lazaruksesta mm. kertoo mikä versio on kyseessä.
 
 
 
* '''Configure Help''' which opens a pop-up menu with options to select viewers and databases from which to read Help information.  This option allows the user to specify either the on-line documents section of the Lazarus-CCR website, some other website containing the documents, or a local store for the documentation (this would eventually become the default, when the Help system is fully developed).
 
At present by default, if you place your Editor cursor over any keyword from the Free Pascal Components Library FCL, the RunTime Library RTL or the Lazarus Components Library LCL, and then press {{keypress|F1}} you will be taken by your default browser to the appropriate definition on the website. Be aware that your browser may be located on another desktop on your machine (eg in Linux), and you may not see the information immediately; of course if you are not connected to the internet you cannot get this information.
 
 
 
There are alternative help options which gives the end-user off-line help. For example, if you have a copy of Kylix, you can reuse the help files supplied with it, inside Lazarus IDE. See the [[Adding Kylix Help]] page for details.
 
  
 
Eventually there will be a full on-line Help service, with information about Pascal syntax, the use of the IDE, how to use, modify or create Components, and hints on how to perform certain tasks.  This part of the Documentation section (the thing you are currently reading) represents the beginning of the process. '''We need contributions from anyone who feels able to provide them: the WiKi is very easy to edit.'''
 
  
 
== Pikapainikkeet ==
 
== Pikapainikkeet ==
  
Pieni työkalurivi pääikkunan vasemmalla puolen, päävalikon  alapuolelle jonka vasemmalla puolen on komponenttipaletti. Se sisältää joukon painikkeita, jotka ovat samoja kuin usein käytetyt päävalikon valinnat:
+
Pieni työkalurivi pääikkunan vasemmalla puolen, päävalikon  alapuolelle jonka vasemmalla puolen on komponenttipaletti. Se sisältää joukon painikkeita, jotka ovat samoja kuin usein käytetyt päävalikon valinnat: Uusi käännösyksikkö, Avaa (jossa on alas-nuolta painamalla saadaan näyttämään avattavan listan viimeksi käytetyistä tiedostoista), Tallenna, Tallenna kaikki, Uusi lomake, Vaihda lomake / käännösyksikkö (eli näyttää joko lomakkeen tai käännösyksikön lähdekoodia), Näytä käännösyksiköt, Näytä lomakkeet, Suorita (eli kokoa ja suorita), Pysäytä, Askella sisään, Askella yli (kaksi viimeistä ovat virheenjäjityksen toimintoja).  
Uusi käännösyksikkö, Avaa (jossa on alas-nuolta painamalla saadaan näyttämään avattavan listan viimeksi käytetyistä tiedostoista), Tallenna, Tallenna kaikki, Uusi lomake, Vaihda lomake / käännösyksikkö (eli näyttää joko lomakkeen tai käännösyksikön lähdekoodia), Näytä käännösyksiköt, Näytä lomakkeet, Suorita (eli kokoa ja suorita), Pysäytä, Askella sisään, Askella yli (kaksi viimeistä ovat virheenjäjityksen toimintoja).  
 
  
  
 
== Komponenttipaletti ==
 
== Komponenttipaletti ==
 +
{{:Component Palette/fi}}
  
Välilehtiä sisältävä työkalurivi, joka näyttää useita kuvakkeita, jotka edustavat yleisesti käytettyjä komponentteja lomakkeen rakentamiseen.
 
 
Jokainen välilehti näyttää eri joukon kuvakkeita, jotka edustavat saman funktionaalisen ryhmän komponentteja. Kullakin välilehdellä äärimmäisenä vasemmalla on kuvake jossa on vinosti vasemmalle osoittava nuoli on nimeltään valintatyökalu.
 
 
Jos hiiren osoitin on komponenttipaletilla jonkin kuvakkeen päällä ilman että kuvaketta klikataan niin esiin tulee ponnahdusteksti 8vihjeteksti) jossa on komponentin nimi. Huomaa, että jokainen nimi alkaa "T" - kirjaimella. Tämä tarkoittaa komponentin "tyyppiä" tai tarkemmin "luokkaa". Kun valitaan komponentti sisällytettäväksi lomakkeelle [[Class|luokka]] lisätään [[Type|tyypin]] esittelylohkoon [[Unit/fi|käännösyksikön]] ''' [[Interface|interface]] '''  osaan(yleensä osana TForm1).  Tämän luokan olio lisätään muuttujien esittelylohkoon [[Var/fi|var]] (se on usein Form1 niminen  muuttuja). Metodeja, joita suunnitellaan käyttämään lomaketta tai sen osia (esim [[Procedure/fi|aliohjelmia]] tai [[Function|funktiota]] ) sijoitetaan sen käännösyksikön '''[[Implementation|implementation]] ''' osaan.
 
 
 
==== Kuinka käytetään komponenttipalettia ====
 
 
Jos haluat käyttää komponenttipalettia on oltava avoin lomake näkymä editorissa (jos sellaista ei ole, valitse Tiedosto -> Uusi lomake). Klikkaa komponentin kuvaketta jota halutaan käyttä komponenttipaletin asianmukaisella välilehdellä, klikkaa lomaketta lähellä sitä paikkaa, jossa haluat komponentin näkyvän. Kun haluttu komponentti tulee näyttöön, voit valita sen klikkaamalla hiirellä. Kun valittu lomake, komponentti on valittu myös komponenttimuokkaimeen, jossa voit muokata sen ominaisuuksia ja tapahtumia.
 
 
Komponentin "ulkoasun" muutokset voidaan tehdä joko muuttamalla sen näkymää hiirellä lomakkeella tai muuttamalla komponentin ominaisuuksia komponenttimuokkaimella.
 
 
Jos asennetaan lisäkomponentteja, joko itse kirjoittamia tai jotain muita jotka tulevat pakettina muusta lähteestä, sitten komponenttipaletille tulee ylimääräisiä välilehtiä ja  kuvakkeita. Nämä uudet komponentit voidaan valita ja käyttää lomakkeella samalla tavalla kuin oletuksena toimitetut.
 
 
Seuraavassa on luettelo komponenteista, löydät linkkejä tiedostoihin, jotka sisältävät määrittelyt. Käännösyksiköt, joissa ne löytyvät. Jos haluat tietää tietyn komponentin  ominaisuuksia, on usein syytä tarkastella mistä kyseinen komponentti on peritty ja sitten tarkastaa myös sen ominaisuuksia. Esimerkiksi jotta ymmärtää TMaskEdit on myös hyödyllistä tutkia TCustomMaskEdit.
 
 
 
==== [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/index-4.html Standard] ====
 
Katso [[Standard tab/fi|Standard-välilehdeltä]] komponenttien kuvaukset.
 
<center>[[Image:Component_Palette_Standart.png]]</center>
 
:''Frequently used components:'' [http://lazarus-ccr.sourceforge.net/docs/lcl/menus/tmainmenu.html TMainMenu], [http://lazarus-ccr.sourceforge.net/docs/lcl/menus/tpopupmenu.html TPopupMenu], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tbutton.html TButton], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tlabel.html TLabel], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tedit.html TEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tmemo.html TMemo], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/ttogglebox.html TToggleBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tcheckbox.html TCheckBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tradiobutton.html TRadioButton], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tlistbox.html TListBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tcombobox.html TComboBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tscrollbar.html TScrollBar], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tgroupbox.html TGroupBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tradiogroup.html TRadioGroup], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tcheckgroup.html TCheckGroup], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tpanel.html TPanel], [http://lazarus-ccr.sourceforge.net/docs/lcl/actnlist/tactionlist.html TActionList]
 
 
==== [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/index-4.html Additional] ====
 
Katso [[Additional tab/fi|Additional-välilehdeltä]] komponenttien kuvaukset.
 
<center>[[Image:Component_Palette_Additional.png]]</center>
 
:''More, often-used components:'' [http://lazarus-ccr.sourceforge.net/docs/lcl/buttons/tbitbtn.html TBitBtn], [http://lazarus-ccr.sourceforge.net/docs/lcl/buttons/tspeedbutton.html TSpeedButton], [http://lazarus-ccr.sourceforge.net/docs/lcl/stdctrls/tstatictext.html TStaticText], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/timage.html TImage], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tshape.html TShape], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tbevel.html TBevel], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tpaintbox.html TPaintBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tnotebook.html TNotebook], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tlabelededit.html TLabeledEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tsplitter.html TSplitter], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/ttrayicon.html TTrayIcon], [http://lazarus-ccr.sourceforge.net/docs/lcl/maskedit/tmaskedit.html TMaskEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/checklst/tchecklistbox.html TCheckListBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/forms/tscrollbox.html TScrollBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/forms/tapplicationproperties.html TApplicationProperties], [http://lazarus-ccr.sourceforge.net/docs/lcl/grids/tstringgrid.html TStringGrid], [http://lazarus-ccr.sourceforge.net/docs/lcl/grids/tdrawgrid.html TDrawGrid], [http://lazarus-ccr.sourceforge.net/docs/lcl/pairsplitter/tpairsplitter.html TPairSplitter], [http://lazarus-ccr.sourceforge.net/docs/lcl/colorbox/tcolorbox.html TColorBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/colorbox/tcolorlistbox.html TColorListBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/chart/index.html TChart]
 
 
==== [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/index-4.html Common Controls] ====
 
 
Katso [[Common Controls tab/fi|Common-välilehdeltä]] komponenttien kuvaukset.
 
 
<center>[[Image:Component_Palette_Common_Controls.png]]</center>
 
:[http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/ttrackbar.html TTrackBar], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/tprogressbar.html TProgressBar], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/ttreeview.html TTreeView], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/tlistview.html TListView], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/tstatusbar.html TStatusBar], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/ttoolbar.html TToolBar], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/tupdown.html TUpDown], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/tpagecontrol.html TPageControl], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/ttabcontrol.html TTabControl], [http://lazarus-ccr.sourceforge.net/docs/lcl/comctrls/theadercontrol.html THeaderControl], [http://lazarus-ccr.sourceforge.net/docs/lcl/controls/timagelist.html TImageList], [http://lazarus-ccr.sourceforge.net/docs/lcl/popupnotifier/index.html TPopupNotifier]
 
 
==== [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/index-4.html Dialogs] ====
 
Katso [[Dialogs tab/fi|Dialogs-välilehdeltä]] komponenttien kuvaukset.
 
 
<center>[[Image:Component_Palette_Dialogs.png]]</center>
 
:[http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/topendialog.html TOpenDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/tsavedialog.html TSaveDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/tselectdirectorydialog.html TSelectDirectoryDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/tcolordialog.html TColorDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/tfontdialog.html TFontDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/tfinddialog.html TFindDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/treplacedialog.html TReplaceDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/extdlgs/topenpicturedialog.html TOpenPictureDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/extdlgs/tsavepicturedialog.html TSavePictureDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/extdlgs/tcalendardialog.html TCalendarDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/extdlgs/tcalculatordialog.html TCalculatorDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/tcustomprintersetupdialog.html TPrinterSetupDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/tcustomprintdialog.html TPrintDialog], [http://lazarus-ccr.sourceforge.net/docs/lcl/dialogs/tcustomprintersetupdialog.html TPageSetupDialog]
 
 
Useita hyödyllisiä '''[http://lazarus-ccr.sourceforge.net/index.php?wiki=DialogExamples Dialog]'''  aliohjelmia tai funktioita eivät näy komponenttipaletilla, mutta niitä voi helposti käyttää kutsumalla suoraan lähdekoodista.
 
 
Useita hyviä esimerkkejä komponenttien käytöstä näkee $LazarusPath/lazarus/examples alihakemistosta. Monet ohjelmat osoittavat, kuinka käyttää dialogeja ja muita komponentteja suoraan käyttämättä komponenttipalettia tai erillistä lomake määrittelytiedostoa: kaikki osat ovat täysin ja yksiselitteisesti määritelty Pascal:n pääohjelmassa. Muut esimerkki ohjelmat hyödyntävät kehitysympäristöä
 
 
Muista avata näitä esimerkkejä projekteista jossa .lpi tiedosto. Avaamalla .pas lähdekooditiedoston ja ajamalla se suorita käskyllä vain liittää tämän lähdetiedoston viimeiseksi avattuun projektiin.
 
 
Jokin esimerkkeistä eivät toimi heti: voit joutua muuttaa polkuja ja käyttöoikeuksia tiedostoissa tai hakemistoissa. Jos haluat koota mitä tahansa esimerkeistä, varmista, että olet antanut tiedostoille ja hakemistoille lukuun / kirjoittamiseen / ajoon käyttöoikeudet  tai kopioi tiedostot hakemistoon, jossa on riittävät käyttöoikeudet.
 
 
Kokeile käynnistää "testall" ohjelma nähdäksesi valikon käytettävistä komponenteista. Testauslomakkeen yhteydessä on pieni esimerkki  useimmista. Sitten voit tarkastella koodin ja selvittää miten ne toimivat!
 
 
==== [[Misc tab|Misc]] ====
 
<center>[[Image:Component_Palette_Misc.png]]</center>
 
:[http://lazarus-ccr.sourceforge.net/index.php?wiki=DialogsTxt TColorButton], [http://lazarus-ccr.sourceforge.net/docs/lcl/spin/tspinedit.html TSpinEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/spin/tfloatspinedit.html TFloatSpinEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/arrow/tarrow.html TArrow], [http://lazarus-ccr.sourceforge.net/docs/lcl/calendar/tcalendar.html TCalendar], [http://lazarus-ccr.sourceforge.net/docs/lcl/editbtn/teditbutton.html TEditButton], [http://lazarus-ccr.sourceforge.net/docs/lcl/editbtn/tfilenameedit.html TFileNameEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/editbtn/tdirectoryedit.html TDirectoryEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/editbtn/tdateedit.html TDateEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/editbtn/tcalcedit.html TCalcEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/filectrl/tfilelistbox.html TFileListBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/xmlpropstorage/txmlpropstorage.html TXMLPropStorage], [http://lazarus-ccr.sourceforge.net/docs/lcl/inipropstorage/tinipropstorage.html TIniPropStorage], [http://lazarus-ccr.sourceforge.net/docs/lcl/chart/tbarchart.html TBarChart], [http://lazarus-ccr.sourceforge.net/docs/lcl/buttonpanel/tbuttonpanel.html TButtonPanel], TIDEDialogLayoutStorage
 
 
==== [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/index-4.html Data Controls] ====
 
<center>[[Image:Component_Palette_DataControls.png]]</center>
 
: ''Data-tietoisia komponentteja, jotka suurelta osin toistavat Standard ja Additional ryhmiä, mutta ovat sovellettavissa tietokantoihin:''[http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbnavigator.html TDBNavigator], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbtext.html TDBText], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbedit.html TDBEdit], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbmemo.html TDBMemo], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbimage.html TDBImage], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdblistbox.html TDBListBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbcombobox.html TDBComboBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbcheckbox.html TDBCheckBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbradiogroup.html TDBRadioGroup], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbcalendar.html TDBCalendar], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbctrls/tdbgroupbox.html TDBGroupBox], [http://lazarus-ccr.sourceforge.net/docs/lcl/dbgrids/tdbgrid.html TDBGrid]
 
 
==== [[Data Access tab]] ====
 
<center>[[Image:Component_Palette_DataAccess.png]]</center>
 
: TDatasource, TMemDataset, TSdfDataSet, TFixedFormatDataSet, [[Lazarus Tdbf Tutorial|TDbf]]
 
 
==== [[System tab]] ====
 
<center>[[Image:Component_Palette_System.png]]</center>
 
:[http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/ttimer.html TTimer], [http://lazarus-ccr.sourceforge.net/docs/lcl/extctrls/tidletimer.html TIdleTimer], [http://lazarus-ccr.sourceforge.net/docs/lcl/lresources/tlazcomponentqueue.html TLazComponentQueue], [http://lazarus-ccr.sourceforge.net/docs/lcl/lazhelphtml/thtmlhelpdatabase.html THtmlHelpDatabase], [http://lazarus-ccr.sourceforge.net/docs/lcl/lazhelphtml/thtmlbrowserhelpviewer.html THtmlBrowserHelpViewer], [http://lazarus-ccr.sourceforge.net/docs/lcl/asyncprocess/tprocessutf8.html TProcessUTF8], [http://lazarus-ccr.sourceforge.net/docs/lcl/asyncprocess/tasyncprocess.html TAsyncProcess], [[doc:fcl/process/tprocess.html|TProcess]], TSimpleIPCClient, TSimpleIPCServer, TXMLConfig,  [[doc:fcl/eventlog/teventlog.html|TEventLog]]
 
 
==== [[SynEdit]] ====
 
<center>[[Image:Component_Palette_SynEdit.png]]</center>
 
: ''[[SynEdit]] on edistyksellinen monirivinen muokkauskonrolli, joka on integroitu Lazarukseen. Sitä käytetään Lazarus kehitysympäristön lähdekoodieditorina ja on saatavilla hakemistosta "lazarus/components/synedit".  Se tukee syntaksin korostusta, koodin täydennystä, koodintaittoa ja sisältää HTML, tex ja rtf viejät: TSynEdit, TSynAutoComplete, TSynExporterHTML, TSynMacroRecorder, TSynMemo, TSynPasSyn, TSynFreePascalSyn, TSynCppSyn, TSynJavaSyn, TSynPerlSyn, TSynHTMLSyn, TSynXMLSyn, TSynLFMSyn, TSynUNIXShellScriptSyn, TSynCssSyn, TSynPHPSyn, TSynTeXSyn, TSynSQLSyn, TSynPythonSyn, TSynVBSyn, TSynAnySyn, TSynMultiSyn
 
  
 
== Kuinka käyttää komponentteja==
 
== Kuinka käyttää komponentteja==
  
Käännösyksiköt '''StdCtrls''', '''ComCtrls''' ja '''ExtCtrls''' sisältävät määritelmät ja kuvaukset moniin yleisimmin käytettyihin komponenteihin, lomakkeen rakentamiseen ja muihin objekteihin Lazarus sovelluksissa.
+
[[Unit/fi|Käännösyksiköt]] '''StdCtrls''', '''ComCtrls''' ja '''ExtCtrls''' sisältävät määritelmät ja kuvaukset moniin yleisimmin käytettyihin komponenteihin, lomakkeen rakentamiseen ja muihin objekteihin Lazarus sovelluksissa.
  
Sovelluskehittäjän usein lopullisena tavoitteena on että  halutaan käyttää komponentteja kuten TButton, TMemo, TScrollBar jne, näiden  vastaava kantaisät ovat luokat TCustomButton, TCustomMemo tai TCustomScrollBar. Usein ominaisuuksia ja metodeiden merkitystä on määritelty (ja selitetty) täydellisemmin TCustomXXX luokassa ja ne periytyvät näihin lopullisiin tavoite komponentteihin.
+
Sovelluskehittäjän usein lopullisena tavoitteena on että  halutaan käyttää komponentteja kuten TButton, [[TMemo/fi|TMemo]], [[TScrollBar/fi|TScrollBar]] jne, näiden  vastaava kantaisät ovat luokat TCustomButton, TCustomMemo tai TCustomScrollBar. Usein ominaisuuksia ja metodeiden merkitystä on määritelty (ja selitetty) täydellisemmin TCustomXXX luokassa ja ne periytyvät näihin lopullisiin tavoite komponentteihin.
  
Jos pudotat komponentin lomakkeelle niin silloin ei tarvita lisätä koodia luomaan sitä. Komponentti automaattisesti luodaan lomakkeen yhteudessä ja tuhotaan kun lomake on tuhottu. Jos kuitenkin luodaan komponentti (omatoimisesti) koodilla niin ei saa unohtaa sen vapauttamista, kun sitä ei enää tarvita.
+
Jos pudotat komponentin lomakkeelle niin silloin ei tarvita lisätä koodia luomaan sitä. Komponentti automaattisesti luodaan lomakkeen yhteydessä ja tuhotaan kun lomake on tuhottu. Jos kuitenkin luodaan komponentti (omatoimisesti) koodilla niin ei saa unohtaa sen vapauttamista, kun sitä ei enää tarvita.
  
 
==== Tapoja asettaa ominaisuuksia ====
 
==== Tapoja asettaa ominaisuuksia ====
Line 434: Line 142:
 
Voidaan myös nimenomaisesti muuttaa komponentin ominaisuuksia koodin kirjoittamalla (asianmukaisessa implementation lohkossa lähdekoodieditorissa), esimerkiksi
 
Voidaan myös nimenomaisesti muuttaa komponentin ominaisuuksia koodin kirjoittamalla (asianmukaisessa implementation lohkossa lähdekoodieditorissa), esimerkiksi
  
<code>Form1.Button1.Height := 48;</code>
+
 
 +
<syntaxhighlight lang="pascal">Form1.Button1.Height := 48;</syntaxhighlight>
  
 
Yhteenvetona, on yleisesti kolme erilaista tapaa määrittää jokaisen komponentin ominaisuuksia:
 
Yhteenvetona, on yleisesti kolme erilaista tapaa määrittää jokaisen komponentin ominaisuuksia:
Line 444: Line 153:
 
</ul>
 
</ul>
  
==== Common Properties ====
+
==== Yleisiä ominaisuuksia ====
 
 
The components defined in these Units have several properties that are common to most of them, and other properties that are specific to the individual components. We shall describe the most common ones here. Unusual or control-specific properties will be described for the individual controls.
 
  
Additional Help can always be obtained by selecting a property or keyword, in either the Object Inspector or the Source Editor, and pressing {{keypress|F1}}. You will be taken by your Help browser to the appropriate page in the documentation.  
+
Komponenttien käännösyksiköissä on määritelty useita ominaisuuksia, jotka ovat yhteisiä useimmille niistä ja muita ominaisuuksia jotka ovat ominaisia ​​yksittäisille komponenteille. Yleisimpiä on kuvattu tässä. Epätavallisia tai okomponenttiriippuvaisia ominaisuuksia kuvataan tarkemmin komponettikohtaisissa ohjeissa.  
  
If the description of a property on that page is insufficient, you can navigate to the corresponding description in the ancestor classes, by selecting the links in the Inheritance listing or by selecting the ancestor Type in the declaration of the object.
+
Lisäohjeita saadaan valitsemalla ominaisuus tai avainsana, joko komponenttimuokkaimessa tai lähdekoodieditorissa ja painamalla {{keypress|F1}}. Tämä vie ohjeen oikealle sivulle dokumentaatiossa.
  
 +
Jos ominaisuuden kuvaus on sivulla riittämätön, voidaan siirtyä katsomaan mistä se on peritty.
  
  
 
<table>
 
<table>
   <caption><b>Some commonly listed properties</b></caption>
+
   <caption><b>Joitakin yleisesti olevia ominaisuuksia</b></caption>
   <tr><td><b>Property</b></td><td><b>Meaning</b></td></tr>
+
   <tr><td><b>Ominaisuus</b></td><td><b>Merkitys</b></td></tr>
 
   <tr>
 
   <tr>
 
     <td>Action</td>
 
     <td>Action</td>
     <td>The main action or event associated with the object. For example selecting an 'Exit' Button might cause the 'Close' action</td>
+
     <td>Tärkein toiminta tai tapahtuma joka liittyy komponenttiin. Esimerkiksi valitsemalla "Lopeta" -painike saattaa aiheuttaa Sulje-toiminnan.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Align</td>
 
     <td>Align</td>
     <td>Defines the way in which an object is to be lined up with the parent object. Possible values are alTop (placed at the top and using the full available width), alBottom, alLeft (placed at the left and using the full available height), alRight. alNone (place anywhere on parent control) or alClient (takes all available space next to controls aligned to top, bottom, left or right)</td>
+
     <td>Määrittää miten komponentti on sijoittunut vanhempaansa nähden. Mahdolliset arvot ovat alTop (sijoittuu yläosaan ja käyttää koko käytettävissä olevan leveyden), alBottom, alLeft (sijoittuu vasemmalle ja käyttäen koko käytettävissä olevan korkeuden), alRight. alNone (missä tahansa) tai alClient (käyttää kaiken käytettävissä olevan tilan) </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Anchor</td>
 
     <td>Anchor</td>
     <td>Used to keep a control a certain distance from the defined edges of a parent control, when the parent is resized. For example <b>[akBottom, akRight]</b> will keep the control a fixed distance from the bottom right corner.</td>
+
     <td>Käytetään pitämään komponentti tietyn etäisyyden päässä vanhemmasta komponentista, määritelty reunoista, kun vanhempi muuttaa kokoa. Esimerkiksi <b>[akBottom, akRight]</b> pitää komponentin kiinteän matkan päässä oikeaan alakulmaan.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>AutoSelect</td>
 
     <td>AutoSelect</td>
     <td>When True, an editing control will select all its text when it receives focus or when the Enter key is pressed.</td>
+
     <td>Kun sen arvo on True niin valitaan kaikki se teksti, joka on valittu kun {{keypress|Enter}}-näppäintä painetaan tai hyväksytään kyseinen kohta.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>AutoSelected</td>
 
     <td>AutoSelected</td>
     <td>True indicate that the edit or combobox control has just performed an AutoSelect operation so that subsequent mouse-clicks and keystrokes proceed normally without selecting the text.</td>
+
     <td>True osoittaa, että Edit tai ComboBox komponentti on juuri suorittanut AutoSelect toiminnan siten, että myöhemmät hiirellä ja näppäimistön syöttö jatkuu normaalisti valitsematta tekstiä.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>BorderSpacing</td>
 
     <td>BorderSpacing</td>
     <td>The space around the edge between an '''Anchored''' control and its parent.</td>
+
     <td>''Ankkuroidun'' komponentin ja sen vanhemman välisen ympäröivän reunan etäisyys.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Caption</td>
 
     <td>Caption</td>
     <td>The text that is displayed on or near the control; it should preferably give some clue as to the function of the control, or an instruction such as 'Close' or 'Execute'. By default Caption is set to be the same as the 'Name' property, and the application programmer should substitute meaningful text instead of the default values.</td>
+
     <td> Teksti, joka näkyy tai on lähellä komponenttia; Ohjelman käyttäjälle tulee antaa vihjeen siitä, minkä tehtävän tai käskyn komponentti tekee kuten "Sulje" tai "Suorita". Oletuksena Caption-teksti asetetaan samaksi kuin mitä on "Name" ominaisuudessa ja ohjelmoijan pitäisi oletusarvon sijaan korvata se sopivalla tekstillä.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>CharCase</td>
 
     <td>CharCase</td>
     <td>Indicates how text is displayed in a text editing control: Normal (retaining the case of the letters typed by the user), converted to uppercase, or converted to lowercase</td>
+
     <td>Kertoo, miten teksti näkyy tekstin muokkauskomponentissa: Normaali (sellaisenaan, säilyttäen käyttäjän antaman syötteen), muunnetaan isoiksi tai pieniksi kirjaimiksi.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Constraints</td>
 
     <td>Constraints</td>
     <td>Sets the minimum and maximum sizes for a control. If a control is resized the new dimensions are always within the ranges given here. You should take care when setting these options that they do not conflict with the Anchors and Align settings.</td>
+
     <td> Asettaa äärikoot komponentille. Jos kokoa muutetaan niin uudet ulottuvuudet ovat aina vaihteluvälien rajoissa. Ohjelmoikan tulisi huolehtia asettaessaan näitä, että ne eivät ole ristiriidassa Anchors ja Align asetuksien kanssa.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Color</td>
 
     <td>Color</td>
     <td>The Colour to be used to draw the control or to write the text it contains.</td>
+
     <td>Väri jota käytetään piirtämään komponentti ja sen näyttämää kirjoitettavaa tekstiä. </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Enabled</td>
 
     <td>Enabled</td>
     <td>A Boolean property to determine whether or not a control is capable of being selected and performing an action. If it is not '''Enabled''', it is often <b>Grayed</b> out on the Form.</td>
+
     <td> Boolean ominaisuus joka määrittää, onko komponentti  valittavissa, käytössä tai voiko se suorittaa toiminnon. Jos se ei ole käytössä (arvossa false) niin se on usein <b>harmaana</b> lomakkeella.
 +
</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Font</td>
 
     <td>Font</td>
     <td>The Font to be used for writing the text associated with the control - either the caption or label, or the text-strings contained within the control. The entry on the Object Inspector usually has a (+) box on the left, and selecting this box reveals further options such as character set, colour and size.</td>
+
     <td>Kirjaisin jota käytetään kirjoitettaessa tekstiä komponenttiin liittyen - joko caption, label tai teksti komponentin sisällä . Komponenttimuokkaimessa on nuoli-merkintä yleensä tämän kohdan vasemmalla puolen, ja valitsemalla se niin se paljastaa muita vaihtoehtoja kuten merkistön, värin ja koon.</td>
 +
  </tr>
 +
  <tr>
 +
    <td>Height</td>
 +
    <td>Komponentin korkeus. Katso myös Width. </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Hint</td>
 
     <td>Hint</td>
     <td>A short piece of informative pop-up text that appears if the mouse-cursor hovers over the control. See the ShowHint property.</td>
+
     <td>Lyhyt informatiivinen vihjeteksti joka näkyy ponnahdustekstinä, jos hiiren kursori menee komponentin päälle. Katso myös ShowHint ominaisuus. </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Items</td>
 
     <td>Items</td>
     <td>The list of 'Things' that the object contains, such as a group of images, a series of lines of text, a number of actions in an actionlist, etc</td>
+
     <td> Luettelo "asioista", jota kohde sisältää, kuten joukko kuvia, luettelo tekstiä, toimintoja käytettäessä actionlist:aa jne. </td>
 +
  </tr>
 +
  <tr>
 +
    <td> Left</td>
 +
    <td>Määrittää missä komponentti sijaitsee suhteessa vanhempaan (lomake, ikkuna) vaakasuunta. Katso myös Top</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Lines</td>
 
     <td>Lines</td>
     <td>An array of strings, containing the textual data in controls with more than a single line of data, such as an Edit-Box or a Combo-Box. The array is zero-indexed, ie the lines are numbered [0..numLines-1]</td>
+
     <td>Merkkijonojen joukko, joka sisältää tekstisisältöä enemmän kuin yhden rivin tietoja. Taulukko on nolla-indeksoitu eli rivit on numeroitu (alkaen nollasta)[0..numLines-1] </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Name</td>
 
     <td>Name</td>
     <td>The identifier by which the control is known in the program. The IDE gives it a default name based on the underlying type, for example successive instances of TBitButton would be named Form1.BitBitton1 and Form1.BitButton2; it is up to the application programmer to give them more meaningful names such as ExitButton or OKButton. By default the Name of the control is applied to the Caption for the control, but the text of the Caption may be changed separately.</td>
+
     <td>Tunniste eli nimi, jonka avulla komponentti tunnetaan ohjelmassa. Kehitysympäristö antaa sille oletuksena nimen joka pohjautuu taustalla tyypin mukaan, esimerkiksi peräkkäisinä esiintyvät TBitButton-komponentit olisivat nimeltään BitButton1 ja BitButton2; Olisi hyvä jos ohjelmoija antaisi näille enemmän kuvaavampia nimiä kuten ExitButton tai OKButton. Oletuksena komponentin nimi viedään myös Caption tekstiksi, mutta Caption teksti voidaan muuttaa erikseen. </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>PopUpMenu</td>
 
     <td>PopUpMenu</td>
     <td>A window containing context-sensitive menu information that pops up when the right mouse button is clicked on the object.</td>
+
     <td>Ikkuna joka sisältää tilannekohtainen valikkotietoa, joka avautuu, kun hiiren oikealla painikkeella klikataan komponenttia.</td>
  </tr>
 
  <tr>
 
    <td>Position (or Top, Left)</td>
 
    <td>Determines where the control is located on the parent form or window</td>
 
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>ReadOnly</td>
 
     <td>ReadOnly</td>
     <td>Boolean property which, if True, signifies that the contents of the control can be read by the user or the calling routine, but cannot be written or changed.</td>
+
     <td>Boolean omonaisuus, ja jos sen arvo on true, niin tarkoittaa sitä että käyttäjä tai kutsuva rutiini voi luke komponentin sisältö, mutta se ei voi kirjoittaa siihen tai muuttaa sitä. </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>ShowHint</td>
 
     <td>ShowHint</td>
     <td>Allows a small window containing a context-sensitive Help or other description to be displayed when the mouse cursor 'hovers' over the control. See the Hint property.</td>
+
     <td>Sallii pienen tekstikentän, joka sisältää tilannekohtaisen ​​ohjeen tai muun kuvauksen, joka näkyy, kun hiiren kursori on komponentin "päällä". Katso Hint-ominaisuutta.</td>
  </tr>
 
  <tr>
 
    <td>Size (or Height and Width)</td>
 
    <td>The dimensions of the control</td>
 
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Style</td>
 
     <td>Style</td>
     <td>The options available for Style depend upon the sort of Control being considered: for instance the Style may be defined by TFormStyle, TBorderStyle, TButtonStyle etc.</td>
+
     <td> Valittavissa olevia tyylivaihtoehtoja: esimerkiksi Style voidaan määrittää TFormStyle, TBorderStyle, TButtonStyle jne.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>TabOrder</td>
 
     <td>TabOrder</td>
     <td>Integer defining where in the sequence of tabs on the Form this control is to lie</td>
+
     <td>Kokonaisluku määritellään missä järjestyksessä {{keypress|Tab}} -näppäin käy läpi lomaketta.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>TabStop</td>
 
     <td>TabStop</td>
     <td>Boolean property which if True places this control in the sequence of objects that the user can reach by successively pressing the Tab key</td>
+
     <td>Boolean ominaisuus jos True niin paikka johon käyttäjä voi päästä peräkkäin painamalla {{keypress|Tab}}  eli sarkainnäppäintä.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Text</td>
 
     <td>Text</td>
     <td>The String of Text that represents the actual data that this control contains. Applies particularly to Text, Memo and StringList types of object. Most of the editing operations (such as '''Select''', '''Clear''', '''Cut''', '''Copy''') are performed in this part of the object, which holds the actual string being edited. If the control contains more than a single line of text, for example '''TMemo''' or '''TComboBox''', then the textual elements are arranged as an array of strings (zero-indexed, ie numbered from [0..numLines-1]) in '''Lines'''.</td>
+
     <td>Merkkijono teksti, joka edustaa todellisia tietoja, mitä tämä komponentti sisältää. Koskee erityisesti Text, Memo ja StringList tyyppisiä komponentteja. Suurin osa editointi (kuten '''Select''', '''Clear''', '''Cut''', '''Copy''') suoritetaan komponentin tässä osassa, joka sisältää todellisen muokattavan merkkijonon. Jos komponentissa on enemmän kuin yksi rivi tekstiä, esimerkiksi TMemo tai TComboBox, niin tekstielementtejä on järjestetty  merkkijonojoukoiksi (nolla-indeksoitu eli numeroituna [0..rivien määrä-1]) rivejä. </td>
 +
  </tr>
 +
  <tr>
 +
    <td> Top</td>
 +
    <td>Määrittää missä komponentti sijaitsee suhteessa vanhempaan (lomake, ikkuna) pystysuunta. Katso myös Left</td>
 
   </tr>
 
   </tr>
 +
 
   <tr>
 
   <tr>
 
     <td>Visible</td>
 
     <td>Visible</td>
     <td>If true, the object can be seen on the Form; if False, object is hidden</td>
+
     <td>Jos ominaisuuden arvo on true niin komponentti näkyy lomakkeella. Jos arvo on false niin komponentti on piilotettu.</td>
 +
  </tr>
 +
  <tr>
 +
    <td>Width</td>
 +
    <td>Komponentin leveys. Katso myös Height. </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>WordWrap</td>
 
     <td>WordWrap</td>
     <td>Logical flag to show whether or not word-wrap is enabled, ie if a word comes close to the end of a line and is going to be too long for the line, it is wrapped down to the next line.</td>
+
     <td> Looginen lippu osoittaa, onko automaattinen rivinvaihto on käytössä, eli jos sana tulee lähelle rivin loppuun ja tulee olemaan liian pitkä rivi niin osa siitä on siiretty (alaspäin) seuraavalle riville.</td>
 
   </tr>
 
   </tr>
 
</table>
 
</table>
  
==== Event Actions ====
+
==== Tapahtumat ====
Many actions are commonly listed in the 'Events' tab of the Object Inspector. If you select an entry in the list, a ComboBox appears with a DropDown list showing any actions that have aleady been defined, and allowing you to choose one to be associated with this event. Alternatively you can select the ellipsis (three dots ...) and you will be taken to an area of the Source Editor where you can begin typing your own action instructions for the selected event.
 
  
While a large number of events is available for any given control, in practice it is only necessary to populate a few of them. For most controls, it is sufficient to provide coding for 'OnClick'; for more complex controls it may be necessary also to provide for 'OnEntry' (when the mouse cursor enters the Control and gives it focus) and 'OnExit' (when the mouse cursor leaves the Control; or you may need to write an event handler for 'OnChange' or 'OnScroll', depending on the nature of the particular control with which you are dealing.
+
Monet tapahtumat ovat yleisesti lueteltu "Tapahtumat" välilehdellä komponenttimuokkaimessa. Jos komponenttimuokkaimessa valitaan tapahtuman viereinen tyhjäkenttä kenttä niin siihen muodostuu ComboBox jonka alasvetoluettelosta näkyy luettelo kaikista toimista jotka on jo määritelty. Tämän avulla voidaan valita tähän tapahtumaan yhden kohdan. Vaihtoehtoisesti voit valita kolme pistettä {{keypress|...}}-painike  jolloin lähdekoodieditorissa tehdään metodin sisään alue johon voidaan aloittaa kirjoittamaan oman toiminnan käskyjä valittuun tapahtumaan.
  
The pop-up menu that appears when you right-click an object in the Form Designer has, as its first item: 'Create default event' and selecting this option will have the same effect as selecting the ellipsis in the Object Inspector for the default event, usually OnClick: you are taken to the Implementation area of the Source Editor where you can type the code for the event handler.
+
Vaikka suuri määrä tapahtumia on liitettävissä komponentin toimintaan. Käytännössä se on tarpeen vain asettaa muutamaan niistä. Useimmille komponenteille on riittävää koodaata onClick-tapahtuma; monimutkaisemmissa komponenteissa voi olla tarpeen myös kirjoittaa toiminta tapahtumiin "OnEntry" (kun hiiren osoitin siirtyy komponentille ja se valitaan) ja "OnExit" (kun hiiren osoitin poistuu komponentilta), tai ehkä kirjoittaa tapahtumankäsittelijä "OnChange" tai "OnScroll" -tapahtumiin, riippuen komponenteista, jonka kanssa ollaan tekemisissä.
 +
 
 +
Pop-up-valikko, joka tulee näkyviin hiiren oikealla painikkeella kun komponenttia klikataan lomakkeella. Siinä ensimmäisenä vaihtoehtona on: "Luo oletustapahtuma". Valitsemalla tämän vaihtoehdon on sillä sama vaikutus kuin valitsemalla kolme pistettä komponenttimuokkaimen oletuksena olevassa tapahtumassa joka on yleensä "onClick".  Eli lähdekoodieditorissa tehdään metodin sisään alue johon voidaan aloittaa kirjoittamaan oman toiminnan käskyjä.
 +
 
 +
Yleinen strategia Olio-ohjelmoinnissa on tarjota '''[[TActionList|ActionList]]''' johon on tehty useita ennalta määriteltyjä toimenpiteitä, joista sopivin voidaan valita käyttöön siinä tapauksessa.
  
A common strategy in Object-Oriented programming is to provide an '''[[TActionList|ActionList]]''' with the facility for entering, removing or editing a number of pre-defined actions from which the most appropriate can be selected to use in any particular instance.
 
  
 
<br/>
 
<br/>
 
<table>
 
<table>
   <caption><b>Some commonly listed Actions</b></caption>
+
   <caption><b>Joitakin yleisiä tapahtumia</b></caption>
 
   <tr>
 
   <tr>
     <td><b>Action</b></td>
+
     <td><b>Tapahtuma</b></td>
     <td><b>Meaning</b></td>
+
     <td><b>Merkitys</b></td>
 
   <tr>
 
   <tr>
 
     <td>OnChange</td>
 
     <td>OnChange</td>
     <td>Action to be taken if any change is detected (eg mouse move, mouse click, key press, edit text, alter picture, etc)</td>
+
     <td>Tapahtuu jos jokin muutos havaitaan (esim hiiren liikkua, hiiren klikkaus, näppäimen painallus, tekstin muokkaus, kuva muuttuu jne) </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnClick</td>
 
     <td>OnClick</td>
     <td>Action to be taken when the (first, usually left) mouse button is clicked. This is commonly the main or default action of the control; for example clicking on a button or checkbox initiates the action associated with the checkbox. It may alternatively initate a process of selection, for instance in a TextBox or Memo, or signal the beginning of painting with a Pen or Brush.</td>
+
     <td>Tapahtuu kun (ensimmäinen, yleensä vasenta) hiiren painiketta klikataan. Tämä on yleensä pää- tai oletus toiminto; esimerkiksi kun klikataan painiketta tai muuta vastaavaa.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>Click</td>
 
     <td>Click</td>
     <td>A method to emulate in code the effect of clicking on a control. This method is most often found in Button-type controls (TButton, TBitBtn, TSpeedButton etc). A procedure can be written that calls the same code as the OnClick action. This facility can be particularly useful if the activation of one control by clicking causes a cascade of other controls to be activated, and the Click method can be used to initiate the action rather than having the user explicitly click on a lot of controls.</td>
+
     <td>Menetelmä matkia koodina  klikkaamisen vaikutusta. Tämä menetelmä on useimmiten löytyy Button-tyyppisistä komponenteista (TButton, TBitBtn, TSpeedButton jne). Aliohjelma voidaan kirjoittaa niin että kutsutaan samaa koodia kuin onClick toiminta. Tämä järjestely voi olla erityisen hyödyllistä, jos yhden komponentin aktivointi  klikkaamalla aiheuttaa lukuisiin muiden komponenttien aktivointia, ja valitsemalla menetelmä voidaan käyttää aloittamaan toiminto sen sijaan, käyttäjä joutuu klikkaamaan monia komponentteja.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnDragDrop</td>
 
     <td>OnDragDrop</td>
     <td>Action to be taken during Drag-Drop manoeuvres, ie when the mouse is used to 'capture' an item or some text etc and move it around the screen to a new location.</td>
+
     <td>Toteuttaa toimet vedä ja pudota (Drag-Drop) liikkeen aikana, eli kun hiirtä käytetään "kaappaamaan" kohteen tai jotain tekstiä jne ja siirtää sen uuteen paikkaan.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnEditingDone</td>
 
     <td>OnEditingDone</td>
     <td>Action to be taken when the user has finished all edits/modifications to the control. This is often used to validate the control content (e.g. check if an entered text is a valid IP address)</td>
+
     <td>Toiminta alkaa kun käyttäjä on lopettanut kaikki muutokset / muutokset komponenttiin. Tätä käytetään usein tarkistamaan komponentin sisältöä (esim. tarkistamaan että syötetty teksti on oikea tai kunnollinen IP-osoite) </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnEntry</td>
 
     <td>OnEntry</td>
     <td>Action to be taken when the mouse cursor enters the area occupied by the object, usually transfering focus to that object. This might include changes in the appearance of the object such as highlighting or raising the border.</td>
+
     <td>Toteuttaa toimet kun hiiren osoitin siirtyy komponentille tai yleisesti kun "painopiste" siirtyy komponenttiin. Tämä saattaa sisältää muutoksia komponentin ulkonäköön kuten korostamaan sitä tai kohottamaan sen reunuksia.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnExit</td>
 
     <td>OnExit</td>
     <td>Action to be taken when the mouse moves out of the area of the object, usually transferring focus out of the object.</td>
+
     <td> Tapahtuma aktivoituu, kun hiiri siirtyy pois komponentin alueelta, yleisesti siirtämällä "painopiste" pois komponentilta.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnKeyPress</td>
 
     <td>OnKeyPress</td>
     <td>Action to be taken for any key-press. Subtly different from OnKeyDown, which simply responds to a key being down, whether or not it was already down when focus was given to this control. OnKeyPress requires that a key becomes pressed while focus is in this control.</td>
+
     <td>Tapahtuma aktivoituu, kun painetaan jotain näppäintä. Hienovaraisesti erilainen kuin OnKeyDown, joka yksinkertaisesti aktivoituu näppäimen ollessa alhaalla. OnKeyPress vaatii, että painopiste on jo tässä komponentissa kun näppäintä painetaan.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnKeyDown</td>
 
     <td>OnKeyDown</td>
     <td>Action to be taken if a key is down while focus is in this control. Subtly different from OnKeyPress - for example the key might already have been down when focus entered this control, whereas OnKeyPress requires the key to become pressed while focus is in the control.</td>
+
     <td>Tapahtuma aktivoituu, jos näppäin on alhaalla, kun "painopiste" (fokus) on tässä komponentissa. Hienovaraisesti erilainen kuin OnKeyPress - esimerkiksi näppäin saattaa olla jo alhaalla, kun focus tuli tähän komponenttiin, kun taas OnKeyPress vaatii näppäintä painetaan vasta kun painopiste on tässä komponentissa.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnKeyUp</td>
 
     <td>OnKeyUp</td>
     <td>Action to be taken if a key is up (ie not pressed) while focus is in this control.</td>
+
     <td>Tapahtuma aktivoituu kun näppäin "vapautetaan" eli nousee ylös (tai näppäimen painaminen loppuu) kun focus on tässä komponentissa.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnMouseMove</td>
 
     <td>OnMouseMove</td>
     <td>Action to be taken if the mouse cursor moves while focus is in this control.</td>
+
     <td>Tapahtuma aktivoituu kun hiiren osoitin liikkuu ja focus on tässä komponentissa.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnMouseDown</td>
 
     <td>OnMouseDown</td>
     <td>Action to be taken if the mouse button is down while focus is in this control.</td>
+
     <td>Tapahtuma aktivoituu kun hiiren näppäin menee alas ja focus on tässä komponentissa.</td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnMouseUp</td>
 
     <td>OnMouseUp</td>
     <td>Action to be taken if the mouse button is up while the cursor is over this control. Implies that the mouse button was previously down and has been released. The case where the cursor enters the control but the mouse button has not yet been pressed is covered by OnEntry or OnMouseEnter.</td>
+
     <td>Tapahtuma aktivoituu kun hiiren näppäin "vapautetaan" ja focus on tässä komponentissa. Eli hiiren näppäin on jo aikaisemmin painettu alas ja painaminen lopetetaan/päätetään </td>
 +
</tr>
 +
  <tr>
 +
    <td>OnMouseEnter</td>
 +
    <td>
 +
Tapahtuma aktivoituu kun hiiren osoitin siirtyy komponentille ( mutta hiiren painiketta ei vielä ole painettu) . </td>
 
   </tr>
 
   </tr>
 
   <tr>
 
   <tr>
 
     <td>OnResize</td>
 
     <td>OnResize</td>
     <td>Action to be taken when the control is resized. Might include re-alignment of text or selection of a different font size etc.</td>
+
     <td>Tapahtuma aktivoituu kun komponentin kokoa muutetaan tai koko muuttuu. Voi aktivoitua esim. kun teksti tasataan toiseen reunaan, keskitetään tai valitaan eri fonttikokoa jne.</td>
 
   </tr>
 
   </tr>
 
</table>
 
</table>
  
==== Contructors & Destructors ====
+
==== Rakentajat & purkajat ====
  
These are two special methods associated with each control:
+
Nämä ovat kaksi erityistä metodia liittyvät [[Class|luokkiin]](komponentit):
  
* '''Constructors:''' such as '''Create''' allocate memory and system resources needed by the object. They also call the constructor of any sub-objects present in the class.
+
* '''[[Constructor/fi|Constructor (Rakentaja)]]:''' kuten '''Create''' varaa olion (komponentin) tarvitsemaa muistia ja järjestelmäresursseja. Ne  tarpeen vaatiessa kutsuvat myös muita luokan aliolioiden rakentajia.
  
* '''Destructors:''' remove the object and de-allocate memory and other resources. If you call '''Destroy''' for an object which hasn't being initialized yet it will generate an error. Always use the '''Free''' method to deallocate objects, because it checks whether an object's value is <b>nil</b> before invoking '''Destroy'''.
+
* '''[[Destructor/fi|Destructor (purkaja)]]:''' poistaa olion ja vapauttaa varatun muistin sekä muita resursseja. Jos kutsut '''Destroy''' (tuhoa) olio, jota ei ole vielä alustettu,niin se aiheuttaa virheen. Käytä aina '''Free''' metodia puratessa olioita, koska se tarkistaa, onko olion arvo on  <b>[[Nil/fi|nil]]</b> ennenkuin kutsuu '''Destroy''' metodia.
 
 
Take the following precautions when creating your own '''Destroy''' method:
 
  
 +
Noudata seuraavia varotoimia, kun luoda oman '''Destroy'''  metodin:
 
<ul>
 
<ul>
   <li>Declare '''Destroy''' with the <b>override</b> directive, because it is a <b>virtual</b> method.</li>
+
   <li>Määritä '''Destroy''' <b>override</b> directive:llä, koska se on <b>virtual</b> metodi.</li>
   <li>Always call ''''inherited Destroy;'''' as the last thing on the destructor code.</li>
+
   <li>Kutsu aina ''''inherited Destroy;'''' viimeisenä asiana  destructor:in koodissa.</li>
   <li>Be aware that an '''exception''' may be raised on the '''constructor''' in case there is not enought memory to create an object, or something else goes wrong. If the '''exception''' is not handled inside the constructor, the object will be only partially built. In this case '''Destroy''' will be called when you weren't expecting it, so your destructor must check if the resources were really allocated before disposing of them.</li>
+
   <li>Huomaa, että [[Exceptions/fi|'''exception''' (poikkeus)]] voidaan nostaa jos '''constructor''' (rakentajalla) ei ole tarpeeksi muistia luoda olio tai jotain muuta menee pieleen. Jos poikkeusta ei käsitellä rakentajan sisällä, olio on tällöin vain osittain rakennettu. Tässä tapauksessa kun '''Destroy'''ta kutsutaan, destructor:in täytyy tarkistaa että resurssit olivat todella varattu ennen kuin se hävittää ne.</li>
   <li>Remember to call '''Free''' for all objects created on the constructor.</li>
+
   <li>Muista kutsua '''Free''' metodia kaikille olioille jotka on luotu constructor:lla.</li>
 
</ul>
 
</ul>
  
== How to use Menu Controls ==
+
== Kuinka käyttää valikko-komponenttia ==
Hints for creating menus for your forms
+
 
 +
Vihjeitä miten luoda valikot lomakkeelle.
  
''TMainMenu'' is the Main Menu that appears at the top of most forms; form designers can customise by choosing various menu items. ''TPopupMenu'' is a menu window that pops up with pertinent, usually context-sensitive, details and choices when the right mouse button is clicked near a control
+
''[[TMainMenu/fi|TMainMenu]]'' [[image:tmainmenu.png]] on päävalikko, joka näkyy monen lomakkeen yläosassa; Lomakkeen suunnittelija voivat muokata sitä valitsemalla eri valikkovaihtoehtoja. ''[[TPopupMenu/fi|TPopupMenu]]'' [[image:tpopupmenu.png]] on valikko -ponnahdusikkunassa, jossa on yleensä tilannekohtaisia, yksityiskohtia vaihtoehtoja. Se "ponnahtaa" kun hiiren oikeaa näppäintä klikataan lähellä komponenttia.
  
Main Menu is a non-visible component: that is, if the icon is selected from the Component Palette and placed on the form, it will not appear at runtime. Instead, a menu bar with a structure defined by the Menu Editor will appear. Popup menus (placed on the form by selecting the icon from the Component Palette) do not appear at all unless the right mouse button is clicked on a control that owns such a menu.
+
Päävalikko on ei-näkyvä komponentti: toisin sanoen jos kuvake on valittu komponenttipaletilta ja saatetaan lomakkeelle niin se ei näy ohjelman [[runtime/fi|ajon aikana]]. Sen sijaan, valikkorivi jonka rakenne määritellään valikkomuokkaimessa ilmestyy. Ponnahdusvalikot (saattaa lomakkeelle valitsemalla kyseinen kuvake komponentipaletilta) eivät näy ollenkaan kunnes hiiren oikealla painikkeella klikataan komponenttia, jolla on tällainen valikko.
  
To see the Menu Editor, right-click on the Main Menu or Popup Menu icon on your Form. A pop-up box appears that invites you to enter items into the Menu bar.
+
Nähdäksesi valikkomuokkaimen, klikkaa hiiren oikealla Main Menu tai Popup Menu -kuvaketta lomakkeella. Tällöin avautuu ikkuna johon voidaan syöttää valikon kohteet.
  
An edit box is displayed, containing a button labelled "New Item1". If you right-click on that box, a pop-up menu is displayed that allows you to add a new item before or after (along the same level) or create a sub-menu with the opportunity to add further items below (or above) the new item in a downward column.
+
valikkomuokkaimessa näkyy laatikko joka sisältää painikkeen "New Item1". Jos klikkaa hiiren oikealla kyseistä painiketta, pop-up-valikko tulee näkyviin, jonka avulla voit lisätä uuden kohdan ennen tai jälkeen (samalla tasolla) tai luoda alivalikon mahdollisuuden johon lisätä uusia kohteita sen alle.
  
Any of the ''MenuItems'' that you add can be configured using the Object Inspector.
+
Mikä tahansa ''MenuItems'' joka lisätään voidaan määrittää käyttämällä komponenttimuokkainta.
  
At the least you should give each item a ''Caption'' which will appear on the Menu Bar. The caption should indicate the activity to be selected, such as "File Open" or "Close", "Run" or "Quit". You may also wish to give it a more meaningful ''Name''.
+
Ainakin kullekin kohdalle pitäisi antaa ''Caption''-teksti , joka näkyy valikkorivillä. sen tulisi kertoa toimintaa jota voidaan valita, kuten "Avaa tiedosto", "Sulje", "Suorita" tai "Lopeta". Voidaan myös haluta antaa tätä merkityksellisempi nimi.
  
If you want a particular letter in the Caption to be associated with a shortcut key, that letter should be preceded by an ampersand (&). The Menu item at run-time will appear with the shortcut letter underlined, and hitting that letter key will have the same effect as selecting the menu item. Alternatively you can choose a shortcut key sequence (such as {{keypress|Ctrl}}+{{keypress|C}} for Copy or {{keypress|Ctrl}}+{{keypress|V}} for Paste - the standard keyboard shortcuts) with the ''ShortCut'' property of the MenuItem.
+
Jos halutaan tietyn Caption-tekstni kirjaimen liittyvän  pikanäppäin-toimintoon, niin kirjain pitäisi edeltää et-merkillä (&). Jolloin ohjelman ajon aikana valikkokohtaan ilmestyy pikanäppäintä vastaava kirjain alleviivattuna ja painamalla kirjainta vastaavaa näppäintä on sillä sama vaikutus kuin valitsemalla valikosta. Vaihtoehtoisesti voidaan pikanäppäin sekvenssit (esimerkiksi {{keypress|Ctrl}}+{{keypress|C}} kopioi tai {{keypress|Ctrl}}+{{keypress|V}} liitä - standardin mukaiset pikanäppäimet) valita MenuItem:n ''ShortCut'' ominaisuuteen.
  
It is often helpful to use the Menu controls in conjunction with an ''ActionList'' which contains a series of standard or customised ''Actions''. Menu Items can be linked in the Object Inspector to ''actions'' on the list, and the same actions can be linked to ''buttons'', ''toolbar buttons'', ''speedbuttons'' etc. It is obviously more efficient to re-use the same code to respond to the various events, rather than writing separate ''OnClick'' event handlers for each individual control.
+
Usein on hyödyllistä käyttää valikoiden yhteydessä  ''[[TActionList]]'' komponenttia  joka sisältää joukon standardin mukaisia tai räätälöityjä tapahtumia. Valikkokohdat voidaan linkittää komponenttimuokkaimessa lueteltuihin tapahtumiin  ja samoja tapahtumia voidaan yhdistää painikkeisiin, työkalupalkin painikkeihin, pikapainikkeisiin jne. On tietenkin tehokkaampaa käyttää uudelleen samaa koodia vastata erilaisiin tapahtumiin, kuin kirjoittaa erillinen ''OnClick'' tapahtumakäsittelijä jokaiseen yksittäiseen komponenttiin.
  
By default, a number of standard actions are pre-loaded from ''StdActns'' or, if DataAware controls are used, from ''DBActns''. These actions can be chosen using the ActionList editor which appears when you right-click on the ActionList icon on the Form Designer.
+
Oletuksena useita standarditapahtumia ovat valmiiksi ladattu. Nämä tapahtumat voidaan valita käyttämällä toimintolistan muokkainta joka näkyy, kun hiiren klikkaa ActionList kuvaketta lomakkeella.
  
 
== Virheenjäljitys ==
 
== Virheenjäljitys ==
: ''Still to be written''.
+
: ''Jotain kirjoitettu toisaalla''.
 +
 
 +
1) Varmista, että olet lukenut sen asetukset: [[Debugger_Setup]]
  
1) Make sure you read the setup: [[Debugger_Setup]]
+
2) Katso myös [[:category: IDE Window - Debug]]
  
2) See also [[:category: IDE Window - Debug]]
+
3) Lue rajoitukset: [[GDB_Debugger_Tips#Inspecting_data_types_.28Watch.2FHint.29]]
 +
Tämä sivu antaa ohjeita myös joidenkin alustoiden / versioiden erityiskysymyksiln
  
3) Read limitations: [[GDB_Debugger_Tips#Inspecting_data_types_.28Watch.2FHint.29]]
 
This page also helps with some platform/version specific issues
 
  
 
== Lazarus tiedostot ==
 
== Lazarus tiedostot ==
    (Thanks to Kevin Whitefoot.)
 
    (Additions by Giuseppe Ridinò, [[User:Kirkpatc]] and Tom Lisjac)
 
When you save you will actually be saving two files:
 
  
  xxx.pas and yyy.lpr
+
    (Kiitokset: Kevin Whitefoot.)
(You save more than that but those are the ones you get to name). The project file (lpr) and the unit file (pas) must not have the same name because Lazarus will helpfully rename the unit (inside the source code) to the same as the unit file name and the program to the name of the project file (it needs to do this or the compiler will probably not be able to find the unit later when referred to in the project file). Of course to be consistent it changes all the occurrences of unit1 to xxx.
+
    (Lisäykset: Giuseppe Ridinò, [[User:Kirkpatc]] ja Tom Lisjac)
 +
Kun tallennat niin tallennat kahden nimisiä tiedostoja:
  
So if you are saving a project called '''again''', trying to save again.pas and again.lpr fails because unit names and program names are in the same name space resulting in a duplicate name error.
+
  xxx.pas ja yyy.lpr  
 +
(Todellisuudessa tallennetaan enemmän mutta niillä on sama nimi mutta eri pääte). Projektitiedoston (lpr) ja käännösyksikön tiedoston (pas) nimi ei saa olla sama. Tietenkin on johdonmukaista muuttaa kaikki esiintymät Unit1 kuuvaavimmiksi nimiksi.
  
So here is what I ended up with:
+
Joten jos tallennat projektin nimeltä '''again''', yrittää tallentaa again.pas ja again.lpr epäonnistuu, koska yksiköiden nimet ja ohjelmien nimet ovat samassa nimiavaruudessa ja on tuloksena kehitysympäristö kertoo että on olemassa samanniminen tiedosto.
 +
 
 +
Joten tähän päädyttiin:  
  
 
e:/lazarus/kj/lazhello:
 
e:/lazarus/kj/lazhello:
Line 706: Line 433:
 
  -rw-rw-rw-  1 kjwh    root      190 Mar 24 11:18 again.lpr
 
  -rw-rw-rw-  1 kjwh    root      190 Mar 24 11:18 again.lpr
 
  -rw-rw-rw-  1 kjwh    root      506 Mar 24 11:08 againu.lfm
 
  -rw-rw-rw-  1 kjwh    root      506 Mar 24 11:08 againu.lfm
  -rw-rw-rw-  1 kjwh    root      679 Mar 24 11:08 againu.lrs
+
  -rw-rw-rw-  1 kjwh    root      679 Mar 24 11:08 again.res
 
  -rw-rw-rw-  1 kjwh    root      677 Mar 24 11:08 againu.pas
 
  -rw-rw-rw-  1 kjwh    root      677 Mar 24 11:08 againu.pas
 
  -rw-rw-rw-  1 kjwh    root    2124 Mar 24 11:08 againu.ppu
 
  -rw-rw-rw-  1 kjwh    root    2124 Mar 24 11:08 againu.ppu
 
  -rwxrwxrwx  1 kjwh    root      335 Mar 24 11:07 ppas.bat
 
  -rwxrwxrwx  1 kjwh    root      335 Mar 24 11:07 ppas.bat
  
Note that there are many more files than the two that I thought I was saving.
+
Huomaa, että on olemassa paljon enemmän tiedostoja kuin ne kaksi, jotka aluksi mainittiin.
  
Here is a brief note about each file:
 
  
 
'''again.exe:'''
 
'''again.exe:'''
The main program binary executable. Win32 adds an "exe" extension. Linux has none (just the name of the program). This file will be huge in Linux due to the inclusion of debugging symbols. Run the "strip" utility to remove them and substantially shrink the executable size.
+
Pääohjelma joka on ajettavissa. MS windows:ssa lisätään "exe" tiedostopäätelaajennus. Linux:ssa ei lisätä mitään (vain ohjelman nimi). Tämä tiedosto on oletuksena paljon tilaa vievä johtuen sen sisällyttämistä virheenkorjaus symboleista.
 +
Kokoa voi pienentää muuttamalla kehitysympäristön asetuksia tai/ja ajamalla "strip" apuohjelma joka poistaa niitä ja merkittävästi pienentää ajettavan tiedoston kokoa.
 +
 
  
 
'''again.lpi:'''
 
'''again.lpi:'''
(Lazarus Project Information). This is the main information file of a Lazarus project; the equivalent Delphi main file of an application will be the .dpr file. It is stored in an XML format and contains instructions about all the libraries and units required to build the executable file.
+
(Lazarus Project Information). Tämä on tärkein informaatio tiedosto Lazarus projektilla; Delphissä sitä vastaavat tärkeimmät tiedot on .dpr tiedostossa. Se on tallennettu XML-muodossa ja sisältää ohjeet kaikista kirjastoista ja tarvittavista käännösyksiköistä kun rakennetaan suoritettavaa tiedostoa.
  
 
'''again.lpr:'''
 
'''again.lpr:'''
The main program source file or master file. Despite its Lazarus specific extension it is in fact a perfectly normal Pascal source file. It has a uses clause that lets the compiler find all the units it needs. Note that the program statement does not have to name the program the same as the file name. This file is usually fairly small, with just a few statements to initialise, build the forms, run and close the application. Most of the work is done in the unit source files, with suffix '.pas'
+
Pääohjelma lähdekooditiedostona. Huolimatta erityisestä tiedostopääte tarkenteesta niin se on itse asiassa täysin normaalia Pascal lähdekooditiedosto. Siinä on uses lauseke, jonka avulla kääntäjä löytää kaikki käännösyksiköt joita se tarvitsee. Huomaa, että program toteamus ei tarvitse nimetä ohjelmaa samaksi kuin tiedoston nimi. Tämä tiedosto on yleensä melko pieni, vain muutaman lausekkeita alustamiseksi, rakentaa lomakkeet, ajaa ja sulkea sovelluksen. Suurin osa työstä tehdään käännösyksiköiden lähdekooditiedostoissa, jossa on tiedostopääte ".pas"
 +
 
  
 
'''againu.lfm:'''
 
'''againu.lfm:'''
This is where Lazarus stores the layout of the form unit, in human readable form. It reflects the properties of the various components, as set in the Object Inspector. Each object description starts with a line:  
+
Lazarus tallentaa käännösyksikön lomakkeen ulkoasun, ihmisen luettavissa olevassa muodossa. Se kertoo eri komponenttien, ominaisuuksia jotka on asetettu komponenttimuokkaimella. Jokaisen komponentin kuvaus alkaa rivillä:
 
  object xxxx  
 
  object xxxx  
  then there follows a list of properties
+
    sitten seuraa ominaisuuksien luettelo
   (including embedded or nested objects) then an
+
   (Myös upotettuja tai sisäkkäisiä objekteja) sitten
 
  end  
 
  end  
line. Lazarus uses this file to generate a resource file (.lrs) that is included in the initialisation section of the againu.pas unit. Delphi dfm files can be converted to lfm format in the Lazarus IDE using the Tools->Convert DFM file to LFM utility.
+
rivi.
 +
 
 +
Lazarus käyttää tätä tiedostoa kun luo resurssitiedoston (.res). Delphi DFM tiedostot voidaan muuntaa lfm muotoon Lazarus kehitysympäristössä käyttäen: Työkalut -> Delphi muunnos -> Muunna binaarinen DFM-tiedosto teksti LFM:ksi ja tarkista syntaksi.
 +
 
 +
'''again.res:'''
 +
Tämä on luotu resurssi tiedosto, joka sisältää ohjeet ohjelman rakentamiseen (jos tarkastellaan pääohjelma tiedostoa, näette alustuksen osassa rivin
 +
 
 +
<syntaxhighlight lang="pascal">{$i *.res}</syntaxhighlight>
 +
joka ohjaa ohjelman lataamaan resurssitiedoston). Huomaa, että se ei ole Windows resurssi-tiedosto.
  
'''againu.lrs:'''
 
This is the generated resource file which contains the instructions to the program for building the form (if you look in the main Unit file, you will see in the initialization section the line
 
<syntaxhighlight>{$i againu.lrs}</syntaxhighlight>
 
which instructs the program to load the resource file). Note that it is not a Windows resource file.
 
  
 
'''againu.pas:'''
 
'''againu.pas:'''
The unit that contains the code for the form; this is usually the only file that the application programmer needs to edit or inspect, and contains any code specifically supplied by the programmer (especially event handlers).
+
Käännösyksikkö, joka voi sisältää myös lomakkeen koodin; tämä on yleensä vain tiedosto jota ohjelmoijan tarvitsee muokata tai tarkastaa, ja se nimenomaisesti sisältää  ohjelmoijan toimittamaa koodia (erityisesti tapahtuman käsittelijät).
  
 
'''againu.ppu:'''
 
'''againu.ppu:'''
This is the compiled unit which gets linked into the executable file together with any other units named in the Uses section.
+
Tämä on koottu käännöyksikkö, joka linkitetään suoritettavaan tiedostoon yhdessä muiden käännösyksiköiden jotka on nimetty Uses osiossa.
  
 
'''ppas.bat:'''
 
'''ppas.bat:'''
This is a simple script that links the program to produce the executable. If compilation is successful, it is deleted by the compiler.
+
Tämä on yksinkertainen skripti, joka yhdistää ohjelman tuottaman suoritettavan tiedoston. Jos käännös on onnistunut, kääntäjä poistaa sen.
 +
 
  
 
==Katso myös==
 
==Katso myös==
  
 
* [[Lazarus_IDE_Tools/fi|Lazarus IDE Tools]]
 
* [[Lazarus_IDE_Tools/fi|Lazarus IDE Tools]]
 +
* [[Lazarus project files]]

Latest revision as of 02:45, 8 December 2021

Deutsch (de) English (en) español (es) suomi (fi) français (fr) magyar (hu) italiano (it) 日本語 (ja) македонски (mk) Nederlands (nl) português (pt) русский (ru) slovenčina (sk) shqip (sq) 中文(中国大陆)‎ (zh_CN) 中文(台灣)‎ (zh_TW)

Tästä alkaa Lazarus Tutorial. Voit vapaasti parantaa sitä.

Yleistä

Lazarus on vapaa avoimeen lähdekoodiin perustuva ohjelmankehitysympäristö joka pohjautuu FreePascal Compiler (object pascal), Joka on myös vapaa ja avointa lähdekoodia. Lazaruksen käyttöliittymä ( kuvakaappauksia) on vakaa ja ominaisuuksiltaan monipuolinen ohjelman kehitysympäristö jolla voi tehdä itsenäisiä graafisia ja komentorivillä toimivia sovelluksia. Se toimii Linux:ssa, FreeBSD:ssä, Win32:ssa, Mac:ssa ja on varustettu customoitavalla lähdekoodieditorilla ja visuaalisella lomakkeen muotoilulla jossa mukana komponenttipakettienhallinta, virheenjäljitin ja täydelliset graafiset käyttöliittymäkomponentit integroituna FreePascal kääntäjään.

Aloittaminen

Hanki, asenna ja käynnistä Lazarus jossa pitää olla Free Pascal Compiler mukana.

Light bulb  Huomaa: Ainakin Linux Ubuntussa, Lazaruksen käynnistyskomento on konsolissa (päätteessä) "startlazarus". Jos olet asentanut Lazaruksen Debianin pakettina, niin Lazarus pitäisi olla valikkokohdan Sovellus / ohjelmointi alla. (Huomaa: Debian ja Ubuntu tärkeimmät binary ja paketti on nimeltään "Lazarus-ide", koska on myös "TCT" paketti jossa mukana tulee apuohjelma nimeltä "Lazarus").

Ensimmäinen Lazarus ohjelma!

Päävalikosta valitsemalla Projekti-Uusi projekti-Sovellus (tai: Tiedosto-Uusi-projekti-Sovellus) niin uusi graafinen sovellus luodaan, katso myös Form opetusohjelma .

Useita ikkunoita ilmestyy työpöydälle: Päävalikkoikkuna yläreunassa, Komponenttimuokkain on vasemmalla, "Lähdekoodieditori" täyttää työpöydän ja valmis lomake "Form1" on omassa ikkunassa (Form1 ) Lähdekoodieditorin päällä.

Jos halutaan sijoittaa painike lomakkeelle: Päävalikkoikkunan alaosassa on välilehtirivi. Jos "Standard" välilehti ei ole jo valittu, valitse se klikkaamalla hiirellä. Sen jälkeen etsii Button kuvakkeen (tbutton.png eli suorakulmio jossa on "OK"-teksti) ja klikkaa sitä hiirellä. Sitten Form1 ikkunassa klikataan jonnekin keskilinjan vasemmalla puolen. Varjostettu "Button1"-tekstillä merkitty suorakulmio ilmestyy siihen. Klikkaa jälleen Button kuvaketta Standard -välilehdellä ja klikkaa Form1-ikkunassa jonnekin oikealle keskelle: toinen "Button2"-tekstillä merkitty suorakulmio ilmestyy.

Nyt klikkaa Button1 jotta se valitaan. Komponenttimuokkainikkuna näyttää nyt kohteen Button1-ominaisuudet. Yläosassa on ominaisuus nimeltä 'Caption', jossa näytetään arvo "Button1". Klikkaa kyseistä kohtaa (ruudukkoa) ja muuta teksti "Button1" muotoon "Press". Jos painat Enter tai klikkaat toista ruutua näet että Form1-lomakkella ensimmäisen painikkeen teksti muuttuu "Press":ksi. Nyt klikkaat Tapahtumat -välilehteä komponenttimuokkaimessa niin näet erilaisia tapahtumia, jotka voivat liittyä tähän Button1-painikkeeseen. Näitä ovat onClick, OnEnter, OnExit jne. Valitse onClick oikealla puolella oleva ruutu. Tällöin siihen ilmestyy pienempi laatikko kolmella pisteellä (...). Kun klikkaat tätä, se otetaan automaattisesti osaksi lähdekoodieditorissa ja kursorin sijoitetaan koodinpätkän keskelle:

procedure TForm1.Button1Click(Sender: TObject);
begin
  {Kirjoita tai kopio&liitä tämä puuttuva osa:}  
  Button1.caption := 'Press again';
  {Lähdekoodieditori on jo täydentänyt aliohjelman lopun}
end;


Painamalla F12 nähdään lähdekoodieditorin sijasta lomakkeen Form1 ikkuna.

Nyt muokataan Button2 ominaisuuksia : klikkaa Button2 jotta nähdään sen ominaisuuksia komponenttimuokkaimessa. Muuta sen Caption ominaisuuteen (property) "Button2" tekstin tilalle "Exit". Valitse tapahtumat-välilehti ja klikkaa onClick. Klikkaa kolmea pistettä (...) ja sen jälkeen ollaan lähdekoodieditorissa, keskellä toisen Button2:n aliohjelmaa:

procedure TForm1.Button2Click(Sender: TObject);
begin
  {Kirjoita tai kopio&liitä tämä puuttuva osa:}    
   Close;
  {Lähdekoodieditori on jo täydentänyt aliohjelman lopun} 
end;

Painamalla F12 nähdään lomakkeen Form1 ikkuna uudelleen. Tallenna nyt työsi (ja muista tehdä se usein !!) valitsemalla päävalikosta Projekti-Tallenna projekti nimellä > sinun_valitsemalla_tiedosto_nimellä. Talletettavana on kaksi erilaista tiedostonimipäätettä (*.pas ja *.lpi). Valitse näille eri nimet. Jos molemmat ovat samannimisiä niin saat "duplicate identifier" käännösvirheen (katso luku "The Lazarus tiedostot" lopussa tämän aiheen lopussa).

Voit nyt yrittää kääntää. Yksinkertaisin tapa tehdä on valita "Suorita" päävalikon yläreunasta ja sitten "Suorita" vaihtoehto alivalikosta. Vaihtoehtoisesti voit yksinkertaisesti painaa F9. Tämä ensin kääntää ja sitten (jos kaikki on hyvin) linkittää sekä suorittaa kyseisen ohjelman.

Kääntäjän viestit ikkuna tulee näkyville ja kaikenlaisia kääntäjä viestejä siihen kirjoitetaan, mutta lopulta sinun Form1 ikkuna ilmestyy näyttöön uudelleen, mutta ilman ruudukon pisteitä. Tämä sovelluksesi pääikkuna ja se odottaa että sinä painat painonappeja tai olet muutoin vuorovaikutuksessa sen kanssa.

Kokeile klikkaamalla painiketta joka on nimetty tekstillä "Press". Huomaat, että sen teksti muuttuu "Press again" tekstiksi. Jos painat sitä uudelleen, sen teksti on silti "Press again" !!

Nyt klikkaat painiketta joka on nimetty tekstillä "Exit". Ikkuna sulkeutuu ja ohjelma päättyy. Alkuperäinen Form1 ikkuna ruudukon pisteillä ilmestyy uudelleen ja on valmis hyväksymään lisää muokkausta toimintaansa.

Muokkaa ohjelmaa

Uudelleen avaa tallennettu projekti. Sen Form1 ikkunassa klikkaa "Press" painiketta (Button1) valitseksesi se. Valitse "Tapahtumat" -välilehti komponenttimuokkaimessa, klikkaa onClick:n oikealla puolella olevaa ruutua, klikkaa kolmea pistettä (...), jolloin siirryt oikeaan kohtaan lähdekoodieditorissa.

Muokkaa kyseinen kohta koodia seuraavanlaiseksi:

procedure TForm1.Button1Click(Sender: TObject);
{Hyödynnetään Tag ominaisuutta, se saa arvot 0 tai 1}
begin
  if Button1.tag = 0 then
  begin
    Button1.caption := 'Press again';
    Button1.tag := 1;
  end else
  begin
    Button1.caption := 'Press';
    Button1.tag := 0;
  end;
end;

Tallenna työsi, uudelleen käännä ja suorita. Vasen painike nyt vaihtaa tekstiä kahden vaihtoehdon välillä.

Loput on sinusta kiinni!

Jos haluat kirjoittaa konsoli(pääte)- tai tekstipohjaisia Pascal ohjelmia (esimerkiksi jos seuraavana on perustiedot Pascal ohjelmoinnista kurssi tai täytyy kirjoittaa ohjelmia joita käytetään eräajona tai järjestelmäohjelmointia), voit silti käyttää Lazarus muokkaamaan , kääntämään ja ajamaan ohjelmia. Katso Komentoriviohjelmointi Pascalilla.


Kehitysympäristön ikkunat

Kun käynnistää Lazarus ensimmäistä kertaa niin joukko erillisiä irti olevia tai "kelluvia" ikkunoita näkyy työpöydällä.

Ensimmäinen, oikealla yläreunassa pitkittäin on otsikoitu "project1 - Lazarus IDE vXXXXXX" (jonka nimi muuttuu vastaamaan nimiä parhaillaan auki olevasta projektista). Tämä on tärkein ikkuna ja se sisältää mm päävalikon ja komponenttipaletin.

Lazarus-IDE.jpg

Otsikkopalkin alapuolella oleva rivi on päävalikko jossa on merkinnät Tiedosto, Muokka, Etsi, Näytä ja niin edelleen. Tämän alapuolella vasemmalla on joukko symboleja (kuvakkeita jotka vievät nopeasti tiettyihin valikkokomentoihin) ja oikealla on komponenttipaletti.

Tämän alle vasemmalla on komponenttimuokkain ('Object Inspector') ikkuna ja Lazaruksen lähdekoodieditori oikealla. Siellä voi olla toinen pienempi ikkuna joka on (aluksi) merkitty nimellä "Form1", Lazaruksen lähdekoodi-ikkunan päällä. Jos tämä ei ole näkyvissä heti, se voidaan saada näkymään painamalla F12. Kyseinen funktionäppäin vaihtaa vuorotellen lähdekoodieditorin ja lomakenäkymän välillä. Lomake (Form) ikkuna on se, johon voidaan rakentaa graafisen käyttöliittymän sovellukseen, kun taas lähdekoodieditorin ikkuna näyttää sovelluksen Pascal koodin jota kehitetään. Komponenttimuokkaimen toiminta on käsitelty tarkemmin alla, kun komponenttipaletti on ensin kuvattu. Lisäksi voi olla myös viesti -ikkuna näytön alareunassa: tätä käytetään näyttämään Lazaruksen palautetta ohjelmoijalle, esimerkiksi ohjelmaa käännettäessä.

Kun aloittaa uuden projektin (tai kun käynnistää Lazarus ohjelman kehitysympäristön) niin oletus lomake rakennetaan, joka koostuu laatikosta, jossa on pisteruudukko, joiden avulla voit sijoittaa eri komponentteja lomakkeelle ja lomakkeen yläpalkki, joka sisältää tavallisesti minimointi, maximointi ja Sulje-painikkeet. Jos klikkaat hiiren kohdistimella mihin tahansa tähän lomakkeeseen, näet vasemmalla puolen komponenttimuokkaimen joka kertoo tämän lomakkeen ominaisuuksia.

Muut ikkunat, jotka voivat tulla näkyviin työskentelyn aikana: Projektin hallinta, joka sisältää yksityiskohtaiset tiedot tiedostojen mukana olosta projektissa. Siinä voidaan lisätä tai poistaa tiedostoja projektista; Viesti-ikkuna, joka näyttää kääntäjän viestejä, virheitä tai edistymisraportteja projektista. Jos Lazarus käynnistettiin pääteikkunasta (konsoli) niin alkuperäinen pääteikkuna pysyy näkyvissä ja yksityiskohtaiset kääntäjän viestit tulostetaan myös siellä.


Päävalikko

Päävalikko sisältää seuraavat nimikkeet:

Tiedosto   Muokkaa   Etsi   Näytä   Lähdekoodi   Projekti   Suorita-valikko   Paketti   Työkalut   Ikkunat   Ohje

Kuten tavallista, vaihtoehdot voidaan valita joko asettamalla hiiren osoitin valikkokohdan ja klikkaamalla hiiren vasenta painiketta.

Lisätietoja saat ottamalla yhteyttä Main menu/fi.


Pikapainikkeet

Pieni työkalurivi pääikkunan vasemmalla puolen, päävalikon alapuolelle jonka vasemmalla puolen on komponenttipaletti. Se sisältää joukon painikkeita, jotka ovat samoja kuin usein käytetyt päävalikon valinnat: Uusi käännösyksikkö, Avaa (jossa on alas-nuolta painamalla saadaan näyttämään avattavan listan viimeksi käytetyistä tiedostoista), Tallenna, Tallenna kaikki, Uusi lomake, Vaihda lomake / käännösyksikkö (eli näyttää joko lomakkeen tai käännösyksikön lähdekoodia), Näytä käännösyksiköt, Näytä lomakkeet, Suorita (eli kokoa ja suorita), Pysäytä, Askella sisään, Askella yli (kaksi viimeistä ovat virheenjäjityksen toimintoja).


Komponenttipaletti

Komponenttipaletti on IDE:ssä oleva välilehti- työkalurivi, joka näyttää suuren määrän kuvakkeita, jotka edustavat yleisesti käytettyjä komponentteja lomakkeen suunnittelua varten.


size="100%

Component Palette
Standard - Additional - Common Controls - Dialogs - Data Controls - Data Access - System - Misc - LazControls - RTTI - SQLdb - Pascal Script - SynEdit - Chart - IPro

Jokainen välilehti näyttää joukon eri kuvakkeita, ne edustaa eri komponenttien funktionaalista ryhmää. Jokaisen välilehden vasemmanpuoleisin kuvake on viistosti vasemmalle suunnattu nuoli, jota kutsutaan valintatyökaluksi (Selection Tool).

Jos annetaan hiiren kohdistimen siirtyä jonkin komponenttipaletin kuvakkeen päälle klikkaamatta kuvaketta, kyseisen komponentin nimi tulee näkyviin. Huomaa, että jokainen nimi alkaa 'T': llä - tämä tarkoittaa komponentin "tyyppiä" tai tarkemmin "luokkaa". Kun valitaan komponentin lomakkeelle niin luokka lisätään käännösyksikön tyypin (Type) esittelyosaan (interface) (oletusarvoisesti TForm1: nä) ja kyseisen luokan esiintymä ( instance ) lisätään var-osioon (oletusarvoisesti muuttujana Form1). Kaikki ne metodit, joita suunnitellaan käytettäväksi lomakkeen tai sen komponenttien (eli aliohjelmien tai funktioiden) avulla, sijoitetaan käännösyksikön implementation eli toteutusosaan.

Kuinka komponenttipalettia käytetään

Komponenttipaletin käyttämiseksi editorissa on oltava avoin lomake (jos sellaista ei ole, valitse Tiedosto -> Uusi lomake). Klikataan haluttua komponentitpaletin sopivassa välilehdessä olevaa kuvaketta ja klikataan sitten lomaketta, lähellä sitä kohtaa, jossa halutaan komponentin näkyvän. Kun haluttu komponentti tulee näkyviin, voidaan se valita klikkaamalla hiirtä. Kun lomake on valittu, kohde on myös valittu myös Komponenttimuokkain-ikkunassa, jossa voidaan muokata sen ominaisuuksia ja tapahtumia.

Objektin visuaalisen ulkonäön säätäminen voidaan tehdä joko muuttamalla itse lomaketta lomakkeella hiirellä tai muuttamalla kyseistä ominaisuutta komponenttimuokkaimessa.

Jos asennetaan lisäkomponentteja, itsetehdyt tai ne, jotka tulevat pakettina toisesta lähteestä niin komponenttipaletissa näkyy ylimääräisiä välilehtiä, joissa on kyseiset kuvakkeet. Nämä uudet osat voidaan valita ja käyttää lomakkeella samalla tavalla kuin oletuksena olevat komponentit.

Seuraavissa komponenttien luettelossa on linkkejä tiedostoihin, jotka sisältävät niiden käännösyksiköiden kuvaukset, joista ne löytyvät. Jos halutaan tietää tietyn komponentin ominaisuuksista, on usein syytä tarkastella kyseisen komponentin perintää ja tarkastaa sitten sen perustyypin ominaisuudet, josta se on johdettu. Esimerkiksi TMaskEditin ymmärtämiseksi on myös hyödyllistä tutkia TCustomMaskEdit.

Räätälöinti

Valikon [Työkalut | Asetukset] tai Crtl-Shift-O:n avulla voit muuttaa komponenttipaletti-elementtien asettelua ja näkyvyyttä. IDE Options - Environment - Component Palette.png

Esimerkit

Useita hyödyllisiä valintaikkunoita (aliohjelmia tai funktioita) ei näy paletissa, mutta niitä voidaan helposti käyttää suorina kutsuina ohjelman lähdekoodissa.

Useita hyviä esimerkkejä Komponenttien käytöstä on lähdeasennuksen $LazarusPath/lazarus/example-alikansiossa. Monet ohjelmista osoittavat, miten dialogeja ja muita komponentteja käytetään suoraan ilman IDE- ja komponenttipalettia tai erillistä lomakkeen määritystiedostoa: kaikki komponentit on määritelty kokonaisuudessaan ja nimenomaisesti Pascal-pääohjelmassa. Muut esimerkkiohjelmat hyödyntävät täysin IDE:ä.

Muista avata nämä esimerkit projekteina .lpi-tiedostolla. .Pas-lähdekooditiedoston avaaminen ja RUN: n lyöminen vain lisää tämän lähdetiedoston mihin tahansa viimeksi avattuun projektiin.

Jotkut esimerkit eivät toimi heti: voi joutua asettamaan tiedostojen tai hakemistojen polkuja ja käyttöoikeuksia. Jos halutaan kääntää mikä tahansa esimerkki niin pitää varmistaa, että on tiedostojen ja hakemistojen luku- / kirjoitus- / suoritusoikeudet tai kopioida tiedostot hakemistoon, jossa on asianmukaiset oikeudet.

Kokeilemalla 'testall'-ohjelmaa nähdään käytettävissä olevien komponenttien valikko yhdessä pienen esimerkkitestin kanssa useimmille niille; Sen jälkeen voi tarkastella niiden koodia, miten he toimivat!


Kuinka käyttää komponentteja

Käännösyksiköt StdCtrls, ComCtrls ja ExtCtrls sisältävät määritelmät ja kuvaukset moniin yleisimmin käytettyihin komponenteihin, lomakkeen rakentamiseen ja muihin objekteihin Lazarus sovelluksissa.

Sovelluskehittäjän usein lopullisena tavoitteena on että halutaan käyttää komponentteja kuten TButton, TMemo, TScrollBar jne, näiden vastaava kantaisät ovat luokat TCustomButton, TCustomMemo tai TCustomScrollBar. Usein ominaisuuksia ja metodeiden merkitystä on määritelty (ja selitetty) täydellisemmin TCustomXXX luokassa ja ne periytyvät näihin lopullisiin tavoite komponentteihin.

Jos pudotat komponentin lomakkeelle niin silloin ei tarvita lisätä koodia luomaan sitä. Komponentti automaattisesti luodaan lomakkeen yhteydessä ja tuhotaan kun lomake on tuhottu. Jos kuitenkin luodaan komponentti (omatoimisesti) koodilla niin ei saa unohtaa sen vapauttamista, kun sitä ei enää tarvita.

Tapoja asettaa ominaisuuksia

Jos asetetaan komponentti lomakkeelle ja katsotaan komponenttimuokkaimella niin voidaan tarkkailla kun ominaisuudet muuttuvat, kun siirrät komponettia ympäriinsä.

Jos esimerkiksi asetetaan painike (TButton) lomakkeelle, valitaan se klikkaamalla sitä niin sen hiirellä siirtämistä ympäri lomaketta hiirellä, voidaan katsella Top ja Left arvojen muutosta vastaamaan uutta asentoon komponenttimuokkaimella. Jos käytetään objektin uudelleen mitoitusta säätämään sen kokoa niin voidaan katsella Height (korkeus) ja Width (leveys) ominaisuuksien muuttumista myös.

Toisaalta, käyttämällä komponenttimuokkainta voidaan valita arvon liittyvä ominaisuus, kuten height (korkeus), ja kirjoittaa siihen uusi arvo niin voidaan katsella lomakkeella kohteen koon muutosta vastaamaan uutta arvoa.

Voidaan myös nimenomaisesti muuttaa komponentin ominaisuuksia koodin kirjoittamalla (asianmukaisessa implementation lohkossa lähdekoodieditorissa), esimerkiksi


Form1.Button1.Height := 48;

Yhteenvetona, on yleisesti kolme erilaista tapaa määrittää jokaisen komponentin ominaisuuksia:

  • hiiren avulla lomakkeella
  • asettamalla arvot komponenttimuokkaimessa
  • eksplisiittisesti kirjoittamalla koodia editorissa.

Yleisiä ominaisuuksia

Komponenttien käännösyksiköissä on määritelty useita ominaisuuksia, jotka ovat yhteisiä useimmille niistä ja muita ominaisuuksia jotka ovat ominaisia ​​yksittäisille komponenteille. Yleisimpiä on kuvattu tässä. Epätavallisia tai okomponenttiriippuvaisia ominaisuuksia kuvataan tarkemmin komponettikohtaisissa ohjeissa.

Lisäohjeita saadaan valitsemalla ominaisuus tai avainsana, joko komponenttimuokkaimessa tai lähdekoodieditorissa ja painamalla F1. Tämä vie ohjeen oikealle sivulle dokumentaatiossa.

Jos ominaisuuden kuvaus on sivulla riittämätön, voidaan siirtyä katsomaan mistä se on peritty.


Joitakin yleisesti olevia ominaisuuksia
OminaisuusMerkitys
Action Tärkein toiminta tai tapahtuma joka liittyy komponenttiin. Esimerkiksi valitsemalla "Lopeta" -painike saattaa aiheuttaa Sulje-toiminnan.
Align Määrittää miten komponentti on sijoittunut vanhempaansa nähden. Mahdolliset arvot ovat alTop (sijoittuu yläosaan ja käyttää koko käytettävissä olevan leveyden), alBottom, alLeft (sijoittuu vasemmalle ja käyttäen koko käytettävissä olevan korkeuden), alRight. alNone (missä tahansa) tai alClient (käyttää kaiken käytettävissä olevan tilan)
Anchor Käytetään pitämään komponentti tietyn etäisyyden päässä vanhemmasta komponentista, määritelty reunoista, kun vanhempi muuttaa kokoa. Esimerkiksi [akBottom, akRight] pitää komponentin kiinteän matkan päässä oikeaan alakulmaan.
AutoSelect Kun sen arvo on True niin valitaan kaikki se teksti, joka on valittu kun Enter-näppäintä painetaan tai hyväksytään kyseinen kohta.
AutoSelected True osoittaa, että Edit tai ComboBox komponentti on juuri suorittanut AutoSelect toiminnan siten, että myöhemmät hiirellä ja näppäimistön syöttö jatkuu normaalisti valitsematta tekstiä.
BorderSpacing Ankkuroidun komponentin ja sen vanhemman välisen ympäröivän reunan etäisyys.
Caption Teksti, joka näkyy tai on lähellä komponenttia; Ohjelman käyttäjälle tulee antaa vihjeen siitä, minkä tehtävän tai käskyn komponentti tekee kuten "Sulje" tai "Suorita". Oletuksena Caption-teksti asetetaan samaksi kuin mitä on "Name" ominaisuudessa ja ohjelmoijan pitäisi oletusarvon sijaan korvata se sopivalla tekstillä.
CharCase Kertoo, miten teksti näkyy tekstin muokkauskomponentissa: Normaali (sellaisenaan, säilyttäen käyttäjän antaman syötteen), muunnetaan isoiksi tai pieniksi kirjaimiksi.
Constraints Asettaa äärikoot komponentille. Jos kokoa muutetaan niin uudet ulottuvuudet ovat aina vaihteluvälien rajoissa. Ohjelmoikan tulisi huolehtia asettaessaan näitä, että ne eivät ole ristiriidassa Anchors ja Align asetuksien kanssa.
Color Väri jota käytetään piirtämään komponentti ja sen näyttämää kirjoitettavaa tekstiä.
Enabled Boolean ominaisuus joka määrittää, onko komponentti valittavissa, käytössä tai voiko se suorittaa toiminnon. Jos se ei ole käytössä (arvossa false) niin se on usein harmaana lomakkeella.
Font Kirjaisin jota käytetään kirjoitettaessa tekstiä komponenttiin liittyen - joko caption, label tai teksti komponentin sisällä . Komponenttimuokkaimessa on nuoli-merkintä yleensä tämän kohdan vasemmalla puolen, ja valitsemalla se niin se paljastaa muita vaihtoehtoja kuten merkistön, värin ja koon.
Height Komponentin korkeus. Katso myös Width.
Hint Lyhyt informatiivinen vihjeteksti joka näkyy ponnahdustekstinä, jos hiiren kursori menee komponentin päälle. Katso myös ShowHint ominaisuus.
Items Luettelo "asioista", jota kohde sisältää, kuten joukko kuvia, luettelo tekstiä, toimintoja käytettäessä actionlist:aa jne.
Left Määrittää missä komponentti sijaitsee suhteessa vanhempaan (lomake, ikkuna) vaakasuunta. Katso myös Top
Lines Merkkijonojen joukko, joka sisältää tekstisisältöä enemmän kuin yhden rivin tietoja. Taulukko on nolla-indeksoitu eli rivit on numeroitu (alkaen nollasta)[0..numLines-1]
Name Tunniste eli nimi, jonka avulla komponentti tunnetaan ohjelmassa. Kehitysympäristö antaa sille oletuksena nimen joka pohjautuu taustalla tyypin mukaan, esimerkiksi peräkkäisinä esiintyvät TBitButton-komponentit olisivat nimeltään BitButton1 ja BitButton2; Olisi hyvä jos ohjelmoija antaisi näille enemmän kuvaavampia nimiä kuten ExitButton tai OKButton. Oletuksena komponentin nimi viedään myös Caption tekstiksi, mutta Caption teksti voidaan muuttaa erikseen.
PopUpMenu Ikkuna joka sisältää tilannekohtainen valikkotietoa, joka avautuu, kun hiiren oikealla painikkeella klikataan komponenttia.
ReadOnly Boolean omonaisuus, ja jos sen arvo on true, niin tarkoittaa sitä että käyttäjä tai kutsuva rutiini voi luke komponentin sisältö, mutta se ei voi kirjoittaa siihen tai muuttaa sitä.
ShowHint Sallii pienen tekstikentän, joka sisältää tilannekohtaisen ​​ohjeen tai muun kuvauksen, joka näkyy, kun hiiren kursori on komponentin "päällä". Katso Hint-ominaisuutta.
Style Valittavissa olevia tyylivaihtoehtoja: esimerkiksi Style voidaan määrittää TFormStyle, TBorderStyle, TButtonStyle jne.
TabOrder Kokonaisluku määritellään missä järjestyksessä Tab -näppäin käy läpi lomaketta.
TabStop Boolean ominaisuus jos True niin paikka johon käyttäjä voi päästä peräkkäin painamalla Tab eli sarkainnäppäintä.
Text Merkkijono teksti, joka edustaa todellisia tietoja, mitä tämä komponentti sisältää. Koskee erityisesti Text, Memo ja StringList tyyppisiä komponentteja. Suurin osa editointi (kuten Select, Clear, Cut, Copy) suoritetaan komponentin tässä osassa, joka sisältää todellisen muokattavan merkkijonon. Jos komponentissa on enemmän kuin yksi rivi tekstiä, esimerkiksi TMemo tai TComboBox, niin tekstielementtejä on järjestetty merkkijonojoukoiksi (nolla-indeksoitu eli numeroituna [0..rivien määrä-1]) rivejä.
Top Määrittää missä komponentti sijaitsee suhteessa vanhempaan (lomake, ikkuna) pystysuunta. Katso myös Left
Visible Jos ominaisuuden arvo on true niin komponentti näkyy lomakkeella. Jos arvo on false niin komponentti on piilotettu.
Width Komponentin leveys. Katso myös Height.
WordWrap Looginen lippu osoittaa, onko automaattinen rivinvaihto on käytössä, eli jos sana tulee lähelle rivin loppuun ja tulee olemaan liian pitkä rivi niin osa siitä on siiretty (alaspäin) seuraavalle riville.

Tapahtumat

Monet tapahtumat ovat yleisesti lueteltu "Tapahtumat" välilehdellä komponenttimuokkaimessa. Jos komponenttimuokkaimessa valitaan tapahtuman viereinen tyhjäkenttä kenttä niin siihen muodostuu ComboBox jonka alasvetoluettelosta näkyy luettelo kaikista toimista jotka on jo määritelty. Tämän avulla voidaan valita tähän tapahtumaan yhden kohdan. Vaihtoehtoisesti voit valita kolme pistettä ...-painike jolloin lähdekoodieditorissa tehdään metodin sisään alue johon voidaan aloittaa kirjoittamaan oman toiminnan käskyjä valittuun tapahtumaan.

Vaikka suuri määrä tapahtumia on liitettävissä komponentin toimintaan. Käytännössä se on tarpeen vain asettaa muutamaan niistä. Useimmille komponenteille on riittävää koodaata onClick-tapahtuma; monimutkaisemmissa komponenteissa voi olla tarpeen myös kirjoittaa toiminta tapahtumiin "OnEntry" (kun hiiren osoitin siirtyy komponentille ja se valitaan) ja "OnExit" (kun hiiren osoitin poistuu komponentilta), tai ehkä kirjoittaa tapahtumankäsittelijä "OnChange" tai "OnScroll" -tapahtumiin, riippuen komponenteista, jonka kanssa ollaan tekemisissä.

Pop-up-valikko, joka tulee näkyviin hiiren oikealla painikkeella kun komponenttia klikataan lomakkeella. Siinä ensimmäisenä vaihtoehtona on: "Luo oletustapahtuma". Valitsemalla tämän vaihtoehdon on sillä sama vaikutus kuin valitsemalla kolme pistettä komponenttimuokkaimen oletuksena olevassa tapahtumassa joka on yleensä "onClick". Eli lähdekoodieditorissa tehdään metodin sisään alue johon voidaan aloittaa kirjoittamaan oman toiminnan käskyjä.

Yleinen strategia Olio-ohjelmoinnissa on tarjota ActionList johon on tehty useita ennalta määriteltyjä toimenpiteitä, joista sopivin voidaan valita käyttöön siinä tapauksessa.



Joitakin yleisiä tapahtumia
Tapahtuma Merkitys
OnChange Tapahtuu jos jokin muutos havaitaan (esim hiiren liikkua, hiiren klikkaus, näppäimen painallus, tekstin muokkaus, kuva muuttuu jne)
OnClick Tapahtuu kun (ensimmäinen, yleensä vasenta) hiiren painiketta klikataan. Tämä on yleensä pää- tai oletus toiminto; esimerkiksi kun klikataan painiketta tai muuta vastaavaa.
Click Menetelmä matkia koodina klikkaamisen vaikutusta. Tämä menetelmä on useimmiten löytyy Button-tyyppisistä komponenteista (TButton, TBitBtn, TSpeedButton jne). Aliohjelma voidaan kirjoittaa niin että kutsutaan samaa koodia kuin onClick toiminta. Tämä järjestely voi olla erityisen hyödyllistä, jos yhden komponentin aktivointi klikkaamalla aiheuttaa lukuisiin muiden komponenttien aktivointia, ja valitsemalla menetelmä voidaan käyttää aloittamaan toiminto sen sijaan, käyttäjä joutuu klikkaamaan monia komponentteja.
OnDragDrop Toteuttaa toimet vedä ja pudota (Drag-Drop) liikkeen aikana, eli kun hiirtä käytetään "kaappaamaan" kohteen tai jotain tekstiä jne ja siirtää sen uuteen paikkaan.
OnEditingDone Toiminta alkaa kun käyttäjä on lopettanut kaikki muutokset / muutokset komponenttiin. Tätä käytetään usein tarkistamaan komponentin sisältöä (esim. tarkistamaan että syötetty teksti on oikea tai kunnollinen IP-osoite)
OnEntry Toteuttaa toimet kun hiiren osoitin siirtyy komponentille tai yleisesti kun "painopiste" siirtyy komponenttiin. Tämä saattaa sisältää muutoksia komponentin ulkonäköön kuten korostamaan sitä tai kohottamaan sen reunuksia.
OnExit Tapahtuma aktivoituu, kun hiiri siirtyy pois komponentin alueelta, yleisesti siirtämällä "painopiste" pois komponentilta.
OnKeyPress Tapahtuma aktivoituu, kun painetaan jotain näppäintä. Hienovaraisesti erilainen kuin OnKeyDown, joka yksinkertaisesti aktivoituu näppäimen ollessa alhaalla. OnKeyPress vaatii, että painopiste on jo tässä komponentissa kun näppäintä painetaan.
OnKeyDown Tapahtuma aktivoituu, jos näppäin on alhaalla, kun "painopiste" (fokus) on tässä komponentissa. Hienovaraisesti erilainen kuin OnKeyPress - esimerkiksi näppäin saattaa olla jo alhaalla, kun focus tuli tähän komponenttiin, kun taas OnKeyPress vaatii näppäintä painetaan vasta kun painopiste on tässä komponentissa.
OnKeyUp Tapahtuma aktivoituu kun näppäin "vapautetaan" eli nousee ylös (tai näppäimen painaminen loppuu) kun focus on tässä komponentissa.
OnMouseMove Tapahtuma aktivoituu kun hiiren osoitin liikkuu ja focus on tässä komponentissa.
OnMouseDown Tapahtuma aktivoituu kun hiiren näppäin menee alas ja focus on tässä komponentissa.
OnMouseUp Tapahtuma aktivoituu kun hiiren näppäin "vapautetaan" ja focus on tässä komponentissa. Eli hiiren näppäin on jo aikaisemmin painettu alas ja painaminen lopetetaan/päätetään
OnMouseEnter Tapahtuma aktivoituu kun hiiren osoitin siirtyy komponentille ( mutta hiiren painiketta ei vielä ole painettu) .
OnResize Tapahtuma aktivoituu kun komponentin kokoa muutetaan tai koko muuttuu. Voi aktivoitua esim. kun teksti tasataan toiseen reunaan, keskitetään tai valitaan eri fonttikokoa jne.

Rakentajat & purkajat

Nämä ovat kaksi erityistä metodia liittyvät luokkiin(komponentit):

  • Constructor (Rakentaja): kuten Create varaa olion (komponentin) tarvitsemaa muistia ja järjestelmäresursseja. Ne tarpeen vaatiessa kutsuvat myös muita luokan aliolioiden rakentajia.
  • Destructor (purkaja): poistaa olion ja vapauttaa varatun muistin sekä muita resursseja. Jos kutsut Destroy (tuhoa) olio, jota ei ole vielä alustettu,niin se aiheuttaa virheen. Käytä aina Free metodia puratessa olioita, koska se tarkistaa, onko olion arvo on nil ennenkuin kutsuu Destroy metodia.

Noudata seuraavia varotoimia, kun luoda oman Destroy metodin:

  • Määritä Destroy override directive:llä, koska se on virtual metodi.
  • Kutsu aina 'inherited Destroy;' viimeisenä asiana destructor:in koodissa.
  • Huomaa, että exception (poikkeus) voidaan nostaa jos constructor (rakentajalla) ei ole tarpeeksi muistia luoda olio tai jotain muuta menee pieleen. Jos poikkeusta ei käsitellä rakentajan sisällä, olio on tällöin vain osittain rakennettu. Tässä tapauksessa kun Destroyta kutsutaan, destructor:in täytyy tarkistaa että resurssit olivat todella varattu ennen kuin se hävittää ne.
  • Muista kutsua Free metodia kaikille olioille jotka on luotu constructor:lla.

Kuinka käyttää valikko-komponenttia

Vihjeitä miten luoda valikot lomakkeelle.

TMainMenu tmainmenu.png on päävalikko, joka näkyy monen lomakkeen yläosassa; Lomakkeen suunnittelija voivat muokata sitä valitsemalla eri valikkovaihtoehtoja. TPopupMenu tpopupmenu.png on valikko -ponnahdusikkunassa, jossa on yleensä tilannekohtaisia, yksityiskohtia vaihtoehtoja. Se "ponnahtaa" kun hiiren oikeaa näppäintä klikataan lähellä komponenttia.

Päävalikko on ei-näkyvä komponentti: toisin sanoen jos kuvake on valittu komponenttipaletilta ja saatetaan lomakkeelle niin se ei näy ohjelman ajon aikana. Sen sijaan, valikkorivi jonka rakenne määritellään valikkomuokkaimessa ilmestyy. Ponnahdusvalikot (saattaa lomakkeelle valitsemalla kyseinen kuvake komponentipaletilta) eivät näy ollenkaan kunnes hiiren oikealla painikkeella klikataan komponenttia, jolla on tällainen valikko.

Nähdäksesi valikkomuokkaimen, klikkaa hiiren oikealla Main Menu tai Popup Menu -kuvaketta lomakkeella. Tällöin avautuu ikkuna johon voidaan syöttää valikon kohteet.

valikkomuokkaimessa näkyy laatikko joka sisältää painikkeen "New Item1". Jos klikkaa hiiren oikealla kyseistä painiketta, pop-up-valikko tulee näkyviin, jonka avulla voit lisätä uuden kohdan ennen tai jälkeen (samalla tasolla) tai luoda alivalikon mahdollisuuden johon lisätä uusia kohteita sen alle.

Mikä tahansa MenuItems joka lisätään voidaan määrittää käyttämällä komponenttimuokkainta.

Ainakin kullekin kohdalle pitäisi antaa Caption-teksti , joka näkyy valikkorivillä. sen tulisi kertoa toimintaa jota voidaan valita, kuten "Avaa tiedosto", "Sulje", "Suorita" tai "Lopeta". Voidaan myös haluta antaa tätä merkityksellisempi nimi.

Jos halutaan tietyn Caption-tekstni kirjaimen liittyvän pikanäppäin-toimintoon, niin kirjain pitäisi edeltää et-merkillä (&). Jolloin ohjelman ajon aikana valikkokohtaan ilmestyy pikanäppäintä vastaava kirjain alleviivattuna ja painamalla kirjainta vastaavaa näppäintä on sillä sama vaikutus kuin valitsemalla valikosta. Vaihtoehtoisesti voidaan pikanäppäin sekvenssit (esimerkiksi Ctrl+C kopioi tai Ctrl+V liitä - standardin mukaiset pikanäppäimet) valita MenuItem:n ShortCut ominaisuuteen.

Usein on hyödyllistä käyttää valikoiden yhteydessä TActionList komponenttia joka sisältää joukon standardin mukaisia tai räätälöityjä tapahtumia. Valikkokohdat voidaan linkittää komponenttimuokkaimessa lueteltuihin tapahtumiin ja samoja tapahtumia voidaan yhdistää painikkeisiin, työkalupalkin painikkeihin, pikapainikkeisiin jne. On tietenkin tehokkaampaa käyttää uudelleen samaa koodia vastata erilaisiin tapahtumiin, kuin kirjoittaa erillinen OnClick tapahtumakäsittelijä jokaiseen yksittäiseen komponenttiin.

Oletuksena useita standarditapahtumia ovat valmiiksi ladattu. Nämä tapahtumat voidaan valita käyttämällä toimintolistan muokkainta joka näkyy, kun hiiren klikkaa ActionList kuvaketta lomakkeella.

Virheenjäljitys

Jotain kirjoitettu toisaalla.

1) Varmista, että olet lukenut sen asetukset: Debugger_Setup

2) Katso myös category: IDE Window - Debug

3) Lue rajoitukset: GDB_Debugger_Tips#Inspecting_data_types_.28Watch.2FHint.29 Tämä sivu antaa ohjeita myös joidenkin alustoiden / versioiden erityiskysymyksiln


Lazarus tiedostot

   (Kiitokset: Kevin Whitefoot.)
   (Lisäykset: Giuseppe Ridinò, User:Kirkpatc ja Tom Lisjac)

Kun tallennat niin tallennat kahden nimisiä tiedostoja:

  xxx.pas ja yyy.lpr 

(Todellisuudessa tallennetaan enemmän mutta niillä on sama nimi mutta eri pääte). Projektitiedoston (lpr) ja käännösyksikön tiedoston (pas) nimi ei saa olla sama. Tietenkin on johdonmukaista muuttaa kaikki esiintymät Unit1 kuuvaavimmiksi nimiksi.

Joten jos tallennat projektin nimeltä again, yrittää tallentaa again.pas ja again.lpr epäonnistuu, koska yksiköiden nimet ja ohjelmien nimet ovat samassa nimiavaruudessa ja on tuloksena kehitysympäristö kertoo että on olemassa samanniminen tiedosto.

Joten tähän päädyttiin:

e:/lazarus/kj/lazhello:

total 4740  free 76500
-rwxrwxrwx   1 kjwh     root  4618697 Mar 24 11:19 again.exe
-rw-rw-rw-   1 kjwh     root     3002 Mar 24 11:21 again.lpi
-rw-rw-rw-   1 kjwh     root      190 Mar 24 11:18 again.lpr
-rw-rw-rw-   1 kjwh     root      506 Mar 24 11:08 againu.lfm
-rw-rw-rw-   1 kjwh     root      679 Mar 24 11:08 again.res
-rw-rw-rw-   1 kjwh     root      677 Mar 24 11:08 againu.pas
-rw-rw-rw-   1 kjwh     root     2124 Mar 24 11:08 againu.ppu
-rwxrwxrwx   1 kjwh     root      335 Mar 24 11:07 ppas.bat

Huomaa, että on olemassa paljon enemmän tiedostoja kuin ne kaksi, jotka aluksi mainittiin.


again.exe: Pääohjelma joka on ajettavissa. MS windows:ssa lisätään "exe" tiedostopäätelaajennus. Linux:ssa ei lisätä mitään (vain ohjelman nimi). Tämä tiedosto on oletuksena paljon tilaa vievä johtuen sen sisällyttämistä virheenkorjaus symboleista. Kokoa voi pienentää muuttamalla kehitysympäristön asetuksia tai/ja ajamalla "strip" apuohjelma joka poistaa niitä ja merkittävästi pienentää ajettavan tiedoston kokoa.


again.lpi: (Lazarus Project Information). Tämä on tärkein informaatio tiedosto Lazarus projektilla; Delphissä sitä vastaavat tärkeimmät tiedot on .dpr tiedostossa. Se on tallennettu XML-muodossa ja sisältää ohjeet kaikista kirjastoista ja tarvittavista käännösyksiköistä kun rakennetaan suoritettavaa tiedostoa.

again.lpr: Pääohjelma lähdekooditiedostona. Huolimatta erityisestä tiedostopääte tarkenteesta niin se on itse asiassa täysin normaalia Pascal lähdekooditiedosto. Siinä on uses lauseke, jonka avulla kääntäjä löytää kaikki käännösyksiköt joita se tarvitsee. Huomaa, että program toteamus ei tarvitse nimetä ohjelmaa samaksi kuin tiedoston nimi. Tämä tiedosto on yleensä melko pieni, vain muutaman lausekkeita alustamiseksi, rakentaa lomakkeet, ajaa ja sulkea sovelluksen. Suurin osa työstä tehdään käännösyksiköiden lähdekooditiedostoissa, jossa on tiedostopääte ".pas"


againu.lfm: Lazarus tallentaa käännösyksikön lomakkeen ulkoasun, ihmisen luettavissa olevassa muodossa. Se kertoo eri komponenttien, ominaisuuksia jotka on asetettu komponenttimuokkaimella. Jokaisen komponentin kuvaus alkaa rivillä:

object xxxx 
   sitten seuraa ominaisuuksien luettelo 
  (Myös upotettuja tai sisäkkäisiä objekteja) sitten 
end 
rivi.

Lazarus käyttää tätä tiedostoa kun luo resurssitiedoston (.res). Delphi DFM tiedostot voidaan muuntaa lfm muotoon Lazarus kehitysympäristössä käyttäen: Työkalut -> Delphi muunnos -> Muunna binaarinen DFM-tiedosto teksti LFM:ksi ja tarkista syntaksi.

again.res: Tämä on luotu resurssi tiedosto, joka sisältää ohjeet ohjelman rakentamiseen (jos tarkastellaan pääohjelma tiedostoa, näette alustuksen osassa rivin

{$i *.res}

joka ohjaa ohjelman lataamaan resurssitiedoston). Huomaa, että se ei ole Windows resurssi-tiedosto.


againu.pas: Käännösyksikkö, joka voi sisältää myös lomakkeen koodin; tämä on yleensä vain tiedosto jota ohjelmoijan tarvitsee muokata tai tarkastaa, ja se nimenomaisesti sisältää ohjelmoijan toimittamaa koodia (erityisesti tapahtuman käsittelijät).

againu.ppu: Tämä on koottu käännöyksikkö, joka linkitetään suoritettavaan tiedostoon yhdessä muiden käännösyksiköiden jotka on nimetty Uses osiossa.

ppas.bat: Tämä on yksinkertainen skripti, joka yhdistää ohjelman tuottaman suoritettavan tiedoston. Jos käännös on onnistunut, kääntäjä poistaa sen.


Katso myös