SlideShare a Scribd company logo
1 of 7
Download to read offline
Giới thiệu

Các lớp control của VB.NET (cũng như .NET Framework) có dạng cây kế thừa như sau:

                                                            Control




                  TextBoxBase                    ListView                                ...       UserControl




    RichTextBox                      TextBox




                                User-defined Control              User-defined Control         User-defined Control




Đầu tiên, tạo 1 Windows Application Project, đặt tên tùy ý (ở đây là
VBUserControlCustomControl). Visual Studio tạo 1 solution tên là
“VBUserControlCustomControl”; trong đó có sẵn 1 project dạng WinForm cùng tên. Form1
của project này được dùng để chạy thử các control sắp được định nghĩa.

Sau đó tiến hành thêm các control. Các control do người dùng định nghĩa (user-defined) đều
có thể được sử dụng tương tự các control có sẵn (built-in) của .NET Framework. Sau khi
build ứng dụng thành công, các control mới do người lập trình (người dùng) tự định nghĩa
được thêm vào Toolbox.

Để tạo control mới, người lập trình thường thừa kế từ một control có sẵn (như TextBox,
ListView,…), từ lớp System.Windows.Forms.UserControl hay từ lớp
Systems.Windows.Forms.Control.

Custom Control – RoundButton

Custom Control là các control được tạo thành bằng cách kế thừa lớp
System.Windows.Forms.Control.

Mục tiêu: tạo 1 Custom Control dạng Button nhưng có hình ellipse.

Trong cửa sổ Solution Explorer, nhấp chuột phải vào tên project, chọn Add → New Item….

Trong cửa số Add New Item, chọn Custom Control. Nhập tên cho Custom Control mới:
RoundButton. Nhấn OK.

Trong cửa sổ Solution Explorer, nhấp chuột phải vào RoundButton.vb, chọn View Code.
Thêm data member m_BackgroundColor vào lớp RoundButton, data member này lưu trữ
màu nền của đối tượng RoundButton:



Khai báo và định nghĩa Property cho m_BackgroundColor; nhờ phần này, BackgroundColor
sẽ xuất hiện ở dạng 1 mục chọn trong cửa sổ Properties của control RoundButton:




Override hàm OnPaint của lớp Control trong lớp RoundControl:




Đối tượng RoundButton khi thể hiện trong 1 Form sẽ có hình dạng 1 ellipse, màu nền là
m_BackgroundColor. Thông tin về kích thước (Width & Height) và dòng chữ (Text) trên
hình ellipse này có thể được thay đổi bằng cách kéo thả hay / và thao tác trong cửa sổ
Properties.

Build ứng dụng. Sửa lỗi nếu có thông báo lỗi.

Nhấp đôi chuột trái vào Form1.vb để mở màn hình thiết kế Form1.

Lúc này trong phần Toolbox đã có thêm control RoundButton. Ta có thể kéo thả control này
vào Form1 và sử dụng như 1 Button. Nhấp đôi chuột trái vào control này để vào hàm xử lí sự
kiện OnClick.

Tuy nhiên, khi ta nhấp chuột trái ngoài hình ellipse (nhưng vẫn còn trong control) thì sự kiện
OnClick vẫn xảy ra. Để sự kiện OnClick chỉ xảy ra khi người dùng nhấp chuột trong hình
ellipse ta phải kiểm tra điểm nhấp chuột có nằm trong hình ellipse hay không.

Cách đơn giản nhất là dùng 1 GraphicsPath có hình ellipse khớp với hình của RoundButton,
sau đó dùng hàm IsVisible của GraphicsPath để kiểm tra điểm nhấp chuột có nằm trong
GraphicsPath hay không. Lưu ý: phải chuyển điểm nhấp chuột từ hệ tọa độ Form1 sang hệ
tọa độ của control, dùng hàm PointToClient của Form1.
Các bước thực hiện:

   -   Bước 1: thêm data member m_VisibleArea kiểm GraphicsPath. Đây là biến giữ thông
       tin vùng có thể xảy ra sự kiện OnClick.



   -   Bước 2: chỉnh sửa hàm OnPaint để đưa thông tin vào m_VisibleArea.




   -   Bước 3: override hàm OnClick của RoundButton. Cursor.Position là vị trí của chuột
       trên Form1.




Extended Control – PowerTextBox

Extended Control là control được tạo ra bằng cách kế thừa một control có sẵn (TextBox,
ListView,…).

Mục tiêu: tạo 1 TextBox có cho phép chọn loại dữ liệu nhập (chữ, số, không phân biệt).

Trong cửa sổ Solution Explorer, nhấp chuột phải vào tên project, chọn Add → User
Control….

Nhập tên cho Control mới: PowerTextBox. Nhấn OK.

Mở tập tin PowerTextBox.Designer.vb (bằng Notepad hay Notepad++). Lưu ý: Visual Studio
không hiển thị tập tin này trong Solution Explorer, chỉ có thể chọn xem tập tin này trong
Windows Explorer (hoặc trình duyệt tập tin khác).

Sửa System.Windows.Forms.UserControl thành System.Windows.Forms.TextBox: control
PowerTextBox kế thừa từ lớp TextBox.
Sau khi sửa xong, có thể bị báo lỗi ở hàm InitializeComponent. Đó là do một số thuộc tính
của TextBox khác so với UserControl, chỉ cần bỏ (comment) những dòng báo lỗi là được.

Định nghĩa enum kiểu nhập trong lớp PowerTextBox:




Thêm các data member và property: m_TypeMode để lưu kiểu nhập và m_ErrorText để lưu
thông báo lỗi.




Viết hàm tạo (contructor) cho lớp PowerTextBox:




Chuyển qua màn hình Designer của PowerTextBox (bằng cách nhấp đôi chuột vào
PowerTextBox.vb trong Solution Explorer), gán hàm xử lí sự kiện KeyPress (nhấn phím) cho
control này. Hàm xử lí sự kiện được gán bằng cách nhấp đôi chuột vào dòng KeyPress.
Viết hàm xử lí sự kiện:




Composite Control

Composite Control là control chứa một số control khác. Thường được tạo bằng cách thừa kế
lớp System.Windows.Forms.UserControl.

Trong cửa sổ Solution Explorer, nhấp chuột phải vào Solution “…” (cấp cao nhất), chọn Add
→ New Project. Chọn loại project là Class Library. Đặt tên là FileChooserControl. Project
này sẽ chứa control mới do người lập trình tự định nghĩa và ở dạng thư viện DLL. Control
mới này bao gồm 1 TextBox và 1 Button, cho phép người dùng chọn tập tin và trả về đường
dẫn tập tin đó.

Để sử dụng control mới ở trên trong project VBUserControlCustomControl (project dạng
WinForm có chứa Form1.vb), nhấp chuột phải vào tên project
VBUserControlCustomControl, chọn Add Reference, chọn tab Projects, chọn
FileChooserControl, nhấn OK.

Quay lại project FileChooseControl, thêm UserControl bằng cách nhấp chuột phải vào
FileChooserControl, chọn Add… → User Control…, đặt tên là FileChooser.

Kéo từ Toolbox vào màn hình Designer của FileChooser 2 control:

   -   TextBox: trong cửa sổ Properties, gán Name = txtPath.
   -   Button: trong cửa sổ Properties, gán Name = btnBrowse, Text = Browse.




Nhấp đôi chuột vào button btnBrowse để nhảy đến hàm xử lí sự kiện OnClick
(btnBrowse_Click).

Trong lớp FileChooser, thêm enum biểu diễn loại cửa sổ cần mở (chọn đường dẫn mở file
hay lưu file):




Định nghĩa data member và property cho người dùng chọn loại cửa sổ:




Khai báo data member cửa sổ sẽ hiển thị cho người dùng chọn tập tin, lớp
System.Windows.Forms.FileDialog là lớp cha của lớp OpenFileDialog và SaveFileDialog:



Thêm data member lưu đường dẫn mà người dùng đã chọn:
Xử lí sự kiện OnClick của btnBrowse:




Tùy vào chọn lựa của người dùng mà cửa sổ OpenFileDialog hay SaveFileDialog được hiển
thị. Sau đó nếu người dùng nhấn nút OK, đường dẫn tập tin sẽ được đưa vào txtPath.Text
(thuộc tính nội dung của TextBox txtPath) và m_Path. Người dùng có thể truy xuất đến
đường dẫn này qua property Path (ví dụ: FileChooser1.Path).

Sau khi build solution thành công, chuyển qua màn hình Designer của Form1.vb (trong
project VBUserControlCustomControl), control FileChooser đã được gắn vào Toolbox và
chúng ta có thể dùng như 1 control thông thường. Người dùng có thể chọn DialogType bằng
cách vào cửa sổ Properties của control hay thao tác trực tiếp trong mã nguồn.

Nếu chúng ta quan sát kết quả sau khi build của project FileChooserControl thì thấy có một
tập tin DLL (FileChooserControl.dll) thay vì một tập tin .exe. Trong thư mục chứa kết quả
build của project VBUserControlCustomControl cũng có file FileChooserControl.dll do đã có
tham chiếu (reference) trước đó. Nếu muốn chạy được VBUserControlCustomControl.exe,
chúng ta phải chép file FileChooserControl.dll đi theo cùng thư mục.

Tài liệu tham khảo

http://msmvps.com/blogs/deborahk/archive/2009/10/13/winforms-user-controls-101.aspx

http://ondotnet.com/pub/a/dotnet/2002/06/03/custom.html

http://msdn.microsoft.com/en-us/library/ms996437.aspx

http://msdn.microsoft.com/en-us/library/ms996439.aspx

http://www.caulacbovb.com/forum/viewtopic.php?f=23&t=868

More Related Content

What's hot (16)

Bai tap testing junit…..
Bai tap testing junit…..Bai tap testing junit…..
Bai tap testing junit…..
 
63 2601
63 260163 2601
63 2601
 
Tai lieu wincc flexible tieng viet
Tai lieu wincc flexible tieng vietTai lieu wincc flexible tieng viet
Tai lieu wincc flexible tieng viet
 
Oop 11
Oop 11Oop 11
Oop 11
 
Introduction Android For Begineer
Introduction Android For BegineerIntroduction Android For Begineer
Introduction Android For Begineer
 
Chuong 3 windows forms
Chuong 3   windows formsChuong 3   windows forms
Chuong 3 windows forms
 
Bài giảng ACCESS - VBA
Bài giảng ACCESS - VBABài giảng ACCESS - VBA
Bài giảng ACCESS - VBA
 
P7 controls 2010
P7  controls 2010P7  controls 2010
P7 controls 2010
 
P3 web server control
P3   web server controlP3   web server control
P3 web server control
 
Chuong vb.net
Chuong vb.netChuong vb.net
Chuong vb.net
 
C# co ban 8
C# co ban 8C# co ban 8
C# co ban 8
 
Chuong 08 menu and toolbar
Chuong 08   menu and toolbarChuong 08   menu and toolbar
Chuong 08 menu and toolbar
 
Bai tap3 java
Bai tap3 javaBai tap3 java
Bai tap3 java
 
Hướng dẫn lập trình với SCSF phần II(smart client software factory)
Hướng dẫn lập trình với SCSF phần II(smart client software factory)Hướng dẫn lập trình với SCSF phần II(smart client software factory)
Hướng dẫn lập trình với SCSF phần II(smart client software factory)
 
Do xuanthai
Do xuanthaiDo xuanthai
Do xuanthai
 
access
accessaccess
access
 

Similar to Hdth03 ltudql02-user control

Core java 5
Core java 5Core java 5
Core java 5
. .
 
Về Visual Basic 20 5
Về Visual Basic 20 5Về Visual Basic 20 5
Về Visual Basic 20 5
Phong Lữ
 
Giáo trình tổng quan về Vb
Giáo trình tổng quan về VbGiáo trình tổng quan về Vb
Giáo trình tổng quan về Vb
Sun Down
 
Bài 7: Toast – Dialog, ListView & Binding
Bài 7: Toast – Dialog, ListView & BindingBài 7: Toast – Dialog, ListView & Binding
Bài 7: Toast – Dialog, ListView & Binding
hoccungdoanhnghiep
 
Giao trinh asp.ne_tvoi_csharp
Giao trinh asp.ne_tvoi_csharpGiao trinh asp.ne_tvoi_csharp
Giao trinh asp.ne_tvoi_csharp
ngohanty13
 
Vi du chi tiet giai thich lap trinh gui trong matlab
Vi du chi tiet  giai thich lap trinh gui trong matlabVi du chi tiet  giai thich lap trinh gui trong matlab
Vi du chi tiet giai thich lap trinh gui trong matlab
PhạmThế Anh
 
Joomla administratormanual vi_20060206
Joomla administratormanual vi_20060206Joomla administratormanual vi_20060206
Joomla administratormanual vi_20060206
Giang Nguyễn
 

Similar to Hdth03 ltudql02-user control (20)

Core java 5
Core java 5Core java 5
Core java 5
 
Bai giangvb.net
Bai giangvb.netBai giangvb.net
Bai giangvb.net
 
Window Form
Window FormWindow Form
Window Form
 
Microstation v8
Microstation v8Microstation v8
Microstation v8
 
Sử dụng Microstation v8 căn bản
Sử dụng Microstation v8 căn bảnSử dụng Microstation v8 căn bản
Sử dụng Microstation v8 căn bản
 
Hướng dẫn lập trình với visual basic
Hướng dẫn lập trình với visual basicHướng dẫn lập trình với visual basic
Hướng dẫn lập trình với visual basic
 
Về Visual Basic 20 5
Về Visual Basic 20 5Về Visual Basic 20 5
Về Visual Basic 20 5
 
Giáo trình tổng quan về Vb
Giáo trình tổng quan về VbGiáo trình tổng quan về Vb
Giáo trình tổng quan về Vb
 
Oop unit 12 đồ họa và xử lý sự kiện
Oop unit 12 đồ họa và xử lý sự kiệnOop unit 12 đồ họa và xử lý sự kiện
Oop unit 12 đồ họa và xử lý sự kiện
 
Bài 2: Hướng dẫn làm việc với các điều khiển - Giáo trình FPT - Có ví dụ kèm ...
Bài 2: Hướng dẫn làm việc với các điều khiển - Giáo trình FPT - Có ví dụ kèm ...Bài 2: Hướng dẫn làm việc với các điều khiển - Giáo trình FPT - Có ví dụ kèm ...
Bài 2: Hướng dẫn làm việc với các điều khiển - Giáo trình FPT - Có ví dụ kèm ...
 
IT120-2. Bắt đầu với Hello World
IT120-2. Bắt đầu với Hello WorldIT120-2. Bắt đầu với Hello World
IT120-2. Bắt đầu với Hello World
 
Bai tap-vb
Bai tap-vbBai tap-vb
Bai tap-vb
 
Bài 7: Toast – Dialog, ListView & Binding
Bài 7: Toast – Dialog, ListView & BindingBài 7: Toast – Dialog, ListView & Binding
Bài 7: Toast – Dialog, ListView & Binding
 
Giao trinh asp.ne_tvoi_csharp
Giao trinh asp.ne_tvoi_csharpGiao trinh asp.ne_tvoi_csharp
Giao trinh asp.ne_tvoi_csharp
 
Joomla administratormanual vi_20060206
Joomla administratormanual vi_20060206Joomla administratormanual vi_20060206
Joomla administratormanual vi_20060206
 
Vi du chi tiet giai thich lap trinh gui trong matlab
Vi du chi tiet  giai thich lap trinh gui trong matlabVi du chi tiet  giai thich lap trinh gui trong matlab
Vi du chi tiet giai thich lap trinh gui trong matlab
 
Hdsd eclipse
Hdsd eclipseHdsd eclipse
Hdsd eclipse
 
Vb6 16 (4)
Vb6 16 (4)Vb6 16 (4)
Vb6 16 (4)
 
Ltctwd
LtctwdLtctwd
Ltctwd
 
Joomla administratormanual vi_20060206
Joomla administratormanual vi_20060206Joomla administratormanual vi_20060206
Joomla administratormanual vi_20060206
 

More from Dũng Đinh

Hdth08 ltudql02-linq
Hdth08 ltudql02-linqHdth08 ltudql02-linq
Hdth08 ltudql02-linq
Dũng Đinh
 
Hdth07 ltudql02-linq-ep1
Hdth07 ltudql02-linq-ep1Hdth07 ltudql02-linq-ep1
Hdth07 ltudql02-linq-ep1
Dũng Đinh
 
Hdth06 ltudql02-multi languages
Hdth06 ltudql02-multi languagesHdth06 ltudql02-multi languages
Hdth06 ltudql02-multi languages
Dũng Đinh
 
Hdth04 ltudql02-dotnet bar
Hdth04 ltudql02-dotnet barHdth04 ltudql02-dotnet bar
Hdth04 ltudql02-dotnet bar
Dũng Đinh
 
Hdth02 ltudql02--tuan02 tt-
Hdth02 ltudql02--tuan02 tt-Hdth02 ltudql02--tuan02 tt-
Hdth02 ltudql02--tuan02 tt-
Dũng Đinh
 
Hdth02 ltudql02-su dungsubversion-2
Hdth02 ltudql02-su dungsubversion-2Hdth02 ltudql02-su dungsubversion-2
Hdth02 ltudql02-su dungsubversion-2
Dũng Đinh
 
Hdth02 ltudql02-su dungsubversion-1
Hdth02 ltudql02-su dungsubversion-1Hdth02 ltudql02-su dungsubversion-1
Hdth02 ltudql02-su dungsubversion-1
Dũng Đinh
 
Hdth01 ltudql2-lap tinhduongdoituong-vb
Hdth01 ltudql2-lap tinhduongdoituong-vbHdth01 ltudql2-lap tinhduongdoituong-vb
Hdth01 ltudql2-lap tinhduongdoituong-vb
Dũng Đinh
 
Hdth09 ltudql02-linq-e3
Hdth09 ltudql02-linq-e3Hdth09 ltudql02-linq-e3
Hdth09 ltudql02-linq-e3
Dũng Đinh
 
Thiet kegiaodien
Thiet kegiaodienThiet kegiaodien
Thiet kegiaodien
Dũng Đinh
 
07bis.thiet kedulieu
07bis.thiet kedulieu07bis.thiet kedulieu
07bis.thiet kedulieu
Dũng Đinh
 
06.mo hinhhoayeucau
06.mo hinhhoayeucau06.mo hinhhoayeucau
06.mo hinhhoayeucau
Dũng Đinh
 
05.thu thapyeucau
05.thu thapyeucau05.thu thapyeucau
05.thu thapyeucau
Dũng Đinh
 
01.lap trinhhuongdoituong
01.lap trinhhuongdoituong01.lap trinhhuongdoituong
01.lap trinhhuongdoituong
Dũng Đinh
 

More from Dũng Đinh (19)

Report
ReportReport
Report
 
Linq2 sql
Linq2 sqlLinq2 sql
Linq2 sql
 
Hdth08 ltudql02-linq
Hdth08 ltudql02-linqHdth08 ltudql02-linq
Hdth08 ltudql02-linq
 
Hdth07 ltudql02-linq-ep1
Hdth07 ltudql02-linq-ep1Hdth07 ltudql02-linq-ep1
Hdth07 ltudql02-linq-ep1
 
Hdth06 ltudql02-multi languages
Hdth06 ltudql02-multi languagesHdth06 ltudql02-multi languages
Hdth06 ltudql02-multi languages
 
Hdth04 ltudql02-dotnet bar
Hdth04 ltudql02-dotnet barHdth04 ltudql02-dotnet bar
Hdth04 ltudql02-dotnet bar
 
Hdth02 ltudql02--tuan02 tt-
Hdth02 ltudql02--tuan02 tt-Hdth02 ltudql02--tuan02 tt-
Hdth02 ltudql02--tuan02 tt-
 
Hdth02 ltudql02-su dungsubversion-2
Hdth02 ltudql02-su dungsubversion-2Hdth02 ltudql02-su dungsubversion-2
Hdth02 ltudql02-su dungsubversion-2
 
Hdth02 ltudql02-su dungsubversion-1
Hdth02 ltudql02-su dungsubversion-1Hdth02 ltudql02-su dungsubversion-1
Hdth02 ltudql02-su dungsubversion-1
 
Hdth01 ltudql2-lap tinhduongdoituong-vb
Hdth01 ltudql2-lap tinhduongdoituong-vbHdth01 ltudql2-lap tinhduongdoituong-vb
Hdth01 ltudql2-lap tinhduongdoituong-vb
 
Hdth09 ltudql02-linq-e3
Hdth09 ltudql02-linq-e3Hdth09 ltudql02-linq-e3
Hdth09 ltudql02-linq-e3
 
Thiet kegiaodien
Thiet kegiaodienThiet kegiaodien
Thiet kegiaodien
 
07bis.thiet kedulieu
07bis.thiet kedulieu07bis.thiet kedulieu
07bis.thiet kedulieu
 
06.mo hinhhoayeucau
06.mo hinhhoayeucau06.mo hinhhoayeucau
06.mo hinhhoayeucau
 
05.thu thapyeucau
05.thu thapyeucau05.thu thapyeucau
05.thu thapyeucau
 
04.mo daucnpm
04.mo daucnpm04.mo daucnpm
04.mo daucnpm
 
03.ke thua daxa
03.ke thua daxa03.ke thua daxa
03.ke thua daxa
 
02.thiet kelop
02.thiet kelop02.thiet kelop
02.thiet kelop
 
01.lap trinhhuongdoituong
01.lap trinhhuongdoituong01.lap trinhhuongdoituong
01.lap trinhhuongdoituong
 

Recently uploaded

C6. Van de dan toc va ton giao ....pdf . Chu nghia xa hoi
C6. Van de dan toc va ton giao ....pdf . Chu nghia xa hoiC6. Van de dan toc va ton giao ....pdf . Chu nghia xa hoi
C6. Van de dan toc va ton giao ....pdf . Chu nghia xa hoi
dnghia2002
 
Tử Vi Là Gì Học Luận Giải Tử Vi Và Luận Đoán Vận Hạn
Tử Vi Là Gì Học Luận Giải Tử Vi Và Luận Đoán Vận HạnTử Vi Là Gì Học Luận Giải Tử Vi Và Luận Đoán Vận Hạn
Tử Vi Là Gì Học Luận Giải Tử Vi Và Luận Đoán Vận Hạn
Kabala
 
26 Truyện Ngắn Sơn Nam (Sơn Nam) thuviensach.vn.pdf
26 Truyện Ngắn Sơn Nam (Sơn Nam) thuviensach.vn.pdf26 Truyện Ngắn Sơn Nam (Sơn Nam) thuviensach.vn.pdf
26 Truyện Ngắn Sơn Nam (Sơn Nam) thuviensach.vn.pdf
ltbdieu
 
SD-05_Xây dựng website bán váy Lolita Alice - Phùng Thị Thúy Hiền PH 2 7 8 6 ...
SD-05_Xây dựng website bán váy Lolita Alice - Phùng Thị Thúy Hiền PH 2 7 8 6 ...SD-05_Xây dựng website bán váy Lolita Alice - Phùng Thị Thúy Hiền PH 2 7 8 6 ...
SD-05_Xây dựng website bán váy Lolita Alice - Phùng Thị Thúy Hiền PH 2 7 8 6 ...
ChuThNgnFEFPLHN
 
bài tập lớn môn kiến trúc máy tính và hệ điều hành
bài tập lớn môn kiến trúc máy tính và hệ điều hànhbài tập lớn môn kiến trúc máy tính và hệ điều hành
bài tập lớn môn kiến trúc máy tính và hệ điều hành
dangdinhkien2k4
 

Recently uploaded (20)

TUYỂN TẬP ĐỀ THI GIỮA KÌ, CUỐI KÌ 2 MÔN VẬT LÍ LỚP 11 THEO HÌNH THỨC THI MỚI ...
TUYỂN TẬP ĐỀ THI GIỮA KÌ, CUỐI KÌ 2 MÔN VẬT LÍ LỚP 11 THEO HÌNH THỨC THI MỚI ...TUYỂN TẬP ĐỀ THI GIỮA KÌ, CUỐI KÌ 2 MÔN VẬT LÍ LỚP 11 THEO HÌNH THỨC THI MỚI ...
TUYỂN TẬP ĐỀ THI GIỮA KÌ, CUỐI KÌ 2 MÔN VẬT LÍ LỚP 11 THEO HÌNH THỨC THI MỚI ...
 
C6. Van de dan toc va ton giao ....pdf . Chu nghia xa hoi
C6. Van de dan toc va ton giao ....pdf . Chu nghia xa hoiC6. Van de dan toc va ton giao ....pdf . Chu nghia xa hoi
C6. Van de dan toc va ton giao ....pdf . Chu nghia xa hoi
 
Giới Thiệu Về Kabala | Hành Trình Thấu Hiểu Bản Thân | Kabala.vn
Giới Thiệu Về Kabala | Hành Trình Thấu Hiểu Bản Thân | Kabala.vnGiới Thiệu Về Kabala | Hành Trình Thấu Hiểu Bản Thân | Kabala.vn
Giới Thiệu Về Kabala | Hành Trình Thấu Hiểu Bản Thân | Kabala.vn
 
Tử Vi Là Gì Học Luận Giải Tử Vi Và Luận Đoán Vận Hạn
Tử Vi Là Gì Học Luận Giải Tử Vi Và Luận Đoán Vận HạnTử Vi Là Gì Học Luận Giải Tử Vi Và Luận Đoán Vận Hạn
Tử Vi Là Gì Học Luận Giải Tử Vi Và Luận Đoán Vận Hạn
 
Đề thi tin học HK2 lớp 3 Chân Trời Sáng Tạo
Đề thi tin học HK2 lớp 3 Chân Trời Sáng TạoĐề thi tin học HK2 lớp 3 Chân Trời Sáng Tạo
Đề thi tin học HK2 lớp 3 Chân Trời Sáng Tạo
 
TUYỂN TẬP 50 ĐỀ LUYỆN THI TUYỂN SINH LỚP 10 THPT MÔN TOÁN NĂM 2024 CÓ LỜI GIẢ...
TUYỂN TẬP 50 ĐỀ LUYỆN THI TUYỂN SINH LỚP 10 THPT MÔN TOÁN NĂM 2024 CÓ LỜI GIẢ...TUYỂN TẬP 50 ĐỀ LUYỆN THI TUYỂN SINH LỚP 10 THPT MÔN TOÁN NĂM 2024 CÓ LỜI GIẢ...
TUYỂN TẬP 50 ĐỀ LUYỆN THI TUYỂN SINH LỚP 10 THPT MÔN TOÁN NĂM 2024 CÓ LỜI GIẢ...
 
Danh sách sinh viên tốt nghiệp Đại học - Cao đẳng Trường Đại học Phú Yên năm ...
Danh sách sinh viên tốt nghiệp Đại học - Cao đẳng Trường Đại học Phú Yên năm ...Danh sách sinh viên tốt nghiệp Đại học - Cao đẳng Trường Đại học Phú Yên năm ...
Danh sách sinh viên tốt nghiệp Đại học - Cao đẳng Trường Đại học Phú Yên năm ...
 
các nội dung phòng chống xâm hại tình dục ở trẻ em
các nội dung phòng chống xâm hại tình dục ở trẻ emcác nội dung phòng chống xâm hại tình dục ở trẻ em
các nội dung phòng chống xâm hại tình dục ở trẻ em
 
Bài giảng môn Truyền thông đa phương tiện
Bài giảng môn Truyền thông đa phương tiệnBài giảng môn Truyền thông đa phương tiện
Bài giảng môn Truyền thông đa phương tiện
 
xemsomenh.com-Vòng Lộc Tồn - Vòng Bác Sĩ và Cách An Trong Vòng Lộc Tồn.pdf
xemsomenh.com-Vòng Lộc Tồn - Vòng Bác Sĩ và Cách An Trong Vòng Lộc Tồn.pdfxemsomenh.com-Vòng Lộc Tồn - Vòng Bác Sĩ và Cách An Trong Vòng Lộc Tồn.pdf
xemsomenh.com-Vòng Lộc Tồn - Vòng Bác Sĩ và Cách An Trong Vòng Lộc Tồn.pdf
 
ĐỀ KIỂM TRA CUỐI KÌ 2 BIÊN SOẠN THEO ĐỊNH HƯỚNG ĐỀ BGD 2025 MÔN TOÁN 10 - CÁN...
ĐỀ KIỂM TRA CUỐI KÌ 2 BIÊN SOẠN THEO ĐỊNH HƯỚNG ĐỀ BGD 2025 MÔN TOÁN 10 - CÁN...ĐỀ KIỂM TRA CUỐI KÌ 2 BIÊN SOẠN THEO ĐỊNH HƯỚNG ĐỀ BGD 2025 MÔN TOÁN 10 - CÁN...
ĐỀ KIỂM TRA CUỐI KÌ 2 BIÊN SOẠN THEO ĐỊNH HƯỚNG ĐỀ BGD 2025 MÔN TOÁN 10 - CÁN...
 
26 Truyện Ngắn Sơn Nam (Sơn Nam) thuviensach.vn.pdf
26 Truyện Ngắn Sơn Nam (Sơn Nam) thuviensach.vn.pdf26 Truyện Ngắn Sơn Nam (Sơn Nam) thuviensach.vn.pdf
26 Truyện Ngắn Sơn Nam (Sơn Nam) thuviensach.vn.pdf
 
Giáo trình xây dựng thực đơn. Ths Hoang Ngoc Hien.pdf
Giáo trình xây dựng thực đơn. Ths Hoang Ngoc Hien.pdfGiáo trình xây dựng thực đơn. Ths Hoang Ngoc Hien.pdf
Giáo trình xây dựng thực đơn. Ths Hoang Ngoc Hien.pdf
 
Kiến thức cơ bản về tư duy số - VTC Net Viet
Kiến thức cơ bản về tư duy số - VTC Net VietKiến thức cơ bản về tư duy số - VTC Net Viet
Kiến thức cơ bản về tư duy số - VTC Net Viet
 
60 CÂU HỎI ÔN TẬP LÝ LUẬN CHÍNH TRỊ NĂM 2024.docx
60 CÂU HỎI ÔN TẬP LÝ LUẬN CHÍNH TRỊ NĂM 2024.docx60 CÂU HỎI ÔN TẬP LÝ LUẬN CHÍNH TRỊ NĂM 2024.docx
60 CÂU HỎI ÔN TẬP LÝ LUẬN CHÍNH TRỊ NĂM 2024.docx
 
20 ĐỀ DỰ ĐOÁN - PHÁT TRIỂN ĐỀ MINH HỌA BGD KỲ THI TỐT NGHIỆP THPT NĂM 2024 MÔ...
20 ĐỀ DỰ ĐOÁN - PHÁT TRIỂN ĐỀ MINH HỌA BGD KỲ THI TỐT NGHIỆP THPT NĂM 2024 MÔ...20 ĐỀ DỰ ĐOÁN - PHÁT TRIỂN ĐỀ MINH HỌA BGD KỲ THI TỐT NGHIỆP THPT NĂM 2024 MÔ...
20 ĐỀ DỰ ĐOÁN - PHÁT TRIỂN ĐỀ MINH HỌA BGD KỲ THI TỐT NGHIỆP THPT NĂM 2024 MÔ...
 
SD-05_Xây dựng website bán váy Lolita Alice - Phùng Thị Thúy Hiền PH 2 7 8 6 ...
SD-05_Xây dựng website bán váy Lolita Alice - Phùng Thị Thúy Hiền PH 2 7 8 6 ...SD-05_Xây dựng website bán váy Lolita Alice - Phùng Thị Thúy Hiền PH 2 7 8 6 ...
SD-05_Xây dựng website bán váy Lolita Alice - Phùng Thị Thúy Hiền PH 2 7 8 6 ...
 
bài tập lớn môn kiến trúc máy tính và hệ điều hành
bài tập lớn môn kiến trúc máy tính và hệ điều hànhbài tập lớn môn kiến trúc máy tính và hệ điều hành
bài tập lớn môn kiến trúc máy tính và hệ điều hành
 
Giáo trình nhập môn lập trình - Đặng Bình Phương
Giáo trình nhập môn lập trình - Đặng Bình PhươngGiáo trình nhập môn lập trình - Đặng Bình Phương
Giáo trình nhập môn lập trình - Đặng Bình Phương
 
xemsomenh.com-Vòng Thái Tuế và Ý Nghĩa Các Sao Tại Cung Mệnh.pdf
xemsomenh.com-Vòng Thái Tuế và Ý Nghĩa Các Sao Tại Cung Mệnh.pdfxemsomenh.com-Vòng Thái Tuế và Ý Nghĩa Các Sao Tại Cung Mệnh.pdf
xemsomenh.com-Vòng Thái Tuế và Ý Nghĩa Các Sao Tại Cung Mệnh.pdf
 

Hdth03 ltudql02-user control

  • 1. Giới thiệu Các lớp control của VB.NET (cũng như .NET Framework) có dạng cây kế thừa như sau: Control TextBoxBase ListView ... UserControl RichTextBox TextBox User-defined Control User-defined Control User-defined Control Đầu tiên, tạo 1 Windows Application Project, đặt tên tùy ý (ở đây là VBUserControlCustomControl). Visual Studio tạo 1 solution tên là “VBUserControlCustomControl”; trong đó có sẵn 1 project dạng WinForm cùng tên. Form1 của project này được dùng để chạy thử các control sắp được định nghĩa. Sau đó tiến hành thêm các control. Các control do người dùng định nghĩa (user-defined) đều có thể được sử dụng tương tự các control có sẵn (built-in) của .NET Framework. Sau khi build ứng dụng thành công, các control mới do người lập trình (người dùng) tự định nghĩa được thêm vào Toolbox. Để tạo control mới, người lập trình thường thừa kế từ một control có sẵn (như TextBox, ListView,…), từ lớp System.Windows.Forms.UserControl hay từ lớp Systems.Windows.Forms.Control. Custom Control – RoundButton Custom Control là các control được tạo thành bằng cách kế thừa lớp System.Windows.Forms.Control. Mục tiêu: tạo 1 Custom Control dạng Button nhưng có hình ellipse. Trong cửa sổ Solution Explorer, nhấp chuột phải vào tên project, chọn Add → New Item…. Trong cửa số Add New Item, chọn Custom Control. Nhập tên cho Custom Control mới: RoundButton. Nhấn OK. Trong cửa sổ Solution Explorer, nhấp chuột phải vào RoundButton.vb, chọn View Code.
  • 2. Thêm data member m_BackgroundColor vào lớp RoundButton, data member này lưu trữ màu nền của đối tượng RoundButton: Khai báo và định nghĩa Property cho m_BackgroundColor; nhờ phần này, BackgroundColor sẽ xuất hiện ở dạng 1 mục chọn trong cửa sổ Properties của control RoundButton: Override hàm OnPaint của lớp Control trong lớp RoundControl: Đối tượng RoundButton khi thể hiện trong 1 Form sẽ có hình dạng 1 ellipse, màu nền là m_BackgroundColor. Thông tin về kích thước (Width & Height) và dòng chữ (Text) trên hình ellipse này có thể được thay đổi bằng cách kéo thả hay / và thao tác trong cửa sổ Properties. Build ứng dụng. Sửa lỗi nếu có thông báo lỗi. Nhấp đôi chuột trái vào Form1.vb để mở màn hình thiết kế Form1. Lúc này trong phần Toolbox đã có thêm control RoundButton. Ta có thể kéo thả control này vào Form1 và sử dụng như 1 Button. Nhấp đôi chuột trái vào control này để vào hàm xử lí sự kiện OnClick. Tuy nhiên, khi ta nhấp chuột trái ngoài hình ellipse (nhưng vẫn còn trong control) thì sự kiện OnClick vẫn xảy ra. Để sự kiện OnClick chỉ xảy ra khi người dùng nhấp chuột trong hình ellipse ta phải kiểm tra điểm nhấp chuột có nằm trong hình ellipse hay không. Cách đơn giản nhất là dùng 1 GraphicsPath có hình ellipse khớp với hình của RoundButton, sau đó dùng hàm IsVisible của GraphicsPath để kiểm tra điểm nhấp chuột có nằm trong GraphicsPath hay không. Lưu ý: phải chuyển điểm nhấp chuột từ hệ tọa độ Form1 sang hệ tọa độ của control, dùng hàm PointToClient của Form1.
  • 3. Các bước thực hiện: - Bước 1: thêm data member m_VisibleArea kiểm GraphicsPath. Đây là biến giữ thông tin vùng có thể xảy ra sự kiện OnClick. - Bước 2: chỉnh sửa hàm OnPaint để đưa thông tin vào m_VisibleArea. - Bước 3: override hàm OnClick của RoundButton. Cursor.Position là vị trí của chuột trên Form1. Extended Control – PowerTextBox Extended Control là control được tạo ra bằng cách kế thừa một control có sẵn (TextBox, ListView,…). Mục tiêu: tạo 1 TextBox có cho phép chọn loại dữ liệu nhập (chữ, số, không phân biệt). Trong cửa sổ Solution Explorer, nhấp chuột phải vào tên project, chọn Add → User Control…. Nhập tên cho Control mới: PowerTextBox. Nhấn OK. Mở tập tin PowerTextBox.Designer.vb (bằng Notepad hay Notepad++). Lưu ý: Visual Studio không hiển thị tập tin này trong Solution Explorer, chỉ có thể chọn xem tập tin này trong Windows Explorer (hoặc trình duyệt tập tin khác). Sửa System.Windows.Forms.UserControl thành System.Windows.Forms.TextBox: control PowerTextBox kế thừa từ lớp TextBox.
  • 4. Sau khi sửa xong, có thể bị báo lỗi ở hàm InitializeComponent. Đó là do một số thuộc tính của TextBox khác so với UserControl, chỉ cần bỏ (comment) những dòng báo lỗi là được. Định nghĩa enum kiểu nhập trong lớp PowerTextBox: Thêm các data member và property: m_TypeMode để lưu kiểu nhập và m_ErrorText để lưu thông báo lỗi. Viết hàm tạo (contructor) cho lớp PowerTextBox: Chuyển qua màn hình Designer của PowerTextBox (bằng cách nhấp đôi chuột vào PowerTextBox.vb trong Solution Explorer), gán hàm xử lí sự kiện KeyPress (nhấn phím) cho control này. Hàm xử lí sự kiện được gán bằng cách nhấp đôi chuột vào dòng KeyPress.
  • 5. Viết hàm xử lí sự kiện: Composite Control Composite Control là control chứa một số control khác. Thường được tạo bằng cách thừa kế lớp System.Windows.Forms.UserControl. Trong cửa sổ Solution Explorer, nhấp chuột phải vào Solution “…” (cấp cao nhất), chọn Add → New Project. Chọn loại project là Class Library. Đặt tên là FileChooserControl. Project này sẽ chứa control mới do người lập trình tự định nghĩa và ở dạng thư viện DLL. Control mới này bao gồm 1 TextBox và 1 Button, cho phép người dùng chọn tập tin và trả về đường dẫn tập tin đó. Để sử dụng control mới ở trên trong project VBUserControlCustomControl (project dạng WinForm có chứa Form1.vb), nhấp chuột phải vào tên project
  • 6. VBUserControlCustomControl, chọn Add Reference, chọn tab Projects, chọn FileChooserControl, nhấn OK. Quay lại project FileChooseControl, thêm UserControl bằng cách nhấp chuột phải vào FileChooserControl, chọn Add… → User Control…, đặt tên là FileChooser. Kéo từ Toolbox vào màn hình Designer của FileChooser 2 control: - TextBox: trong cửa sổ Properties, gán Name = txtPath. - Button: trong cửa sổ Properties, gán Name = btnBrowse, Text = Browse. Nhấp đôi chuột vào button btnBrowse để nhảy đến hàm xử lí sự kiện OnClick (btnBrowse_Click). Trong lớp FileChooser, thêm enum biểu diễn loại cửa sổ cần mở (chọn đường dẫn mở file hay lưu file): Định nghĩa data member và property cho người dùng chọn loại cửa sổ: Khai báo data member cửa sổ sẽ hiển thị cho người dùng chọn tập tin, lớp System.Windows.Forms.FileDialog là lớp cha của lớp OpenFileDialog và SaveFileDialog: Thêm data member lưu đường dẫn mà người dùng đã chọn:
  • 7. Xử lí sự kiện OnClick của btnBrowse: Tùy vào chọn lựa của người dùng mà cửa sổ OpenFileDialog hay SaveFileDialog được hiển thị. Sau đó nếu người dùng nhấn nút OK, đường dẫn tập tin sẽ được đưa vào txtPath.Text (thuộc tính nội dung của TextBox txtPath) và m_Path. Người dùng có thể truy xuất đến đường dẫn này qua property Path (ví dụ: FileChooser1.Path). Sau khi build solution thành công, chuyển qua màn hình Designer của Form1.vb (trong project VBUserControlCustomControl), control FileChooser đã được gắn vào Toolbox và chúng ta có thể dùng như 1 control thông thường. Người dùng có thể chọn DialogType bằng cách vào cửa sổ Properties của control hay thao tác trực tiếp trong mã nguồn. Nếu chúng ta quan sát kết quả sau khi build của project FileChooserControl thì thấy có một tập tin DLL (FileChooserControl.dll) thay vì một tập tin .exe. Trong thư mục chứa kết quả build của project VBUserControlCustomControl cũng có file FileChooserControl.dll do đã có tham chiếu (reference) trước đó. Nếu muốn chạy được VBUserControlCustomControl.exe, chúng ta phải chép file FileChooserControl.dll đi theo cùng thư mục. Tài liệu tham khảo http://msmvps.com/blogs/deborahk/archive/2009/10/13/winforms-user-controls-101.aspx http://ondotnet.com/pub/a/dotnet/2002/06/03/custom.html http://msdn.microsoft.com/en-us/library/ms996437.aspx http://msdn.microsoft.com/en-us/library/ms996439.aspx http://www.caulacbovb.com/forum/viewtopic.php?f=23&t=868