1. สร้างโปรเจคขึ้นมา 1 โปรเจค กำหนดชื่อโปรเจคเป็น “Button in Datagridview”
data:image/s3,"s3://crabby-images/fabca/fabca43a57a0653510d02be8dfe401007cb28b13" alt=""
2. เพิ่ม Datagridview เข้ามาใน Form1
data:image/s3,"s3://crabby-images/bed72/bed7206b9d5565ba654874e7a74ef50b33d5baba" alt=""
3. ทำการ Add Column ขึ้นมา 2 Columns โดยใช้ชื่อเป็น “Column1”,”Column2” โดยกำหนด ColumnType เป็น DataGridViewTextBoxColumn ทั้ง 2 Columns
data:image/s3,"s3://crabby-images/3411f/3411f235566fc3f9c48b32e3064ee90c840cb051" alt=""
4. ที่ Solution Explorer ทำการสร้าง folder ใหม่ ให้ชื่อเป็น “resources” พร้อมกับเพิ่มรูปที่ต้องการให้ไปแสดงใน Button โดยกำหนดชื่อรูปเป็น “finds”
data:image/s3,"s3://crabby-images/67aa2/67aa2ea4189c7c90e4b8894f4a9698016baec9b2" alt=""
5. ทำการ Double Click ที่ Form1 จะเข้าสู่หน้าจอการเขียน Code
data:image/s3,"s3://crabby-images/3e471/3e4715970b13e5532be3e644ff2b38af289477dd" alt=""
6. ให้ทำการเขียน Code ด้านล่างนี้ก่อนบันทัด public Form1()
Button btnSelector = new Button(); //สร้าง Buttnon
int pCase; //สำหรับ เก็บส่วนของการเลือก Column
#region Event Select Button
private void SelectorClick(object sender, EventArgs e)
{
switch (pCase)
{
case 1: //value from dataGridView1_CellEnter
{
MessageBox.Show("Show Dialog here!!");
break;
}
}
}
void CreateButton(ref Button myButton)
{
myButton.FlatStyle = FlatStyle.Flat;
myButton.FlatAppearance.BorderSize = 0;
myButton.Size = new Size(25, 19);
myButton.ImageAlign = ContentAlignment.MiddleCenter;
myButton.FlatAppearance.MouseDownBackColor = Color.Transparent;
myButton.FlatAppearance.MouseOverBackColor = Color.Transparent;
myButton.BackColor = Color.Transparent;
myButton.Image = Properties.Resources.finds;//กำหนดรูปภาพ
//myButton.Text = "...";
myButton.Hide();
myButton.Click += new EventHandler(this.SelectorClick);
//--------------------------------------------
}
#endregion
7. แล้วจะพบกับ Error ดังรูปด้านล่าง ก็ไม่ต้องตกใจครับ ให้ทำตามข้อ 8 เลยครับ
data:image/s3,"s3://crabby-images/afc06/afc06156381ad52fa95d11f9cda0d9af90e5cd08" alt=""
8. ที่ Solution Explorer ให้คลิกขวาที่ Resources.resx แล้วเลือก View Designer จะได้ดังรูป
data:image/s3,"s3://crabby-images/de61f/de61f62b9a2f73410dc6e8e08a903e747a9e0fd0" alt=""
9. คลิกที่ลูกศรลงข้าง Add Resource แล้วเลือก Add Existing File
data:image/s3,"s3://crabby-images/44698/4469879fe6b4a2e8d8ecc568c04c0439751887cc" alt=""
10. Browse หารูปที่ต้องการแสดงใน Button ในตัวอย่างนี้ผมใช้รูป finds.png แล้วกดปุ่ม open
data:image/s3,"s3://crabby-images/2d0f0/2d0f08bc23b899f466c1d9ef64ae7fc9f6c60e29" alt=""
11. กรณีที่เคยใช้รูปนี้แล้ว โปรแกรมจะถามให้ Save รูปทับรูปเดิมหรือไม่ ให้ตอบ Yes แต่ถ้าไม่พบ warning นี้ ให้ข้ามไปข้อต่อไปเลยครับ
data:image/s3,"s3://crabby-images/2a852/2a852c9a1d9fef2e25f4a9a028f5bf63e9d4f324" alt=""
12. จะได้ resource มาดังรูป
data:image/s3,"s3://crabby-images/a0640/a064031414a604f879f2d662d913f8b9e6db7ec0" alt=""
13. จากนั้นทำการ save ก็จะพบว่า error ได้หายไปแล้ว
data:image/s3,"s3://crabby-images/c2214/c2214ef0086febb39746941e2b6af03968d74b26" alt=""
14. กลับไปหน้าต่างการเขียน Code ของ Form1 ทำการเพิ่ม Code ด้านล่างนี้ เข้าไปใน events : CellEnter ของ dataGridView1
if (dataGridView1.Columns[e.ColumnIndex].Name == "Column1")
{
pCase = 1;
Rectangle Loc = dataGridView1.GetCellDisplayRectangle(e.ColumnIndex, e.RowIndex, false);
int Wid = dataGridView1.CurrentCell.Size.Width;
btnSelector.Location = new Point(Loc.X - 25 + Wid, Loc.Y);
btnSelector.Show();
}
15. จะได้ code ดังรูป ซึ่ง code ชุดนี้เป็นการวาด MyButton ใน Cell ของ Column1 ที่ถูก forcus
data:image/s3,"s3://crabby-images/f3dc8/f3dc884f54aa18bec6540531843d30297c2e7ae5" alt=""
16. จากนั้นก็เพิ่ม code ด้านล่าง เข้าไปใน events : CellLeave ของ dataGridView1
if (btnSelector.Focused != true)
{
btnSelector.Hide();
}
17. ได้ผลดังรูป อธิบาย code ชุดนี้ได้ว่า เมื่อออกจาก cell นั้น ๆ แล้วก็จะทำการ Hide ปุ่มไว้
data:image/s3,"s3://crabby-images/65191/65191f93bcd6e32376422ac43088f6cb448b7089" alt=""
18. จากนั้นเพิ่ม code ด้านล่าง เข้าไปใน procedure : private void Form1_Load
CreateButton(ref btnSelector);
dataGridView1.Controls.Add(btnSelector);
19. ได้ผลดังรูป อธิบาย code ชุดนี้เป็นการสร้าง Button ไว้รอตอนที่ทำการโหลด Form1 แต่ยังไม่ได้ทำการวาด Button ลงใน Datagridview1 จนกว่าจะทำการ click cell ใน Column1
data:image/s3,"s3://crabby-images/9693a/9693aa80e340a53fbb7bef0ff569adb6b75998d1" alt=""
20. เสร็จแล้ว ลองทำการ Run ดู ถ้าได้ดังรูปด้านล่างถือว่าประสบความสำเร็จแล้วครับ
data:image/s3,"s3://crabby-images/e0a6f/e0a6f31687506f767bdefa7ad312fed28d4db6b3" alt=""
No comments:
Post a Comment