Rabu, 20 November 2013

DELPHI - Membuat Gradient Warna Pada Form (TForm)

Hai sobat delphiers, udah lama nih ane gak posting,,
just share aja nih coding buat MAKEOVER-nya DELPHI,,

procedure TForm1.FormPaint(Sender: TObject);
var Row, Ht: Word ;
begin
 Ht := (ClientHeight + 255) div 256 ;
 for Row := 0 to 255 do
  with Canvas do begin
    Brush.Color := RGB(255, 255, Row);
    FillRect(Rect(0, Row * Ht,
                  ClientWidth, (Row + 1) * Ht)) ;
  end;
end;

Kalo mau ganti warnanya, tinggal rubah aja angkanya dengan yang anda mau. pake sistem RGB Colour.
Oke sekian aja terimakasih telah berkunjung di giavano.blogspot.com

Salam Sobat delphiers ^_^

Rabu, 18 September 2013

DELPHI - Membedakan warna baris di DBGrid

Selamat malam pemirsa... :D
maaf sudah lama gak spawn , sibuk nih hehe

oke gan langsung aja,
pernah liat DBGrid yang warna barisnya beda2? ganjil genap gitu :D
nih codingnya

procedure TfrmMenuUtama.DBGrid1DrawDataCell(Sender: TObject; const Rect: TRect;
  Field: TField; State: TGridDrawState);
begin
if (ADOQuery1.RecNo mod 2)=0 then
DBGrid1.Canvas.Brush.Color := clSkyBlue
else
DBGrid1.Canvas.Brush.Color := $000080FF;

DBGrid1.DefaultDrawDataCell (Rect, Field, State);
end;

nah itu untuk yang bedakan ganjil genap, sedangkan untuk kriteria tertentu, bisa aja kasih keterangan di if nya.
contohnya untuk memberi warna MERAH pada nilai ujian yang kurang dari 70

procedure TForm1.DBGrid1DrawDataCell(Sender: TObject; const Rect: TRect;
  Field: TField; State: TGridDrawState);
begin
if (ADOQuery1.FieldByName('NILAI').Value < 70 ) then
DBGrid1.Canvas.Brush.Color := clred
else
DBGrid1.Canvas.Brush.Color := clWhite;

DBGrid1.DefaultDrawDataCell (Rect, Field, State);

end;

Mudah kan? oke terimakasih telah berkunjung di giavano.blogspot.com ^^

Selasa, 20 Agustus 2013

DELPHI - Menulis text kedalam sebuah File text .txt

Selamat malam pemirsa :D

kali ini saya bagikan cara untuk menulis ke dalam sebuah file melalui DELPHI..
oke langsung aja lah yah, ini codingnya

procedure TForm1.tbSimpanClick(Sender: TObject);
var TFile : TextFile;
begin
  assignFile(TFile, 'C:\catatan.txt');
  if FileExists('catatan.txt') then
    Append(TFile)
  else
    ReWrite(TFile);
  writeln(TFile,'INI TULISAN PERTAMA SAYA');
  closeFile(TFile);
end;


Coding itu bebas anda letakkan di tempat yang dibutuhkan. silahkan mencoba.
Terimakasih telah berkunjung di giavano.blogspot.com ^_^

Minggu, 11 Agustus 2013

DELPHI - Mengurangi stok secara otomatis menggunakan Trigger MySQL

Selamat siang pemirsa, :D
berhubung kemaren ada yang request jadi saya tempel di blog ini
oke langsung aja,

jadi trigger itu fungsinya untuk jadi pemicu, misalnya :
pas kita jual barang, stok harus berkurang....
pas kita beli barang, stok harus bertambah...
pas kita update penjualan, stok harus dikurangi yang lama dan ditambah yang baru...

nah itu lah yang gunanya trigger, kalo ga pake trigger juga bisa, tapi lambat dan codingnya ribet.

misalnya saya punya tabel penjualan (master & detail) seperti ini
//Master
CREATE TABLE `mjual` (
  `NOMOR_JUAL` char(10) NOT NULL,
  `TANGGAL` date NOT NULL,
  `NOPLAT` varchar(10) default NULL,
  `MOTOR` varchar(20) default NULL,
  `BIAYA_PASANG` double default '0',
  `JENIS_BAYAR` varchar(20) default 'TUNAI',
  `STATUS` varchar(50) default 'LUNAS',
  PRIMARY KEY  (`NOMOR_JUAL`),
  UNIQUE KEY `IDJual` (`NOMOR_JUAL`)
)
//detail
CREATE TABLE `djual` (
  `NOMOR_JUAL` char(10) NOT NULL,
  `ID_BARANG` varchar(20) NOT NULL,
  `JUMLAH` int(11) default '0',
  `HARGA_JUAL` double default '0',
  `DISKON` double default '0',
  KEY `IDJual` (`NOMOR_JUAL`),
  KEY `IDBarang` (`ID_BARANG`),
  CONSTRAINT `djual_fk` FOREIGN KEY (`NOMOR_JUAL`) REFERENCES `mjual` (`NOMOR_JUAL`) ON UPDATE CASCADE,
  CONSTRAINT `djual_fk1` FOREIGN KEY (`ID_BARANG`) REFERENCES `barang` (`ID_BARANG`) ON UPDATE CASCADE
)

//tabel barang
CREATE TABLE `barang` (
  `ID_BARANG` varchar(20) NOT NULL,
  `NAMA_BARANG` varchar(75) default NULL,
  `SATUAN` varchar(10) default NULL,
  `HARGA_BELI` double default '0',
  `HARGA_BARANG` double default '0',
  `STOK` int(11) default '0',
  `NAMA_SUPPLIER` varchar(30) default NULL,
  PRIMARY KEY  (`ID_BARANG`),
  UNIQUE KEY `IDGuru` (`ID_BARANG`),
  KEY `IDSupplier` (`NAMA_SUPPLIER`),
  CONSTRAINT `barang_fk` FOREIGN KEY (`NAMA_SUPPLIER`) REFERENCES `supplier` (`NAMA_SUPPLIER`) ON UPDATE CASCADE
)

//tabel supplier
CREATE TABLE `supplier` (
  `NAMA_SUPPLIER` varchar(30) NOT NULL,
  `ALAMAT` varchar(100) default NULL,
  `TELEPON` varchar(30) default NULL,
  `EMAIL` varchar(50) default NULL,
  `NAMA_SALESMAN` varchar(30) default NULL,
  `TELEPON_SALESMAN` varchar(30) default NULL,
  `SISA_HUTANG` double default '0',
)

misalnya saya punya data tabel barang seperti ini
ID_BARANG | NAMA_BARANG | STOK | HARGA_BARANG
00000000001 | sabun colek             | 100      | 3000
00000000002 | sabun mandi            | 100      | 1500


nah nanti di tabel penjualan (detail) ketika kita masukin
kode 00000000001  
jumlah penjualan 15,
maka stok 00000000001 harus menjadi 85. (inilah yang dimaksud trigger AFTER INSERT)
stok hanya akan berkurang, JIKA barang terjual (sesuai kodebarang yang diinput)

CREATE TRIGGER `djual_after_ins_tr` AFTER INSERT ON `djual`
  FOR EACH ROW
BEGIN
     UPDATE barang SET stok = stok - NEW.jumlah
     WHERE ID_Barang = NEW.ID_Barang;
END;

nah gimana kalo ternyata salah input? trus jumlahnya bukan 15, tapi 20, kita tinggal update aja detail penjualannya, ganti si 15 jadi 20
kode 00000000001  
jumlah penjualan 20,
maka stok 00000000001 harus menjadi 80. (inilah yang dimaksud trigger AFTER UPDATE)

CREATE TRIGGER `djual_after_upd_tr` AFTER UPDATE ON `djual`
  FOR EACH ROW
BEGIN
     UPDATE barang SET stok = stok - NEW.jumlah + OLD.jumlah
     WHERE ID_Barang = OLD.ID_Barang;
END;

nah gimana kalo salah? dan datanya harus dihapus?
contoh kode 00000000001 uda dimasukkin jumlah jualnya 15, trus mau dihapus karena salah, tentu stoknya harus kembali lagi kan jadi 100,
(inilah yang dimaksud trigger BEFORE DELETE)
jadi sebelum datanya dihapus, sistem otomatis kembalikan stok yang lama.

CREATE TRIGGER `djual_before_del_tr` BEFORE DELETE ON `djual`
  FOR EACH ROW
BEGIN
     UPDATE barang SET stok = stok + OLD.jumlah
     WHERE ID_Barang = OLD.ID_Barang;
END;

yah silahkan anda coba di db engine masing2, sesuaikan sintaksnya dengan versi SQL yang dipakai :D
Semoga membantu, 
thanks.



Kamis, 08 Agustus 2013

C# - Membuat Koneksi Dan Melakukan Operasi Database (SQLite embedded database)

Selamat Sore pemirsa setia :D
kali ini saya akan bagikan source code c# untuk membuat koneksi dengan embedded database SQLite

Oke langsung saja

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SQLite;

//.....//

 public frm_department()
        {
            InitializeComponent();
        }

//Tambahkan coding ini setelah constructor (constructor itu kira2 seperti diatas)

        private SQLiteConnection conn;
        private DataSet ds;
        private SQLiteCommand cmd;
        private SQLiteDataAdapter sda;
        private SQLiteCommandBuilder cmdBuilder;

//Bagian Merah dibawah boleh diganti dengan nama database yang anda inginkan.. directorynya pun bebas terserah anda

        private void exec(String query)
        {
            conn = new SQLiteConnection(@"Data Source=D:\School.sdb;
                                          PRAGMA journal_mode = OFF;
                                          PRAGMA synchronous = OFF;
                                          PRAGMA locking_mode = EXCLUSIVE;
                                          PRAGMA temp_store = MEMORY;
                                          PRAGMA page_size = 4096;
                                          PRAGMA cache_size = 10000;");
            conn.Open();
            ds = new DataSet();
            cmd = conn.CreateCommand();
            string sql = query;
            sda = new SQLiteDataAdapter(sql, conn);
            cmdBuilder = new SQLiteCommandBuilder(sda);
            sda.Fill(ds);
        }

Nah coding diatas untuk Procedure, sedangkan untuk mengisi Query seperti ini :

//Pembuatan Embedded database
 exec("CREATE TABLE [Departments] ( " +
                    "[Department_ID] INTEGER  NOT NULL PRIMARY KEY AUTOINCREMENT, " +
                    "[Faculty_ID] INTEGER  NOT NULL," +
                    "[Employee_ID] INTEGER  NOT NULL," +
                    "[Title] TEXT  NOT NULL," +
                    "[Description] TEXT  NOT NULL," +
                    "[Address] TEXT  NOT NULL," +
                    "[Phone] TEXT  NOT NULL," +
                    "[Date_Register] datetime  NOT NULL" +
                    ");");
//Operasi Input Data
                    exec("insert into departments(faculty_id,employee_id, title, description, address, phone, date_register)"+
                        "values ("+
                        "'" +  g_faculty_ID.SelectedItem + "',"+
                        "'" + g_Personnel_Id.SelectedItem + "'," +
                        "'" + txt_Title.Text + "'," +
                        "'" + txt_Description.Text + "'," +
                        "'" + txt_Address.Text + "'," +
                        "'" + txt_Phone.Text + "'," +
                        "datetime('now','localtime') );");
                     
                    MessageBox.Show("Done!");

Jangan lupa di bagian Reference tambahkan SQLite.dll (seperti menambahkan reference Mysqlconnector pada Database server)

Oke sekian dan terimakasih

Bila ada yang ingin ditanyakan silahkan Comment disini :


Sabtu, 03 Agustus 2013

DELPHI - Backup Restore MySQL di delphi dengan komponen Open dan Save Dialog

Malam Pemirsa setia :D
Good night...!

Here Coding to BackUp and Restore your Database with Delphi

for example :

Database : Bengkel ( colored Red, according to your own database - tergantung anda )
Password : 1234 ( colored Red, same, it totally based on your own password - tergantung anda )
Folder MySQL : C:\Program Files (x86)\MySQL\MySQL Server 5.0\bin\
(folder MySQL it depends on your directory - tergantung tempat anda install mysql)

add component SaveDialog and OpenDialog on your form

BackUp

  SaveDialog1.Execute;
if SaveDIalog1.FileName<>'' then
  begin
  ShellExecute(self.Handle, PCHAR('open'),
  PCHAR('C:\Program Files (x86)\MySQL\MySQL Server 5.0\bin\mysqldump.exe'),
  PCHAR('-uroot -p1234 -hlocalhost -R -r "'+ SaveDialog1.FileName+'.sql" bengkel'),
  PCHAR('C:\Program Files (x86)\MySQL\MySQL Server 5.0\bin'),SW_SHOW);

  MessageDlg('Data Berhasil di Backup !!', mtInformation, [mbOK], 0);
  end
else
  MessageDlg('GAGAL. Harap Pilih Lokasi!!', mtInformation, [mbOK], 0);


Restore
   OpenDialog1.Execute;
if OpenDialog1.FileName<>'' then
  begin
  ShellExecute(self.Handle,pchar('open'),
  PCHAR('C:\Program Files (x86)\MySQL\MySQL Server 5.0\bin\mysql.exe'),
  PCHAR('-uroot -p1234 -hlocalhost -e "drop database if exists bengkel; '+
  'create database bengkel; use bengkel;\. '+OpenDialog1.FileName+'"'),nil,SW_HIDE);
  MessageDlg('Data Berhasil di Restore !!', mtInformation, [mbOK], 0);
  end
else
  MessageDlg('GAGAL. Harap Pilih Lokasi !!!', mtInformation, [mbOK], 0);
end;


OK easy right?
thanks 4 ur attention and see the next Update at giavano.blogspot.com

Thank you

Senin, 29 Juli 2013

DELPHI - Mengatur Lebar kolom tStringGrid

Malam lagi pemirsa setia ~xp
kali ini saya akan bagikan untuk mengatur judul kolom (header) dari Stringgrid beserta Cara mengatur lebar kolom Stringgrid

    StringGrid1.Cols[0].Text:='ID BARANG';
    StringGrid1.Cols[1].Text:='JUMLAH';
    StringGrid1.ColWidths[1]:=75;
    StringGrid1.Cols[2].Text:='KETERANGAN';
    StringGrid1.ColWidths[2]:=300;
    StringGrid1.Cols[3].Text:='STATUS_RETUR';
    StringGrid1.ColWidths[3]:=200;
.... dst

mudah kan?
ayo kunjungi terus Giavano.blogspot.com ^^
terimakasih

DELPHI - Menghapus isi komponen StringGrid dengan cepat

Selamat malam pemirsa setia :D
kembali lagi bersama saya disini B-)
maaf nih lagi sibuk makanya baru ngepost lagi :D
oke langsung aja cekidot..

procedure HapusStringGrid();
var i : integer;
begin
for i := 0 to StringGrid1.ColCount - 1 do
    StringGrid1.Cols[i].Clear;
end;

Mudah kan?
oke Terus kunjungi giavano.blogspot.com ^_^
thank you

Kamis, 25 Juli 2013

DELPHI - Memberi Format Rupiah (Rp.) pada Delphi

selamat subuh para pemirsa setia :D
kali ini saya akan berbagi cerita tentang cara memberikan format rupiah di delphi

oke langsung aja sedot...


sEdit1.Text:=FormatFloat('Rp. ##,###,###',total);

variabel total nya anda tentukan sendiri algoritma dan rulenya
yang jelas tipenya harus float.

taruh aja codingnya di event on click button / onChange TEdit / sejenisnya

oke mudah kan?
terimakasih telah berkunjung ^_^

thank you~

Rabu, 24 Juli 2013

DELPHI - Mengatasi error File not found .dcu pada delphi

hai pemirsa setia :D
kembali lagi bersama saya disini

kali ini saya akan bagikan cara mengatasi error khususnya
"file not found %.dcu"
setelah ngulik sana sini ga dapat jawaban akhirnya coba pasrah dan ngopi dlu sampe subuh :p
akhirnya dapat juga
oke langsung saja

gini caranya pilih menu

Tools -> options -> Delphi Options -> Library - win32 -> library path

cari folder yang bermasalah,
misalnya error Qrpt.dcu not found : pada komponen QUICK REPORT, cari tempat folder kita install QUICK REPORT
tinggal ADD - OK
Trus misalnya error pada Alpha skin, sEdit not found bla bla bla
Cara yang sama bisa diterapkan, cari aja folder alphaskin nya
trus ADD - OK

Mudah kan?
Semoga bisa membantu :D

Terimakasih, Slalu kunjungi Giavano.blogspot.com

Minggu, 21 Juli 2013

JAVA - MakeOver textfield dengan mudah

Selamat siang pemirsa setia :D
seperti posting sebelumnya,
kita mau ubah si jtextfield yang kotak2 jadi agak bulet
biar bagus gitu :D

Pertama bkin dlu Class TextFieldMakeOver namanya
trus copas deh :

package MakeOver;

import java.awt.Color;
import java.awt.GradientPaint;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.RenderingHints;
import javax.swing.JTextField;
import javax.swing.border.EmptyBorder;



public class TextFieldMakeOver extends JTextField {
    public TextFieldMakeOver() {
        setOpaque(false);
        setForeground(Color.WHITE);
        setCaretColor(Color.WHITE);
        setBorder(new EmptyBorder(6, 6, 6, 6));
    }
    @Override
    protected void paintComponent(Graphics g) {
        super.paintComponent(g);
        Graphics2D gd = (Graphics2D) g.create();
                gd.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
               gd.setPaint(new GradientPaint(0, 0, new Color(255, 255, 255, 120), 0, getHeight(), new Color(0, 0, 0, 0)));
        gd.fillRoundRect(0, 0, getWidth(), getHeight(), 25, 25);
        gd.setColor(Color.white);
        gd.drawRoundRect(0, 0, getWidth() - 1, getHeight() - 1, 25, 25);
        gd.dispose();

    }
}

Cara kerjanya sama, COMPILE dulu projectnya, trus DRAG AND DROP si class TextFieldMakeOver
ke jFrame kamu :D

sekian dan terimakasih ^^


JAVA - MakeOver mempercantik tampilan form

Selamat siang pemirsa :D
sudah pernah dengar MakeOver?
Secara singkat, jadi MakeOver itu seperti Menggambar / Mewarnai di Java.
Buat apa??
Ya pastinya buat Mempercantik Tampilan dong :D

oke ini codingnya untuk MakeOver jPanel

kita buat java class namanya panel

package [namaPackage kamu]
import java.awt.Color;
import java.awt.GradientPaint;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.RenderingHints;
import java.awt.geom.GeneralPath;
import java.awt.image.BufferedImage;
import javax.swing.JPanel;

public class panel extends JPanel {
    private static final long serialVersionUID = -1;
    private BufferedImage gradientImage;
    private Color black = Color.blue;
    private Color warna = new Color(0,0,0);

    public panel() {
        super();
    }
    @Override
    protected void paintComponent(Graphics g) {
        super.paintComponent(g);
        if (isOpaque()) {
            Graphics2D g2 = (Graphics2D) g.create();
            g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
            setUpGradient();
            g2.drawImage(gradientImage, 0, 0, getWidth(), getHeight(), null);
            int width = getWidth();
            int height = getHeight() * 5 / 100;
            Color light = new Color(1F, 1F, 1F, 0.5F);
            Color dark = new Color(1F, 1F, 1F, 0.0F);
            GradientPaint paint = new GradientPaint(0, 0, light, 0, height, dark);
            GeneralPath path = new GeneralPath();
            path.moveTo(0, 0);
            path.lineTo(0, height);
            path.curveTo(0, height, width / 2, height / 2, width, height);
            path.lineTo(width, 0);
            path.closePath();
            g2.setPaint(paint);
            g2.fill(path);
            paint = new GradientPaint(0, getHeight(), light, 0, getHeight() - height, dark);
            path = new GeneralPath();
            path.moveTo(0, getHeight());
            path.lineTo(0, getHeight() - height);
            path.curveTo(0, getHeight() - height, width / 2, getHeight() - height / 2, width, getHeight() - height);
            path.lineTo(width, getHeight());
            path.closePath();
           g2.setPaint(paint);
            g2.fill(path);
            g2.dispose();
        }
    }

    private void setUpGradient() {
        gradientImage = new BufferedImage(1, getHeight(), BufferedImage.TYPE_INT_ARGB);
        Graphics2D g2 = (Graphics2D) gradientImage.getGraphics();
        g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
        GradientPaint paint = new GradientPaint(0, 0, black, 0, getHeight(), warna);
        g2.setPaint(paint);
        g2.fillRect(0, 0, 1, getHeight());
        g2.dispose();
    }
}


trus compile (Shift + F11)

seudah itu DRAG n DROP aja classPanel di JFrame kamu
cantik kan? hehehehe




JAVA - membuat koneksi Netbeans dengan MySQL

Selamat siang pemirsa setia :D
oke langsung aja. sesuai jdul, inilah class koneksi untuk netbeans dengan MySQL
jangan lupa ADD LIBRARY di dibagian libraries project, pilih MySQL JDBC Driver

package Application;
import java.sql.*;

public class Koneksi {
public Connection dbKoneksi;
public Statement statement;
public PreparedStatement prepareStatement;
public CallableStatement callableStatement;

public Koneksi() {
this.dbKoneksi = null;
}

public void bukaKoneksi() {
    try {
            /*   utk ms-access
             Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            dbKoneksi = DriverManager.getConnection("jdbc:odbc:kursus");
             */
            Class.forName("com.mysql.jdbc.Driver");
            dbKoneksi = DriverManager.getConnection
                    ("jdbc:mysql://localhost:3306/bengkel","root", "likmi");
         }
         catch(Exception e){
             e.printStackTrace();
         }
}
public void tutupKoneksi(){
       try {
            if (statement != null)
                statement.close();
            if (prepareStatement != null)
                prepareStatement.close();
            if (dbKoneksi != null)
                dbKoneksi.close();
       } catch (Exception e) {
         throw new RuntimeException(e.getMessage());
      }
}
}

Sekian dan Terimakasih

JAVA - memberikan validasi options YES or NO dalam netbeans dengan jOptionPane

Selamat siang pemirsa setia :D

berikut coding untuk memberikan validasi khususnya sebelum menghapus data pada netbeans (JAVA SE)

int ok=JOptionPane.showConfirmDialog(null,"Apakah Anda yakin?","Konfirmasi",JOptionPane.YES_NO_OPTION);
       
if(ok==0){
               ..... // Silahkan isi coding anda  
}

JAVA - membatasi jumlah karakter pada jTextfield

selamat siang pemirsa setia :D

berikut coding JAVA untuk membatasi jumlah karakter yang dimasukkan pada sebuah jtextfield
event - keyTyped

if(txtIDBarang.getText().length()==13)
            evt.consume();

mudah kan? :D

Sekian terimakasih :)

JAVA - mengatur lebar kolom pada jTable

selamat siang pemirsa setia :D
kali ini saya singgung dkit tentang JAVA programming
oke langsung saja

private void AturKolom(){
 TableColumn column;
 jTable1.setAutoResizeMode(javax.swing.JTable.AUTO_RESIZE_OFF);
    column = jTable1.getColumnModel().getColumn(0);
    column.setPreferredWidth(50);
    column = jTable1.getColumnModel().getColumn(1);
    column.setPreferredWidth(125);
    column = jTable1.getColumnModel().getColumn(2);
    column.setPreferredWidth(375);
    column = jTable1.getColumnModel().getColumn(3);
    column.setPreferredWidth(75);
    column = jTable1.getColumnModel().getColumn(4);
    column.setPreferredWidth(50);
    column = jTable1.getColumnModel().getColumn(5);
    column.setPreferredWidth(75);
    column = jTable1.getColumnModel().getColumn(6);
    column.setPreferredWidth(100);
 }

Method diatas adalah method untuk mengatur lebar kolom
misalnya saya punya 7 kolom, dan karena indeks dimulai dari NOL, maka column hanya sampai 6

    column = jTable1.getColumnModel().getColumn(6);
    column.setPreferredWidth(100);

kita gunakan .setPreferredWidth(100) untuk set Lebar kolom ke 6 adalah 100

oke sekian terimakasih telah membaca :D

DELPHI - Validasi Yes or No options

selamat siang pemirsa :D
ini dia cara untuk memberikan pilihan yes or no di delphi

If MessageDlg('SIMPAN DATA ?',mtconfirmation, [mbYes,mbNo],0)=mrYes Then
begin
.......
......
end

Oke sekian dlu terimakasih :D

DELPHI - Pemanggilan stored procedure MySQL

oke saya kembali lagi pemirsa :D

langsung aja yah...
cara memanggil stored procedure MySQL di delphi

pertama, buat procedure sql di delphi
Procedure SQL(IsiSQL : String);
begin
  with frmInputBarang do
  begin
  Q.SQL.Clear;
  Q.SQL.Add(IsiSQL);
  Q.ExecSQL;
  end;
end;

procedure diatas berfungsi untuk mengganti beberapa perintah tanpa harus menambahkan komponen adoquery lagi. ckup 1 untuk ramai2 :D

berikut coding untuk memanggil SP :
StoredProcedure yang saya punya namanya : Barang_Input, bikinnya di MySQL, untuk cara bkinnya silahkan liat postingan sebelumnya :D

try
    SQL('CALL Barang_Input('+
    quotedstr(txtIDBarang.Text)+','+
    quotedstr(txtNamaBarang.Text)+','+
    quotedstr(txtSatuan.Text)+','+
    txtHargaBeli.Text+','+
    txtHargaBarang.Text+','+
    txtStok.Text+','+
    quotedstr(cbNamaSupplier.Text)+')');

    ShowMessage('BERHASIL');
except
   ShowMessage('DATA SUDAH ADA');
end;

ask : koko, apa sih bedanya quotedstr() sama yang biasa?
answer : oh itu kalo pake quotedstr, artinya ditambahin kutip '' alias tipenya STRING/CHAR (huruf)
nah kalo txt yang gak pake quotedstr, artinya tipe datanya integer/float/double (angka)

Oke sekian dlu terimakasih pemirsa setia B-)
oLways Update with giavano.blogspot.com ^_^

DELPHI - Mengisi combobox dengan data dari tabel Database MySQL

Selamat pagi pemirsa :D

kali ini saya akan bagikan tentang memasukkan data dari tabel [database] ke dalam sebuah combobox
ya cara termudah menggunakan komponen dbCombobox, tapi cara ini menurut saya kurang efektif,
mengapa? karena dengan menggunakan dbCombobox, koneksi data akan terus terbuka, sehingga jika data yang ada banyak, akan sangat lambat dalam operasi select. insert, update
oleh karena itu, saya menggunakan komponen standar yaitu combobox.
oke langsung saja gan ni codingnya :

Procedure SQL(IsiSQL : String);
begin
  with form1 do
  begin
  adoQuery1.SQL.Clear;
  adoQuery1.SQL.Add(IsiSQL);
  adoQuery1.Open;
  end;
end;

Procedure IsiCombobox(Result : String);
begin
  with form1 do
  begin
  Combobox1.Items.Clear;
  while not adoQuery1.eof do
  begin
    Combobox1.items.add(Q.FieldByName(Result).Value);
    adoQuery1.Next;
  end;
  end;
end;

nah Result disana adalah sebuah parameter 
jadi kita bisa pakai function diatas berulang kali
misalnya :

kita ingin menampilkan daftar NAMA MAHASISWA dari tabel mahasiswa
maka implemetasinya : (asumsikan bahwa NAMA MAHASISWA berada di field NAMA

isi dulu SQLnya
SQL('SELECT * FROM mahasiswa');

IsiCombobox('NAMA');

nah kalo kita pengen ganti ke field lain, tinggal ubah lagi
IsiCombobox('ALAMAT');

Mudah kan pemirsa?
oke sekian dlu, saya lanjutin project lain dlu
terimakasih telah berkunjung di blog saya ^_^

DELPHI - Menekan enter dan focus ke komponen lain

selamat pagi pemirsa setia :D

sedot aja nih codingnya :

event : keypress

 if Key = #13 then
  editText2.SetFocus;

jadi coding diatas itu untuk focus ke komponen yang dituju ketika kita menekan ENTER
mudah kan?
terimakasih sudah berkunjung ^^


DELPHI - Mempercantik Tampilan FORM DELPHI

Selamat Pagi pemirsa setia (subuh sih lebih tepatnya)
>.<
kali ini saya akan share tentang mempercantik FORM DELPHI
jangan kaget yah., ini semacam MAKEOVER untuk delphi, tapi kita tidak perlu coding,
oke langsung sajah :D


  1. download komponen ALPHASKIN (cari di google)
  2. install sampe beres, ingetin lokasi installnya supaya gmpang dicari
  3. trus cara install komponennya di delphi :
    1. file - open
    2. cari file lokasi kamu install alphaskin
    3. pilih versi delphi yang sesuai contoh : delphi 2010 di folder D2010
    4. pilih file acnt2010_R trus di compile (ctrl+F9 atau klik kanan di jendela projectmanager-diatas window tool palette, compile)
    5. JANGAN CLOSE APAPUN
    6. buka lagi file lainnya, file - open
    7. pilih di folder yang sama file acnt2010 tanpa huruf (R)
    8. klik kanan di jendela projectmanager (buat yang gak tau : adanya disebelah kanan, diatas tool palette / tool komponen tempat kita ketik buat nyari komponen)
    9. nanti ada tulisan acnt2010.bpl (dibawahnya projectgroup1) klik kanan, install
    10. SAVE ALL (ctrl+shift+S)
    11. restart delphi kamu
hufft panjang juga yah :D
but slow...

next kita buka delphinya, new project - vcl form application,

  1. cari komponen SKIN PROVIDER dan SKIN MANAGER
  2. di SKIN MANAGER, dobel klik
  3. ADD NEW
  4. isi directory with skin dengan alamat kita install alphaskin.
  5. klik folder SKIN
  6. maka akan tampil daftar skin yg kita bisa pake
  7. pilih skinnya
  8. OK
  9. CLOSE
lho koq gak terjadi apa2?
sabar dlu
klik skinManagernya - properties ACTIVE - false - true (yah cobain aja beberapa kali centang biar ke refresh)
seudah itu, TAMBAHIN komponen sDATEEDIT, sCOMBOBOX, sBITBTN, sPANEL sEDIT,

sudah deh :D
jadi intinya, kita gak pake komponen bawaan delphi
tpi form kita pake ttep
nanti pas di compile dia otomatis berubah
CANTIK KAN wkkwkwkw :D

oke sekian dlu terimakasih sudah berkunjung :D











DELPHI - Membuat tampilan delphi dengan model Ribbon ( office )

Selamat malam lagi pemirsa setia B-)

kali ini saya bakal bagi2 info buat kalian2 yang suka pake delphi :D
oke langsung aja lah yah :D


  1. Pertama, donlod dlu devExpress, cari aja di google :D
  2. Kedua, install deh sampe kelar. 
  3. Ketiga, buka deh delphi 6 / 7 / 2010 nya (dalam kasus ini aku pake delphi 2010)
nah kalo 3 langkah diatas udah, mari kita lanjut...

  1. bkin new project dlu seperti biasa, pilih VCL form applications.
  2. tambahkan komponen dxBarManager
  3. tambahkan komponen dxRibbon
  4. tambahkan komponen dxRibbonStatusBar
kira2 kyk gini nih tampilan awalnya :


nah kalo sudah, gampang deh
buat nambah TAB, klik kanan di dxRibbon, trus pilih ADD TAB

nah gimana cara isi componen didalem ribbon ini?
saya kasi cara yg paling mudah.
caranya :

di TAB yang kita pilih, dibagian atasnya, klik kanan, pilih ADD GROUP WITH TOOLBAR
sehingga jadi kyk gini :

nah kalo untuk merubah tulisan, tinggal ganti di PROPERTIES - CAPTION
kamu bisa ngulik sendiri soal properties mah ~XD

nah didalam ribbon kan pasti ada item, buat di klik, ya engga?
gini caranya... di GROUP RIBBON yang tadi, klik kanan ADD LARGE BUTTON



fungsinya sama seperti BUTTON aja, kalo di dobel click, bisa dikasih coding, untuk nampilin form lain, untuk query, dan sebagainya. (tergantung keinginan)
untuk rubah tulisan, seperti biasa ada dibagian PROPERTIES - CAPTION

kamu bisa nambahin sebanyak yang km mau, dan seperlunya.
trus untuk LARGE BUTTON, masukin gambarnya lewat PROPERTIES - LARGE GLYPH
trus pilih LOAD dan cari gambar yang kamu mau
selanjutnya, tinggal kamu berkreasi sendiri :D


trus buat menu dipojok kiri, kita tambahin lagi ADD GROUP WITH EMPTY TOOLBAR, trus klik dxRIBBON nya, cari properties QUICK ACCESS TOOLBAR
expands (buka) aja,
trus pilih dibagian TOOLBAR, nanti tampilannya jadi seperti ini :


sebenernya konsepnya SAMA aja dengan toolbar yang biasa, cuman letaknya diatas,
untuk nambahin BUTTON, LARGE BUTTON, sama saja, klik kanan pada toolbar dan selanjutnya terserah anda :D


Mudah kan?
untuk komponen statusbar, dobel klik aja, trus ADD ( ini proses nambahin panel ) sebanyak yang dimau,
ubah2 dibagian PROPERTIES aja, disana banyak macamnya

untuk nampilin jam digital distatus bar, tambahin komponen TIMER
dobel klik trus ketik ini :

SStatusBar1.Panels[1].text:=formatdatetime('hh:mm:ss  dddd dd-MMMM-yyyy',now);

tu artinya NAME statusbar saya adalah sStatusBar1
Panels[1].text memaksudkan panel pertama (bagian pertama) dari status bar saya

semoga bisa membantu kawan2 sekalian :)

DELPHI - Autonumbering (penomoran otomatis) pada Stored function MySQL

Selamat malam pemirsa setia :D
mumpung lagi penat sama kerjaan jadi iseng deh bkin blog dlu :D
sekalian bagi2 nih buat para programmer yang lagi pusing mikirin programmingnya :D
maklum sih ya programming udah jadi hobbi buat saya :p (gila x ye masa hobby programming cba -___-)

oke deh tanpa basa basi :D
nih coding buat autonumbering di MySQL (stored function)

nanti hasilnya : B 13 07 22 001
B itu kode ( bisa kamu tentuin sesuai kebutuhan)
13 itu tahun (2013)
07 itu Bulan ( ke-7 )
22 itu Tanggal di bulan itu
001 itu nomor urut bon/nota

jadi tiap hari akan kereset sendirinya, maksudnya?
gini nih :D
misalnya hari ini (22 july 2013) ada 78 transaksi, maka nomor urut terakhir :
B130722078
nah besoknya tanggal (23 july 2013) nomor urutnya akan balik jadi 1 lagi
B130723001
jadi ga akan penuh gan :D
maksimal 1 hari 999 transaksi, 


BEGIN
  declare an char(10);
  declare n char(10);
  set an = concat('B',substr(year(now()),3,2),lpad(MONTH(now()),2,'0'),lpad(DAY(now()),2,'0') );
  
  select max(Nomor_beli) into n from mbeli
  where Nomor_beli like(concat(an,'%'));

  if n is null then
     set n = concat(an,'001');
  else
      set n = concat(an,lpad(substr(n,8,3)+1,3,'0'));
  end if;
  
  return(n);
END

oke deh pemirsa setia :D
sekian dari saya, semoga dapat membantu yah...
jangan lupa selalu kunjungi blog saya :D
banyak source code yang ditempel & dibagikan gratiss :D