Gobar

Gobar

Gobar

Gobar

Gobar

Sabtu, 30 Mei 2015

Serial Port (Part2)



Assalammualaikum Wr.Wb


Welcome to my blog……

    Kembali lagi dengan saya Gobar di Catatan Mungil. Pada kesempatan kali ini saya ingin berbagi cara koneksi antar serial port (Part2), namun tanpa menggunakan hardware(antar aplikasi, dengan menggunakan aplikasi tambahan "Virtual Port"). Dalam kasus ini kita dapat mengirim dan menerima data sederhana(berupa text) antar serial port, kita cukup menggunakan method Write dengan parameter berupa string yang akan dikirim dan diterima dalam bentuk string juga.

1. Tujuan tutorial ini membuat aplikasi chating antara dua komputer menggunakan port serial.

2. Buat solution baru. Susun form dengan control-control seperti terlihat pada gambar.





3. Komponen Timer ada di Windows Form toolbar, Sedangkan komponen SerialPort ada di Components toolbar. Jangan lupa, set properties "Enabled" di komponen Timer menjadi "true". Kemudian properties Interval di-set menjadi 10 ms.

4. Double click tombol (button) dengan text “Kirim”. Ketikkan statemen di bawah ini di dalam fungsi Button_Click :

serialPort1.Write(textBox1.Text);

Kode di atas tujuannya adalah untuk menuliskan isi dari textBox1 ke port serial. Sebelumnya kita harus membuka port dulu dengan statemen :

serialPort1.Open();

Double click untuk timer. Ketikkan statemen di bawah ini di dalam fungsi Timer_Tick :

if (serialPort1.BytesToRead != 0)
       {
           textBox2.Text = serialPort1.ReadExisting();
       }

Kode di atas tujuannya adalah untuk membaca data yang ada di buffer serial port.

dan ini adalah program yang full :

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;

namespace Serial_port__part2_
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            serialPort1.Open();
        }

        private void button_Kirim_Click(object sender, EventArgs e)
        {
            serialPort1.Write(textBox1.Text);
        }

        private void timer1_Tick(object sender, EventArgs e)
        {
            if (serialPort1.BytesToRead != 0)
            {
                textBox2.Text = serialPort1.ReadExisting();
            }
        }

    }
}


5. Compile dan jalankan program.




6. Buka aplikasi hyperterminal(atau lebih dikenal dengan nama “HTerm”), kemudian amati data yang tampil pada hyperterminal saat anda mengirim data.





  

Baiklah…,, Demikian sedeikit penjelasan yang dapat saya sampaikan, jika ada kesalahan saya mohon maaf. semoga ini bermanfaat :)


Nantikan terus postingan-postingan saya selanjutnya di
http://gobarbetharaagung.blogspot.com/


Wassalammualaikum Wr.Wb




Terima Kasih

Serial Port (Part1)


Assalammualaikum Wr.Wb


Welcome to my blog……

    Kembali lagi dengan saya Gobar di Catatan Mungil. Pada kesempatan kali ini saya ingin berbagi cara koneksi antar serial port, yaitu aplikasi yang kita buat dengan hardware Arduino. Dalam kesempatan kali ini kita dapat menerima data sederhana(berupa angka) dari nilai potensio yang dihubungkan ke Arduino dan kemudian ditampilkan kedalam grarik dari aplikasi yang kita buat.

    Sebelum mulai, saya ingin menjelaskan sedikit tentang Port, port merupakan kumpulan jalur elektronik untuk menyalurkan data. Port ada yang untuk input saja, output saja atau input/output. Port dipakai untuk komunikasi antara CPU dengan monitor, keyboard, mouse dll. Proses pengiriman data dapat langsung sekaligus secara paralel dengan menggunakan beberapa kabel, atau satu-persatu secara berurutan (serial) dengan menggunakan sepasang kabel. Contoh transmisi data secara paralel adalah komunikasi harddisk IDE dengan CPU, komunikasi printer dengan komputer. Contoh transmisi data secara serial adalah komunikasi harddisk SATA dengan CPU, komunikasi USB dll. Mikrokontroller umumnya menggunakan standar komunikasi serial RS232 untuk koneksi dengan perangkat lain. Komputer juga memiliki port standar serialport, paralelport, USB, VGA dan PS/2. Pada Tutorial ini kita akan mempelajari penggunaan serial port.
1. Tujuan Tutorial ini adalah untuk menerima data dari mikrokontroller melalui port serial. Data yang dikirim oleh mikrokontroller adalah kondisi dari potensiometer. Nilai analog tegangan akan dikonversi oleh mikro ke nilai digital dalam range 0 – 1023. Kemudian nilai digital ini yang dikirim ke komputer melalui port serial. Program pada mikro (kita akan menggunakan arduino) cukup sederhana:





2. Buat solution baru. Susun form dengan control-control seperti terlihat pada gambar.






Atur properties “Series” pada chart, sehingga muncul window baru seperti dibawah ini.





Anda bisa mengubah jenis grafik dengan mengubah ChartType nya.

3. Komponen SerialPort ada di Components toolbar sedangkan komponen Chart ada di data.

4. Tambahkan program berikut untuk even Click button_Connect:

if (button_Connect.Text == "Connect")
{
     button_Connect.BackColor = Color.Orange;
     button_Connect.Text = "Disconnect";
     richTextBox1.Text = "";
     a = 0;
     serialPort1.Open();
}

else
{
     button_Connect.BackColor = Color.Gainsboro;
     button_Connect.Text = "Connect";
     serialPort1.Close();
}


5. Tambahkan program berikut ke event DataReceived-nya serial:

this.Invoke(new EventHandler(TextOutput));

Kita menggunakan method Invoke karena thread untuk receive serial berbeda dengan thread program utama. Padahal object RichTextBox atau Label, tempat kita untuk menampilkan data  serial, terletak di thread utama. Invoke membuat kita dapat melakukan cross-thread. Program di atas akan membuat event DataReceived memanggil event handler baru yang terletak dithread utama, yaitu TextOutput.

6. Untuk method TextOutput, tambahkan program berikut:

        int a;

        private void TextOutput(object sender, EventArgs e)
        {
            try
            {
                input = serialPort1.ReadExisting();
                richTextBox1.AppendText(input);

                grafik.Series["Series1"].Points.AddXY(a, Convert.ToInt16(input));
                a++;
            }

            catch (Exception)
            {
                MessageBox.Show("Error");
            }
        }

Dan ini adalah Codingan fullnya :
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;

namespace Serial_port__part1_
{
    public partial class Form1 : Form
    {
        int a;
        string input;

        public Form1()
        {
            InitializeComponent();
            button_Connect.Text = "Connect";
            button_Connect.BackColor = Color.Gainsboro;
        }

        private void button_Connect_Click(object sender, EventArgs e)
        {
            if (button_Connect.Text == "Connect")
            {
                button_Connect.BackColor = Color.Orange;
                button_Connect.Text = "Disconnect";
                richTextBox1.Text = "";
                a = 0;
                serialPort1.Open();
            }

            else
            {
                button_Connect.BackColor = Color.Gainsboro;
                button_Connect.Text = "Connect";
                serialPort1.Close();
            }
        }

        private void TextOutput(object sender, EventArgs e)
        {
            try
            {
                input = serialPort1.ReadExisting();
                richTextBox1.AppendText(input);

                grafik.Series["Series1"].Points.AddXY(a, Convert.ToInt16(input));
                a++;
            }

            catch (Exception)
            {
                MessageBox.Show("Error");
            }
        }

        private void serialPort1_DataReceived(object sender, System.IO.Ports.SerialDataReceivedEventArgs e)
        {
            this.Invoke(new EventHandler(TextOutput));
        }
    }
}



7. Compile dan jalankan programnya, maka akan tampil seperti dibawah ini : 





Baiklah…,, Demikian sedeikit penjelasan yang dapat saya sampaikan, jika ada kesalahan saya mohon maaf. semoga ini bermanfaat :)


Nantikan terus postingan-postingan saya selanjutnya di
http://gobarbetharaagung.blogspot.com/


Wassalammualaikum Wr.Wb





Terima Kasih

Selasa, 26 Mei 2015

Serial Port Communication





Assalammualaikum Wr.Wb


Welcome to my blog……

Kembali lagi dengan saya Gobar di Catatan Mungil. Pada kesempatan kali ini saya ingin berbagi cara koneksi antar serial port, namun tanpa menggunakan hardware(antar aplikasi, dengan menggunakan aplikasi tambahan "Virtual Port"). Dalam kasus ini kita dapat mengirim dan menerima data sederhana(berupa text) antar serial port yang kemudian kita beri fungsi untuk mengontrol beberapa lampu LED, kita cukup menggunakan method Write dengan parameter berupa string yang akan dikirim dan diterima dalam bentuk string juga.

Pertama-tama, teman-teman bisa mengikuti seperti design dibawah ini :




Jangan lupa menambahkan komponen “Timer” dan komponen “SerialPort” yang terdapat pada “toolbox”. Kemudian tambahkan file picture(Image) pada picturebox.




Samakan semua fungsi dan even (source code) anda dengan dibawah ini, dibawah ini adalah versi full Code-nya :

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;

namespace Serial_port_communication
{
    public partial class Form1 : Form
    {
        Image ON = Properties.Resources.LampuOn;
        Image OFF = Properties.Resources.LampuOff;

        public Form1()
        {
            InitializeComponent();
            foreach (String PortKu in System.IO.Ports.SerialPort.GetPortNames())
            {
                comboBox1.Items.Add(PortKu);
            }
            textBox2.Text ="Data Diterima";
            lampu1.Image = lampu2.Image = lampu3.Image = lampu4.Image = lampu5.Image = OFF;
        }

        private void timer1_Tick(object sender, EventArgs e)
        {
            if (serialPort1.IsOpen)
            {               
                if (serialPort1.BytesToRead != 0)
                {
                    if (textBox2.Text == "Data Diterima") { textBox2.Text = "\n"; }

                    else
                    {
                        string input = (serialPort1.ReadExisting());
                        textBox2.AppendText(input + "\n");

                        if (input.ToUpper() == "LAMPU1 HIDUP" || input.ToUpper() == "HIDUP LAMPU1")
                        {
                            lampu1.Image = ON;
                        }

                        if (input.ToUpper() == "LAMPU2 HIDUP" || input.ToUpper() == "HIDUP LAMPU2")
                        {
                            lampu2.Image = ON;
                        }

                        if (input.ToUpper() == "LAMPU3 HIDUP" || input.ToUpper() == "HIDUP LAMPU3")
                        {
                            lampu3.Image = ON;
                        }

                        if (input.ToUpper() == "LAMPU4 HIDUP" || input.ToUpper() == "HIDUP LAMPU4")
                        {
                            lampu4.Image = ON;
                        }

                        if (input.ToUpper() == "LAMPU5 HIDUP" || input.ToUpper() == "HIDUP LAMPU5")
                        {
                            lampu5.Image = ON;
                        }

                        ///...........................................................................................


                        if (input.ToUpper() == "LAMPU1 MATI" || input.ToUpper() == "MATI LAMPU1")
                        {
                            lampu1.Image = OFF;
                        }

                        if (input.ToUpper() == "LAMPU2 MATI" || input.ToUpper() == "MATI LAMPU2")
                        {
                            lampu2.Image = OFF;
                        }

                        if (input.ToUpper() == "LAMPU3 MATI" || input.ToUpper() == "MATI LAMPU3")
                        {
                            lampu3.Image = OFF;
                        }

                        if (input.ToUpper() == "LAMPU4 MATI" || input.ToUpper() == "MATI LAMPU4")
                        {
                            lampu4.Image = OFF;
                        }

                        if (input.ToUpper() == "LAMPU5 MATI" || input.ToUpper() == "MATI LAMPU5")
                        {
                            lampu5.Image = OFF;
                        }
                    }
                }
            }

            else { }
           
        }

        private void button_Open_Click(object sender, EventArgs e)
        {
            serialPort1.PortName = comboBox1.Text;

            if (comboBox1.Text == "Port" || comboBox1.Text == "")
            {
                MessageBox.Show("Pilih Port Terlebih Dahulu", "Gobar System", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }

            else
            {
                if (!serialPort1.IsOpen)
                {
                    button_Open.BackColor = Color.Orange;
                    button_Open.Enabled = false;
                    button_Close.BackColor = Color.Gainsboro;
                    button_Close.Enabled = true;
                    serialPort1.Open();
                }

                else { }
            }
        }

        private void button_Close_Click(object sender, EventArgs e)
        {
            if (serialPort1.IsOpen)
            {
                button_Close.BackColor = Color.Orange;
                button_Close.Enabled = false;
                button_Open.BackColor = Color.Gainsboro;
                button_Open.Enabled = true;
                serialPort1.Close();
            }

            else { }
        }

        private void textBox1_KeyDown(object sender, KeyEventArgs e)
        {
            if (e.KeyData == Keys.Enter)
            {
                if (serialPort1.IsOpen)
                {
                    serialPort1.Write(textBox1.Text);
                    textBox1.Text = "";
                }

                else { }
            }
        }

        private void textBox1_Click(object sender, EventArgs e)
        {
            if (textBox1.Text == "Kirim Data")
            {
                textBox1.Text = "";
            }

            else { }

            textBox1.ForeColor = Color.Maroon;
        }

        private void All_Lampu_Click(object sender, EventArgs e)
        {
            if (serialPort1.IsOpen)
            {
                PictureBox Pilih = (PictureBox)sender;  //memilih pictureBox yg diinginkan

                if (Pilih.Image == OFF)
                {
                    serialPort1.Write(Pilih.Name + " hidup   ");
                    Pilih.Image = ON;
                }

                else
                {
                    serialPort1.Write(Pilih.Name + " mati   ");
                    Pilih.Image = OFF;
                }
            }

            else { }           
        }

        /// /// /// /// /// dibawah ini khusus fungsi textBox_Output ( sehingga Output tidak dapat diubah )...............................
        private bool LetterOnly(System.Windows.Forms.KeyPressEventArgs e)
        {
            string strValid = "";
            if (strValid.IndexOf(e.KeyChar) < 0 && !(e.KeyChar == Convert.ToChar(Keys.Back)))
            {
                return true; // not valid
            }

            else
            {
                return false; // valid
            }
        }

        private void textBox2_KeyPress(object sender, KeyPressEventArgs e)
        {
            e.Handled = LetterOnly(e);
        }

        private void textBox2_KeyDown(object sender, KeyEventArgs e)
        {
            MessageBox.Show("Maaf..... Output tidak dapat diubah !!!", "Gobar System", MessageBoxButtons.OK, MessageBoxIcon.Error);      
        }
        /// /// /// /// /// diatas ini khusus fungsi textBox_Output ( sehingga Output tidak dapat diubah )................................

    }
}




Install Virtual Port terlebih dahulu, kemudian buatlah setidaknya satu pasang koneksi(COM1 dan COM2) dengan cara “Add pair”.



  
lalu jalankan aplikasi HTERM seperti ini, lalu setting COM berlawanan dengan COM yang terdapat pada visual lalu kemudian klik “connect”.




  
Jalankan Program……..
Pemahaman Form serial Port




Contoh : Input melalui HTerm “lampu4 hidup”, maka lampu pada LED akan menyala(hijau)




Baiklah…,, Demikian sedeikit penjelasan yang dapat saya sampaikan, jika ada kesalahan saya mohon maaf. semoga ini bermanfaat :)


untuk lebih jelasnya, silahkan lihat video tutorial dibawah  :D





Nantikan terus postingan-postingan saya selanjutnya di
http://gobarbetharaagung.blogspot.com/


Wassalammualaikum Wr.Wb





Terima Kasih