Rabu, 21 September 2011

Optimalisasi Penggunaan Procedure di Delphi 7

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:

To Share mengatakan...

bener ini gan... bener2 manfaat...

INFO CATATAN ONLINE mengatakan...

nice share mas bro........

Posting Komentar