Selamat siang agan-agan sekalian.Apa kabarnya !? Mudah-mudahan selalu diberi kesehatan dan kekuatan juga semangat untuk terus menambah ilmu.Pada postingan kali ini saya akan menyajikan tutorial mengenai Optimalisasi Penggunaan Procedure di Delphi 7.Bila anda belum tau apa itu procedure , alangkah baiknya bila anda membaca postingan
Berikut terlebih dahulu.Seperti kita tau , delphi 7 merupakan sebuah IDE(Integrated Developement Environment) dari bahasa pemrograman Pascal.Dengan modifikasi yang kompleks , maka lahirlah object pascal yang merupakan delphi 7 itu sendiri.Mengapa dinamakan object pascal !? Yuph , karena
delphi 7 sudah mendukung OOP(Object Oriented Programming) dimana setiap elemen pada dari delphi 7 diperlakukan sebagai object.Dan procedure serta function sendiri merupakan salah satu fasilitas yang mendukung konsep OOP tersebut.Tentu hal ini memermudah dalam proses coding.Mempermudah !? Bagaimana kita tau bahwa konsep OOP mempermudah dalam proses pemrograman !? Well , saya tidak pandai berteori.Lebih baik saya jelaskan dengan praktek.Dari tingkat basic tentunya , dimana kita akan membuat 2 program sederhana dengan fungsionalitas yang sama namun dengan tekhnik coding yang berbeda.Lalu tunggu apa lagi , buka borland delphi 7 anda.
Tambahkan 5 buah komponen TEdit dan 1 buah komponen TButton.Susun komponen tersebut sesuai gambar berikut.
Program tersebut memiliki alur proses sebagai berikut.
1.Ketika pertama kali program tampil , semua komponen TEdit tidak dapat diinput kecuali setelah menekan button tambah terlebih dahulu.
2.ketika user menekan button enter saat mengisi field TEdit , maka focus akan berpindah ke komponen edit selanjutnya kecuali bila field Tedit tersebut kosong.Misal anda mengisi field edit1 , lalu anda menekan button enter , maka focus akan berpindah ke edit2 dan seterusnya , kecuali kalau field edit tersebut kosong.
3.Ketika button tambah di tekan , focus akan berpindah ke edit1 , dan caption Tambah akan berupah menjadi Batal.
4.Bila button tambah dengan caption batal di tekan , maka semua komponen TEdit akan dikosongkan , serta tidak dapat di input.Dan caption button Tambah akan berubah menjadi Tambah.
Bingung !?Bagus lah :D , tapi tetep semangat ya !!Semoga proses coding berikut bisa membuat anda mengerti.Seperti saya bilang , kita akan membuat program dengan fungsionalitas yang sama namun tekhnik coding yang berbeda.Untuk itu , mari kita menggunakan cara pertama terlebih dahulu.
A.Cara Pertama
Masuk ke form1 event on show dan ketikan kode berikut.
procedure TForm1.FormShow(Sender: TObject);
begin
Edit1.Enabled:=false;
Edit2.Enabled:=false;
Edit3.Enabled:=false;
Edit4.Enabled:=false;
Edit5.Enabled:=false;
Edit1.Clear;
Edit2.Clear;
Edit3.Clear;
Edit4.Clear;
Edit5.Clear;
end;
Double klik button1 dan ketikan kode berikut
procedure TForm1.Button1Click(Sender: TObject);
begin
if Button1.Caption='Tambah' then
begin
Edit1.Enabled:=true; //mengaktifkan edit1
Edit1.SetFocus; //memfokuskan edit1
Button1.Caption:='Batal'; //mengganti caption button1 menjadi batal
end
else
begin
Edit1.Enabled:=false; //
Edit2.Enabled:=false; //
Edit3.Enabled:=false; // menonaktifkan semua komponen edit
Edit4.Enabled:=false; //
Edit5.Enabled:=false; //
Edit1.Clear; //
Edit2.Clear; //
Edit3.Clear; // membersihkan semua komponen edit
Edit4.Clear; //
Edit5.Clear; //
Button1.Caption:='Tambah'; //merubah caption button1 menjadi tambah
end;
end;
Selanjutnya , pada edit1 on key press , ketikan kode berikut.
procedure TForm1.Edit1KeyPress(Sender: TObject; var Key: Char);
begin
if key=#13 then //bila tombol enter ditekan
begin
if Edit1.Text='' then //bila field edit kosong
begin
Application.MessageBox('maaf data harus diisi','Keslahan',MB_OK or MB_ICONWARNING);
end
else
begin
Edit2.Enabled:=true; //mengaktifkan edit2
Edit2.SetFocus; //mefocuskan edit2
end;
end;
end;
Lakukan pengkodean tersebut sampai edit4.Tentu dengan mengubah variabel nama edit pada code tersebut.pada event on key press edit5 , focuskan ke button1.Berikut kode lengkap dari program teresbut.
unit Unit1;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, StdCtrls;
type
TForm1 = class(TForm)
Edit1: TEdit;
Edit2: TEdit;
Edit3: TEdit;
Edit4: TEdit;
Edit5: TEdit;
Button1: TButton;
procedure FormShow(Sender: TObject);
procedure Button1Click(Sender: TObject);
procedure Edit1KeyPress(Sender: TObject; var Key: Char);
procedure Edit2KeyPress(Sender: TObject; var Key: Char);
procedure Edit3KeyPress(Sender: TObject; var Key: Char);
procedure Edit4KeyPress(Sender: TObject; var Key: Char);
procedure Edit5KeyPress(Sender: TObject; var Key: Char);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.dfm}
procedure TForm1.FormShow(Sender: TObject);
begin
Edit1.Enabled:=false;
Edit2.Enabled:=false;
Edit3.Enabled:=false;
Edit4.Enabled:=false;
Edit5.Enabled:=false;
Edit1.Clear;
Edit2.Clear;
Edit3.Clear;
Edit4.Clear;
Edit5.Clear;
end;
procedure TForm1.Button1Click(Sender: TObject);
begin
if Button1.Caption='Tambah' then
begin
Edit1.Enabled:=true; //mengaktifkan edit1
Edit1.SetFocus; //memfokuskan edit1
Button1.Caption:='Batal'; //mengganti caption button1 menjadi batal
end
else
begin
Edit1.Enabled:=false; //
Edit2.Enabled:=false; //
Edit3.Enabled:=false; // menonaktifkan semua komponen edit
Edit4.Enabled:=false; //
Edit5.Enabled:=false; //
Edit1.Clear; //
Edit2.Clear; //
Edit3.Clear; // membersihkan semua komponen edit
Edit4.Clear; //
Edit5.Clear; //
Button1.Caption:='Tambah'; //merubah caption button1 menjadi tambah
end;
end;
procedure TForm1.Edit1KeyPress(Sender: TObject; var Key: Char);
begin
if key=#13 then //bila tombol enter ditekan
begin
if Edit1.Text='' then //bila field edit kosong
begin
Application.MessageBox('maaf data harus diisi','Keslahan',MB_OK or MB_ICONWARNING);
end
else
begin
Edit2.Enabled:=true; //mengaktifkan edit
Edit2.SetFocus; //mefocuskan edit
end;
end;
end;
procedure TForm1.Edit2KeyPress(Sender: TObject; var Key: Char);
begin
if key=#13 then //bila tombol enter ditekan
begin
if Edit2.Text='' then //bila field edit kosong
begin
Application.MessageBox('maaf data harus diisi','Keslahan',MB_OK or MB_ICONWARNING);
end
else
begin
Edit3.Enabled:=true; //mengaktifkan edit
Edit3.SetFocus; //mefocuskan edit
end;
end;
end;
procedure TForm1.Edit3KeyPress(Sender: TObject; var Key: Char);
begin
if key=#13 then //bila tombol enter ditekan
begin
if Edit3.Text='' then //bila field edit kosong
begin
Application.MessageBox('maaf data harus diisi','Keslahan',MB_OK or MB_ICONWARNING);
end
else
begin
Edit4.Enabled:=true; //mengaktifkan edit
Edit4.SetFocus; //mefocuskan edit
end;
end;
end;
procedure TForm1.Edit4KeyPress(Sender: TObject; var Key: Char);
begin
if key=#13 then //bila tombol enter ditekan
begin
if Edit4.Text='' then //bila field edit kosong
begin
Application.MessageBox('maaf data harus diisi','Keslahan',MB_OK or MB_ICONWARNING);
end
else
begin
Edit5.Enabled:=true; //mengaktifkan edit
Edit5.SetFocus; //mefocuskan edit
end;
end;
end;
procedure TForm1.Edit5KeyPress(Sender: TObject; var Key: Char);
begin
if key=#13 then //bila tombol enter ditekan
begin
if Edit5.Text='' then //bila field edit kosong
begin
Application.MessageBox('maaf data harus diisi','Keslahan',MB_OK or MB_ICONWARNING);
end
else
begin
Button1.SetFocus;
end;
end;
end;
end.
Jalankan program dan mulai inputkan apa saja pada tiap field edit.Perhatikan , dengan cara pertama untuk membuat program simpel seperti ini saja kita harus melakukan koding yang cukup banyak.Boros waktu tentunya.Dan lagi , bagaimana bila kita ingin merubah message yang ditampilkan menjadi "maaf data tidak boleh kosong"!? Kita harus merubahnya satu persatu.Kurang efisien !? Tentu saja.Maka dari itu , mari kita mencoba cara kedua yang memanfaatkan procedure yang kita buat.
B.Cara Kedua
Buat program baru lagi dengan kriteria form yang sama seperti tadi.Kita akan membuat procedure dengan nama kondisiAwal untuk mensetting tampilan ketika program pertama kali dijalankan.Ketikan kode berikut setelah {$R *.dfm}.
procedure kondisiAwal;
var a:Integer;
begin
with Form1 do
begin
for a :=0 to ComponentCount-1 do
begin
if Components[a] is TEdit then TEdit(Components[a]).Clear; //membersihkan semua komponen TEdit
if Components[a] is TEdit then TEdit(Components[a]).Enabled := False; //menonaktifkan semua komponen TEdit
Button1.Caption:='Tambah';
Button1.SetFocus;
end;
end;
end;
Panggil procedure tersebut pada form1 event on show.
procedure TForm1.FormShow(Sender: TObject);
begin
kondisiAwal;
end;
Selanjutnya , double klik button1 dan ketikan kode berikut.
procedure TForm1.Button1Click(Sender: TObject);
begin
if Button1.Caption='Tambah' then
begin
Edit1.Enabled:=true;
Edit1.SetFocus;
Button1.Caption:='Batal';
end
else
begin
kondisiAwal; //bila button1 captionnya batal , maka kondisiAwal dipanggil
end;
end;
Selanjutnya , kita akan membuat procedure lagi yang berfungsi untuk menangani proses input pada field edit.Bila tombol enter di tekan , maka focus akan berpindah ke edit selanjutnya kecuali bila edit tersebut kosong.Yuph , fungsionalitas yang sama seperti cara pertama.Procedure yang bernama cekEdit ini di tempatkan setelah procedure kondisiAwal.Ayo ketikan kode berikut.
procedure cekEdit(sender,fokus:TObject);//sender adalah Tedit awal , dan fokus Tedit tujuan
begin
with(sender as TEdit) do
begin
if Text='' then //bila sender kosong
begin
Application.MessageBox('Maaf data harus di isi','Kesalahan',MB_OK or MB_ICONWARNING);
end
else
begin
with(fokus as TEdit) do
begin
Enabled:=true;
SetFocus;
end;
end;
end;
end;
Lalu , pada event on key press edit1 , ketikan kode berikut.
procedure TForm1.Edit1KeyPress(Sender: TObject; var Key: Char);
begin
if Key=#13 then
begin
cekEdit(Sender,Edit2);
end;
end;
Lakukan hal yang sama hingga edit4.Tentu dengan mengubah variabel tujuan.Pada , event on key press edit5 ketikan kode berikut.
procedure TForm1.Edit5KeyPress(Sender: TObject; var Key: Char);
begin
if Key=#13 then
begin
if Edit5.Text='' then
begin
Application.MessageBox('Maaf data harus di isi','Kesalahan',MB_OK or MB_ICONWARNING);
end
else
begin
Button1.SetFocus;
end;
end;
end;
Berikut kode lengkap dari Cara Kedua.
unit Unit1;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, StdCtrls;
type
TForm1 = class(TForm)
Edit1: TEdit;
Edit2: TEdit;
Edit3: TEdit;
Edit4: TEdit;
Edit5: TEdit;
Button1: TButton;
procedure FormShow(Sender: TObject);
procedure Button1Click(Sender: TObject);
procedure Edit1KeyPress(Sender: TObject; var Key: Char);
procedure Edit2KeyPress(Sender: TObject; var Key: Char);
procedure Edit3KeyPress(Sender: TObject; var Key: Char);
procedure Edit4KeyPress(Sender: TObject; var Key: Char);
procedure Edit5KeyPress(Sender: TObject; var Key: Char);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.dfm}
procedure kondisiAwal;
var a:Integer;
begin
with Form1 do
begin
for a :=0 to ComponentCount-1 do
begin
if Components[a] is TEdit then TEdit(Components[a]).Clear; //membersihkan semua komponen TEdit
if Components[a] is TEdit then TEdit(Components[a]).Enabled := False; //menonaktifkan semua komponen TEdit
Button1.Caption:='Tambah';
Button1.SetFocus;
end;
end;
end;
procedure cekEdit(sender,fokus:TObject);//sender adalah Tedit awal , dan fokus Tedit tujuan
begin
with(sender as TEdit) do
begin
if Text='' then //bila sender kosong
begin
Application.MessageBox('Maaf data harus di isi','Kesalahan',MB_OK or MB_ICONWARNING);
end
else
begin
with(fokus as TEdit) do
begin
Enabled:=true;
SetFocus;
end;
end;
end;
end;
procedure TForm1.FormShow(Sender: TObject);
begin
kondisiAwal;
end;
procedure TForm1.Button1Click(Sender: TObject);
begin
if Button1.Caption='Tambah' then
begin
Edit1.Enabled:=true;
Edit1.SetFocus;
Button1.Caption:='Batal';
end
else
begin
kondisiAwal; //bila button1 captionnya batal , maka kondisiAwal dipanggil
end;
end;
procedure TForm1.Edit1KeyPress(Sender: TObject; var Key: Char);
begin
if Key=#13 then
begin
cekEdit(Sender,Edit2);
end;
end;
procedure TForm1.Edit2KeyPress(Sender: TObject; var Key: Char);
begin
if Key=#13 then
begin
cekEdit(Sender,Edit3);
end;
end;
procedure TForm1.Edit3KeyPress(Sender: TObject; var Key: Char);
begin
if Key=#13 then
begin
cekEdit(Sender,Edit4);
end;
end;
procedure TForm1.Edit4KeyPress(Sender: TObject; var Key: Char);
begin
if Key=#13 then
begin
cekEdit(Sender,Edit5);
end;
end;
procedure TForm1.Edit5KeyPress(Sender: TObject; var Key: Char);
begin
if Key=#13 then
begin
if Edit5.Text='' then
begin
Application.MessageBox('Maaf data harus di isi','Kesalahan',MB_OK or MB_ICONWARNING);
end
else
begin
Button1.SetFocus;
end;
end;
end;
end.
Jalankan program anda.Sama seperti Cara Pertama bukan !? Tentu saja.Namun lihat , kode anda lebih irit serta terstruktur.Bila ada perubahan pada message , kita cukup merubanhya pada procedure cekEdit.Ini sangat menguntungkan bila kita menginginkan perubahan.Bayangkan bila kita memiliki belasan komponen TEdit yang harus divalidasi seperti Cara Pertama.Tentu program kita akan gemuk oleh source code yang kenyataannya bisa kita optimalkan agar lebih rapih dan singkat.Lebih cepat dan efisien.Ini hanya secuil dari manfaat procedure.Disini saya membeikan contoh procedure yang sangat simple agar mudah dimengerti.Yang terpenting ialah , anda memahami konsep dari procedure itu sendiri.Sekian untuk tutorial kali ini , semoga bermanfat.
Simak Juga Tutorial Lainnya:
2 komentar:
bener ini gan... bener2 manfaat...
nice share mas bro........
Posting Komentar