Nạp cửa sổ con trong form MDI

Một phần của tài liệu giáo trình chuẩn microsoft visual basic (Trang 161)

V. MDI FORM

4. Nạp cửa sổ con trong form MDI

- Khi form đã đượ

Nạp nhiều form tương tự như form

<Tên> As New <Tên form đã thiết kế> ad <Tên>

<Tên>.Show Ví dụ:

Private sub mnuNew_Click() Dim f As frmEdit

Load f f.Show End

ộp tho g tạo tự động ứng dụng MDI với Menu và

ft. Có thể sử dụng chức năng này để tạo nhanh

ụng MDI. Các bước thực hiện như sau:

ọn File/New Project xuất hiện cửa sổ New Project (Hình 15.1), chọn VB

K.

sub

5. Sử dụng Form Wizard tạo ứng dụng MDI

H ại New Project có chức năn

Toolbar có dạng chuẩn của Microso các ứng d

1. Ch

Hình 15.1: Cửa sổ chọn New Project

ype, click chọn loại giao diện ứng dụng cần tạo út Next (Hình 15.2).

Hình 15.2 2. Trong hộp thoại Interface T

là MDI rồi bấm n

: Chọn loại giao diện MDI

menu và menu con (submenu) muốn sử dụng trong chương trình,

để chọn lệnh muốn xuất hiện trên menu, Uncheck để bỏ lệnh xuất ứ tự xuất hiện các mục trên menu

3. Chọn loại Check

hiện, bấm nút Ç hoặc È để di chuyển th rồi bấm nút Next.

Hình 15.3: Chọn menu trong Application Wizard

ộp thoại Customize Toolbar xuất hiện cho phép chọn lựa loạ

4. H i nút lệnh

muốn xuất hiện trên Toolbar (Hình 15.4).

Hình 15.4: Lựa chọn nút lệnh trên Toolbar 5. Bấm nút Finish để kết thúc.

Chươ

Lập trình Drag-and-Drop NG QUAN

ập trình Drag-and-Drop (kéo-nhả) đã được hỗ trợ từ nhữ ủa Visual Basic, chương này trình bày kỹ thuật lập trình kéo-nh

Kéo-nhả tự động

ỗ trợ hai chế độ kéo-nhả: tự động và bằng tay. Trong c ười lập trình chỉ cần gán một thuộc tính trong lúc thiết kế

c trong lúc chạy chương trình (run-time), Visual Basic sẽ thực hiệ

ng 16 I. TỔ

Khả năng l ng phiên bản

đầu tiên c ả trong

Visual Basic 6.0.

1.

Visual Basic h hế độ tự

động, ng (design-time)

hoặ n mọi việc;

ngược

kiện x ượng đang được kéo. Chế độ lập trình bằng tay cho phép

người lập trình tác động lên qui trình kéo-nhả một cách linh hoạt hơn.

Hầu hết các đối khiển ActiveX hỗ trợ chế độ kéo- ể vừa

là đ động ở

Để xác định đối tượng là nguồn trong hoạt động kéo-nhả, người lập trình sử dụng

thuộc tính OLEDragMode. Để xác đối tượng là đích trong hoạt động kéo-nhả,

người lập trình sử dụng thuộc tính OLEDropMode. Bảng 16.1 tóm tắt mức độ hỗ trợ của các loại đối tượng trong hoạt động kéo-nhả.

Bảng 16.1

lại trong chế độ bằng tay, người lập trình phải viết lệnh trong một số sự ảy ra trong lúc đối t

tượng điều khiển chuẩn và một số đối tượng điều

nhả. Một số chỉ có thể là đối tượng đích, một số khác có th

ối tượng nguồn, vừa là đối tượng đích. Chỉ có một số đối tượng có thể hoạt

chế độ kéo-thả tự động.

Đối tượng OLEDragMode OLEDropMode

TextBox, PictureBox, Image,

RichTextBox, MaskEdBox vbManual, vbAutomatic vbNone, vbManual, vbAutomatic ComboBox, ListBox, DirListBox,

FileListBox, DBCombo, DBList, TreeView, ListView, ImageCombo, DataList, DataCombo

vbManual,

vbAutomatic vbNone, vbManual Form, Label, Frame, CommandButton,

DriveListBox, Data, MSFlexGrid, SSTab, TabStrip, Toolbar, S

ProgressBar, Slider, Animation, UpDown, MonthView, DateTimePicker, CoolBar

Không hỗ trợ vbNone, vbManual tatusBar,

Đối với đối tượng hỗ trợ chế độ kéo-nhả tự động, để lập t trình chỉ cần gán các thuộc tính OLEDragMode và OL vbAutomatic. Ví dụ để viết m liệu kéo-nhả từ các ứng dụ người lập trình chỉ cần gán OL RichTextBox.

ập trình tác động lên qui trình kéo-nhả một cách linh hoạt hơn.

Hìn c viết lệnh trên đối tượng nguồn và đích khi muốn điều rình kéo-nhả, người lập

EDropMode có giá trị

ột ứng dụng sử dụng RichTextBox cho phép nhận dữ

ng xử lý văn bản khác như MS Word hoặc WordPad, giá trị vbAutomatic cho các thuộc tính OLEDragMode và EDropMode của

2. Kéo-nhả điều khiển bằng chương trình

Chế độ kéo-nhả điều khiển bằng chương trình (manual drag-and-drop) bằng tay

cho phép người l

h 16.1 mô tả các bướ

khiển hoạt động kéo-nhả bằng chương trình.

Sub Source_MouseDown(…) source.OLEDrag

Hình 16.1: Các sự kiện được kích hoạt khi kéo-nhả điều khiển bằng chương trình

Sub Source_OLEStartDrag(Data, effects) Data.SetData [bytes][, format] Người sử dụng click trên

đối tượng nguồn

Đối tượng nguồn định dạng dữliệu sẽ được chuyểnđi

Người sử dụng di chuyển mouse trên đối tượng đích. Đối tượng đích gán một hoặc nhiều hiệu ứng kéo-nhả

Sub Target_OLEDragOver(Data, effects…) Effects = vbDropEffectCopy

Sub Source_OLEGiveFeedback(Data, DefaultCursors) reen.MousePointer=vbCustom

Sc

Đối tượng nguồn nhận phản hồi bằng cách thay đổi dang con trỏ

Người sử dụng nhả phím chu

Sub Target_OLEDragDrop(Data, effects…) If Data.GetFormat(vbCFText) then

Text = Data.GetData(vbCFText) ột

Đối tượng nguồn hoàn tất hoạt động kéo-nhả bằng cách xóa dữ liệu nguồn nếu là lệnh Move Sub Source_OLECompleteDrag(format)

II. MỘT CHƯƠNG TRÌNH VÍ DỤ

Phần này trình bày một chương trình ví dụ có giao diện như hình 16.2

Hình 16.2: Giao diện chương trình ví dụ

ương trình gồm một RichTextBox được sử dụng vừa làm đối tượng nguồn, vừa đối tượng đích cho các hoạt động kéo-nhả. ListBox bên phải được sử dụng đối tượng đích cho các thao tác kéo nhả. Khi nội dung từ RichTextBox hoặc

một chương trình soạn thảo văn bản khác được kéo nhả vào ListBox, nó sẽ tách , sắp xếp rồi đưa vào thuộc tính List như hình 16.2. Lệnh viết cho từng sự kiện

theo sơ đồ hình 16.1 được lần lượt trình bày như sau:

1. Khởi tạo hoạt động kéo-nhả

ởi tạo hoạt động kéo-nhả bằng cách đặt thuộc tính OLEDragMode thành

vbManual rồi khởi động q trình kéo bằng cách cho thực hiện phương thức

OLEDrag trong sự kiện MouseDown:

Private Sub rtfText_MouseDown(Button As Integer, Shift As Integer, _ x As Single, y As Single)

' Khởi động hoạt động kéo khi phím phải được bấm If Button = 2 Then rtfText.OLEDrag

End Sub

Khi phương thức OLEDrag được gọi thực thi, sự kiện OLEStartDrag được kích

ạt trên đối tượng nguồn. Sự kiện này có tham số là đối tượng DataObject và

tham số AllowedEffects. DataObject là đối tượng chứa dữ liệu chuyển giữa đối

ng nguồn và đối tượng đích. Dữ liệu cũng có thể chứa trong đối tượng này

Ch làm làm từ từ Kh ho tượ

bằng phương thức SetData. Tương tự như cách sử dụng Clipboard, dữ liệu chứa có

ở n ng bảng 16.2. thể hiều dạng khác nhau như tóm tắt tro

Bảng 16.2: Khai báo hằng các loại dữ liệu chứa trong Clipboard

Hằng Giá trị Ý nghĩa

vbCFText 1 Text

vbCFBitmap 2 Bitmap (BMP) vbCFMetafile 3 Metafile (WMF) vbCFEMetafile 14 Enhanced metafile (.emf)

vbCFDIB 8 Device independent bitmap (dib or bmp) vbCFPalette 9 Color palette

vbCFFiles 15 List of files

vbCFRTF -16639 Rich Text Format (RTF)

Ví dụ đối với RichTextBox, dữ liệu di chuyển có thể ở dạng RTF hoặc Text khơng có định dạng:

Private Sub rtfText_OLEStartDrag(Data As RichTextLib.DataObject, _ AllowedEffects As Long)

If rtfText.Se

ectMove Or vbDropEffectCopy

Basic kích hoạt biến cố OLEDragOver trên

mọi đố số là

đối tượ ect đã được chuẩn bị bởi đối tượng nguồn. Căn cứ trên Effect giá trị tương

ứng vớ i sử dụng nhả chuột trên đối tượng.

Giá trị thể có giá trị như cho trong bảng sau:

lLength Then

Data.SetData rtfText.SelRTF, vbCFRTF Data.SetData rtfText.SelText, vbCFText Else

Data.SetData rtfText.TextRTF, vbCFRTF Data.SetData rtfText.Text, vbCFText End If

AllowedEffects = vbDropEff End Sub

2. Chuẩn bị cho thao tác nhả trên đối tượng nguồn

Khi hoạt động kéo đang xảy ra, Visual

i tượng mà mouse di chuyển ngang qua nó. Biến cố này nhận các tham ng DataObject và giá trị Eff

các thơng tin này, người lập trình sẽ gán cho tham số i hoạt động sẽ được thực hiện khi ngườ

effect có

Hằng Giá trị

0 vbDropEffectNone 1 vbDropEffectCopy

2 vbDropEffectMove &H80000000 vbDropEffectScroll

Giá trị cu ó ví dụ

khi m i chuyể ouse thanh cuộn củ . Tham số trạng thái a giá trị xác định tr ái mouse đang di chuyển theo hướng vào hay

i chuy ngang q có giá trị như sau: Hằng Giá

ối cùng có ý nghĩa đối tượng đích sẽ cuộn nội dung bên trong n

ouse d n trên m a Listbox (State) chứ ạng th

ra khỏi hoặc d ển ua đối tượng và trị 0 vbEnter 1 2 er vbLeave vbOv Ví dụ sau làm thay đ ề

n As Integer, Shift As Integer, X As Single, Y As Single, State As Integer) ropEffectCopy

thay đổi màu nền ListBox khi kéo mouse ngang qua listbox. use ra khỏi Listbox rds.BackColor = vbWindowBackground

ền thành màu vàng khi di chuyển mouse vào Listbox

lstWords.BackColor = vbYellow

m khi thực hiện thao tác sao chép trên đối tượng đí

Private Sub lstWords_OLEGive ong, _

DefaultCursors As Boolean)

' effect là Copy, sử dụng dạng con tr

ổi màu n n Listbox khi kéo mouse ngang qua Listbox

Private Sub lstWords_OLEDragOver(Data As DataObject, Effect As Long, Butto

If Data.GetFormat(vbCFText) Then Effect = Effect And vbD

Else

Effect = vbDropEffectNone End If

' Làm

If State = vbLeave Then

' Khôi phục màu nền khi di chuyển mo lstWo

ElseIf Effect <> 0 And State = vbEnter Then ' Đổi màu n

End If End Sub

Ngay sau biến cố OLEDragOver xảy ra trên đối tượng nguồn, Visual Basic kích hoạt tiếp biến cố OLEGiveFeedback trên đối tượng này để nhận biết hoạt động

kéo tác động như thế nào đối với đối tượng đích để có thể thực hiện thao tác tương

ứng ví dụ dạng con trỏ mouse được thay đổi khác nhau với hoạt động sao chép

hoặc di chuyển. Ví dụ sau thay đổi dạng con trỏ Custo ch.

Feedback(Effect As L

If Effect = vb opEffectCopy DefaultCu

DefaultCursors = True End If

End Sub

Cần lưu ý là nếu khơng cần thay đổi dạ thì khơng phải viết lệnh cho biến cố OLEGiveFeedback.

Khi ng OLED

tham s ường hợp này, tác dụng của tham số

Effect ó thể hiện hành vi được quyết

định tr ng đích.

Thủ tụ g biến cố OLEDragDrop trên Listbox.

b lstWords_OLEDragDrop(Data As DataObject, Effect As Long, box.

chuyển.

Then t = vbDropEffectMove

Ngay hoạt biến cố

OLEC ải viết lệnh trong biến cố này để hoàn tất

Dr Then

rsors = False

Screen.MousePointer = vbCustom

'Dạng con trỏ nạp trong đối tượng Image. Screen.MouseIcon = imgCopy.Picture Else

ng con trỏ

3. Nhả trên đối tượng đích

ười sử dụng nhả mouse trên đối tượng đích, Visual Basic kích hoạt biến cố

ragDrop trên đối tượng đích. Ngồi tham số State, biến cố này nhận các ố tương tự như OLEDragOver. Trong tr

hơi khác so với biến cố OLEDragOver vì n ên đối tượ

c dưới đây minh họa lệnh viết tron

Private Su

Button As Integer, Shift As Integer, X As Single, Y As Single) ' Khôi phục màu nền List

lstWords.BackColor = vbWindowBackground ' Xác định giá trị tham số Effect: sao chép hay di If Effect And vbDropEffectCopy Then

Effect = vbDropEffectCopy ElseIf Effect And vbDropEffectMove Effec

End If

' Trong cả hai trường hợp, chỉ nhận dữ liệu dạng Text Dim text As String

text = Data.GetData(vbCFText) ' Lệnh xử lý Text và nạp vào ListBox

End Sub

sau khi biến cố OLEDragDrop xảy ra, Visual Basic kích ompleteDrag. Người lập trình ph

thao tá ẳng hạn như xóa phần text trong đối

tượng yển (effect = vbDropEffectMove) hoặc khôi phục d động sao chép. Thủ tục dưới đây

minh h n Listbox. ct As Long) ct = vbDropEffectMove Then a phần Text chọn. xt.SelText = "" ngth = 0 End Sub

o biến cố OLESetData trên RichTextbox của ví dụ trên

en vbCFText Then ext.SelLength Then F, vbCFRTF End

c đã thực hiện trên đối tượng nguồn ch nguồn nếu là hoạt động di chu

ữ liệu trên đối tượng nguồn nếu là hoạt

ọa lệnh viết trong biến cố OLECompleteDrag trê

Private Sub rtfText_OLECompleteDrag(Effe If Effe

' Nếu là di chuyển thì xó rtfTe

Else

' Nếu là sao chép thì thơi chọn. rtfText.SelLe

End If

4. Nạp dữ liệu theo yêu cầu

Khi phương thức GetData của đối tượng DataObject trên đối tượng đích để nhận

dữ liệu ở một dạng nào đó, Visual Basic kích hoạt biến cố OLESetData trên đối

tượng nguồn. Lệnh viết ch như sau:

Private Sub rtfText_OLESetData(Data As RichTextLib.DataObject, _ DataFormat As Integer)

If DataFormat = vbCFText Th If rtfText.SelLength Then

Data.SetData rtfText.SelText, vbCFText Else Data.SetData rtfText.text, End If ElseIf DataFormat = vbCFRTF If rtfT Data.SetData rtfText.SelRTF, vbCFRTF Else Data.SetData rtfText.TextRT End If If End Sub 5. Kéo-nhả File

Windows Explorer hỗ trợ kéo nhả tập tin và nhiều ứng dụng windows có thể làm

đối tượng đích cho hoạt động kéo-nhả từ windows explorer. Phần này trình bày

cách thực hiện thao tác kéo-nhả tập tin.

Yếu tố g DataObject. Nếu người đích cho hoạt động kéo-nhả file thì phải k liệu ở dạng vbCFFile hay

không nạp tên tập tin khi người sử dụng nhả tập tin trên Listbo ount es.AddItem Data.Files(i) ng) ight$(File1.path, 1) <> "\", "\", "") - 1

ta.Files.Add path & File1.List(i)

Hình 1 giao diện chương trình thực hiện chức năng kéo nhả tập tin. Cửa s n trình bày nội dung tập tin AutoDrop.vbp được kéo-nhả từ Windows Explorer, còn cửa sổ phía dưới trình bày danh sách tập tin được nhả từ hộp hải.

chính của hoạt động này là thuộc tính files của đối tượn lập trình muốn ứng dụng làm đối tượng

iểm tra xem đối tượng DataObject có chứa dữ . Ví dụ sau minh họa cách

x : If Data.GetFormat(vbCFFiles) Then For i = 1 To Data.Files.C lstFil Next End If

Sự kiện OLEStartDrag viết sau đây minh họa đối tượng FileListBox làm đối tượng nguồn cho hoạt động kéo nhả:

Private Sub File1_OLEStartDrag(Data As DataObject, AllowedEffects As Lo

Dim i As Integer, path As String path = File1.path & IIf(R

Data.Files.Clear For i = 0 To File1.ListCount If File1.Selected(i) Then Da End If Next If Data.Files.Count Then Data.SetData , vbCFFiles AllowedEffects = vbDropEffectCopy End If End Sub 6.3 là ví dụ ổ phía trê

Một phần của tài liệu giáo trình chuẩn microsoft visual basic (Trang 161)

Tải bản đầy đủ (PDF)

(172 trang)