CÁC N ỘI DUNG TRÌNH BÀY
CHƯƠNG I. Công cụlập trình.8
I.1. Làm quen với giao diện Visual Basic.8
I.2. Ngôn ngữVisual Basic.27
I.3. Kỹnăng gỡrối chương trình (debug).51
I.4. Sửdụng ActiveX trong Visual Basic.54
I.5. Kết nối cơsởdữliệu với ADO.61
I.6. Các hàm API cơbản.68
CHƯƠNG II. Thiết kếphần mềm.73
II.1. Khái quát vềUML.73
II.2. Rational Rose.77
II.3. Use case diagram.78
II.4. Biểu đồtương tác (Interaction diagram).81
II.5. Class diagram.83
II.6. Biểu đồthành phần (Component diagram).87
II.7. Ví dụáp dụng.88
CHƯƠNG III. Đồhọa.106
III.1. Mục đích.106
III.2. Các chức năng chính của 1 hệ đồhọa.106
III.3. Sửdụng VDraw Component.106
CHƯƠNG IV. Trợgiúp và đóng gói.115
IV.1. Lập trợgiúp với RoboHelp.115
IV.2. Đóng gói với InstallSheld.115
IV.3. Tạo film demo với WinCam.115
Tài liệu tham khảo.116
116 trang |
Chia sẻ: maiphuongdc | Lượt xem: 1839 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Tài liệu hướng dẫn Thực tập tốt nghiệp (ngành Tin học Xây dựng), để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
s Set...
= New...
firstForm và secondForm còn được gọi là các instances của Class frmMyForm. Class giống
như cái khuôn, còn Objects gi ống như những cái bánh làm t ừ khuôn ấy. Chắc bạn đã để ý
thấy trong VB6 t ừ dùng hai t ừ Class và Object l ẫn lộn nhau. Đều này c ũng không quan
trọng, miễn là bạn nắm vững ý nghĩa của chúng.
VB6 có hỗ trợ Class mà ta có thể triển khai và instantiate các Objects của nó khi dùng. Một
Class trong VB6 có chứa data riêng của nó, có những Subs và Functions mà ta có th ể gọi.
Ngoài ra Class còn có th ể Raise Events, tức là báo cho ta bi ết khi chuy ện gì x ảy ra bên
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
42
trong nó. Cũng giống như Event Click của CommandButton, khi User clicks lên button thì
nó Raise Event Click để cho ta x ử lý trong Sub myCommandButton_Click(), ch ẳng h ạn.
Classtrong VB6 không có h ổ trợ Visual components, t ức là không có ch ứa những controls
như TextBox, Label .v.v.. Tuy nhiên, ta có thể lấy những control có sẵn từ bên ngoài rồi đưa
cho Object của Class dùng.
I.2.7.3. Ví dụ - Xây dựng lớp clsBox
Bây giờ chúng ta hãy b ắt đầu viết một Class. B ạn hãy m ở một Project m ới loại Standard
EXE Visual Basic. Sau đó dùng Menu Command chọn Add Class Module:
Khi Add Class Module dialog hiện ra chọn Class Module và click Open.
Bạn s ẽ th ấy mở ra m ột khung tr ắng và Project Explorer v ới Properties Window. Trong
Properties Window, hãy sửa Name property của Class thành clsBox như dưới đây:
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
43
Kế đó đánh vào những dòng code dưới đây, trong đó có biểu diển cách dùng Class clsBox.
Option Explicit
Private mX As Integer
Private mY As Integer
Private mWidth As Integer
Private mHeight As Integer
Public Property Let X(ByVal vValue As Integer)
mX = vValue
End Property
Public Property Get X() As Integer
X = mX
End Property
Public Property Let Y(ByVal vValue As Integer)
mY = vValue
End Property
Public Property Get Y() As Integer
Y = mY
End Property
Public Property Let Width(ByVal vValue As Integer)
mWidth = vValue
End Property
Public Property Get Width() As Integer
Width = mWidth
End Property
Public Property Let Height(ByVal vValue As Integer)
mHeight = vValue
End Property
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
44
Public Property Get Height() As Integer
Height = mHeight
End Property
Public Sub DrawBox(Canvas As Object)
Canvas.Line (mX, mY)-(mX + mWidth, mY + mHeight), , B
End Sub
Public Sub ClearBox(Canvas As Object)
Canvas.Line (mX, mY)-(mX + mWidth, mY + mHeight), Canvas.BackColor, B
End Sub
Class clsBox có 4 thuộc tính: X, Y, Width và Height. Ta sẽ tạo một Object Box từ clsBox.
Mỗi Box có tọa độ (X,Y) và kích thước chiều rộng và chiều cao (width, height) của nó. Thật
ra ta có th ể khai báo các bi ến X, Y, Width và Height đơn giản hơn bằng từ khóa Public.
Nhưng ở đây ta cố ý khai báo chúng là Private, dưới dạng mX, mY, mWidth và mHeight.
Khi ta muốn thay đổi các trị số của chúng, cũng dùng lệnh gán như bình thường. Nhưng khi
chương trình x ử lý l ệnh gán (ví d ụ myBox.X=80), nó s ẽ g ọi m ột ch ương trình con là
Property Let X (vValue) với vValue có giá trị 80.
Khác với phép gán thường, trong Property Let chúng ta có th ể thực hiện các phép ki ểm tra
trước khi gán hoặc thực hiện các lệnh thể hiện sự thay đổi của đối tượng tương ứng với lệnh
gán (ví d ụ khi thay đổi thu ộc tính Caption c ủa CommandButton b ằng l ệnh gán
cmdSwitch.Caption = "On" chúng ta th ấy ngay lập tức sự thay đổi được thể hiện trên màn
hình). Đó là vì trong ch ương trình con Property Let c ủa Caption có c ả đoạn mã cho phép
hiển thị lại caption của đối tượng.
Ngược lại, khi ta dùng thuộc tính X của đối tượng myBox, không phải ta chỉ đọc trị số thôi
mà còn g ọi cả cái ch ương trình con Property Get X . Nói tóm l ại, Property Get, Property
Let cho ta c ơ hội để execute một method mỗi khi chương trình đọc hay viết lên tr ị số của
thuộc tính tương ứng ấy.
Thí dụ như nếu ta muốn kiểm soát để chỉ chấp nhận trị số tọa độ X mới khi nó không phải là
số âm. Ta sẽ sửa Property Let X lại như sau:
Public Property Let X(ByVal vValue As Integer)
If (vValue >= 0) Then
mX = vValue
End If
End Property
Property có thể là Read Only hay Write Only. Nếu muốn một Property là Read Only thì ta
không cung cấp Property Let. Nếu muốn một Property là Write Only thì ta không cung c ấp
Property Get. Ngoài ra nếu làm việc với Object, thay vì Data type thông thường, thì ta phải
dùng Property Set, thay vì Property Let.
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
45
Thí dụ ta cho clsBox một Property mới, gọi là Font dùng object của class stdFont của VB6.
Trong clsBox ta declare m ột Private variable mFont và vi ết một Property Set Font như
sau:
Private mFont As StdFont
Public Property Set Font(ByVal newFont As StdFont)
Set mFont = newFont
End Property
Ta sẽ dùng property Font của myBox (thuộc Class clsBox) như sau:
' Declare an object of Class StdFont of VB6
Dim myFont As StdFont
Set myFont = New StdFont
myFont.Name = "Arial"
myFont.Bold = True
Dim myBox As clsBox
Set myBox = New clsBox
Set myBox.Font = myFont ' Call the Property Set method
Class clsBox có hai Public Subs, DrawBox và ClearBox. ClearBox cũng vẽ một box như
DrawBox, nhưng nó dùng BackColor của màn ảnh (canvas), nên coi như xóa cái box có sẵn.
Do đó, nếu muốn, bạn có thể sửa Sub DrawBox lại một chút để nhận một tham số Optional
(tham số cho phép nhập hoặc không nhập giá trị) là fColor như sau:
Public Sub DrawBox(Canvas As Object, Optional fColor As Long)
If IsMissing(fColor) Then
Canvas.Line (mX, mY)-(mX + mWidth, mY + mHeight), , B
Else
Canvas.Line (mX, mY)-(mX + mWidth, mY + mHeight), fColor, B
End If
End Sub
Trong thí dụ trên, tham số fColor được kiểm tra xem người dùng có nhập giá trị hay không
bằng bằng hàm IsMissing. Nếu fColor là BackColor c ủa canvas thì ta s ẽ có hi ệu quả của
ClearBox.
Trong form chính c ủa chương trình dùng để test clsBox, m ỗi khi ta refer đến một object
thuộc class clsBox, IDE Intellisense sẽ hiển thị các Properties và Subs/Functions của clsBox
như trong hình dưới đây:
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
46
Trong chương trình này, mỗi khi ta click nút Draw thì sẽ tạo ra một đối tượng Box mới, cho
tọa độ X,Y và kích thước Width, Height, rồi được vẽ ra ngay trên form. T ừ khóa Me trong
đoạn chương trình này nói đến đối tượng chứa đoạn code đó, tức là frmClass.
Để cho ch ương trình thú v ị hơn, khi user clicks nút Animate, ta s ẽ cho m ột box màu đỏ
chạy từ trái qua phải.
Khi user clicks nút Two Boxes ta sẽ vẽ hai box, hộp trong màu xanh, hộp ngoài màu đỏ, và
cho chúng chạy từ trái sang ph ải. Ở đây ta biểu diễn cho thấy mình muốn tạo ra bao nhiêu
đối tượng box từ lớp clsBox cũng được, và d ĩ nhiên mỗi box có m ột bộ các thuộc tính với
giá trị riêng của nó.
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
47
Ta có th ể lập trình để cho đối tượng báo cáo ch ương trình ch ủ của nó khi có m ột biến cố
(Event) xảy ra bên trong đối tượng đó.
Ta thử khai báo một Event tên Draw trong clsBox, và viết code để mỗi khi chương trình gọi
hàm DrawBox đối tượng sẽ phát sinh (Raise) một sự kiện Draw.
' Khai báo event Draw
' Event này có 2 tham số X, Y là số Integer
Public Event Draw(X As Integer, Y As Integer)
Public Sub DrawBox(Canvas As Object, Optional fColor As Long)
If IsMissing(fColor) Then
Canvas.Line (mX, mY)-(mX + mWidth, mY + mHeight), , B
Else
Canvas.Line (mX, mY)-(mX + mWidth, mY + mHeight), fColor, B
End If
' Phát sinh sự kiên Draw với 2 tham số mX, mY của đối tượng Box
RaiseEvent Draw(mX, mY)
End Sub
Bây giờ, trong frmClass thay vì chỉ khai báo
Dim myBox As clsBox
Ta sẽ khai báo như sau
Private WithEvents myBox As clsBox
Ngay sau đó, chữ myBox sẽ hiện ra trong danh sách các đối tượng có Event c ủa frmClass.
Sau đó ta s ẽ vi ết code để xử lý m ỗi khi đối tượng myBox phát sinh s ự ki ện Draw c ủa
myBox, tức là ta cung c ấp code cho Private Sub myBox_Draw (X As Integer, Y As
Integer). Ở đây ta chỉ hiển thị một MsgBox thông báo myBox vừa được vẽ ở đâu.
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
48
Khi chạy chương trình, mỗi lần một đối tượng box thuộc lớp clsBox gọi đến Sub DrawBox
ta sẽ thấy có thông báo như dưới đây (chứng tỏ rằng Sub myBox_Draw đã được gọi khi đối
tượng myBox được vẽ và phát sinh sự kiện Draw)
Nhớ rằng, ta khai báo một object với từ khóa WithEvents khi ta muốn xử lý các các sự kiện
của nó. Trong thí dụ trên frmClass chứa đối tượng myBox và nó nhận được các Event Draw
của myBox thông qua Sub myBox_Draw.
I.2.8. Làm việc với file
Để lưu dữ li ệu ra file, có 2 ph ương pháp: l ưu ki ểu v ăn b ản (text) và l ưu ki ểu nh ị phân
(binary). Do đặc thù c ủa các ph ần m ềm xây d ựng thường làm vi ệc với các file v ăn b ản,
trong tài liệu này chúng tôi chỉ giới thiệu các phương thức làm việc với file văn bản.
I.2.8.1. Mở file
Khi mở file text, có 3 chế độ mở file sau:
- Đọc các ký tự từ file (Input)
- Ghi các ký tự ra file (Output)
- Ghi thêm các ký tự vào cuối file đã có (Append)
Cú pháp lệnh mở file
Open For [Input | Output | Append] As [Len = buffersize]
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
49
Khi mở file ở chế độ Input, file ph ải tồn tại, nếu không, chương trình sẽ phát
sinh lỗi. Khi đó ph ải sử dụng các l ệnh b ắt lỗi (xem ph ần gỡ rối). Các ch ế độ Output và
Append sẽ tự tạo file mới nếu như file này chưa có trên ổ đĩa.
Các file sau khi m ở phải được đóng lại bằng lệnh Close, nhất là đối với các chế độ Output
và Append (nếu bạn không đóng lại thì các thông tin ghi ra file sẽ bị mất).
I.2.8.2. Đọc file
Để đọc thông tin từ file text, mở file ở chế độ Input, sau đó sử dụng các lệnh Line Input #,
Input( ), hoặc Input # để đọc thông tin từ file vào các biến trong chương trình.
Đoạn code dưới đây đọc từng dòng vào từ file, nối chúng lại thành một xâu ký tự chứa toàn
bộ nội dung của file.
Dim FileNum As Integer
Dim LinesFromFile, NextLine As String
FileNum = FreeFile
Open "" For Input As FileNum
Do Until EOF(FileNum)
Line Input #FileNum, NextLine
LinesFromFile = LinesFromFile + NextLine + Chr(13) + Chr(10)
Loop
Close FileNum
Bạn có thể sử dụng lệnh Input # đọc một loạt các biến (số, xâu ký tự...)
Input #FileNum, name, street, city, state, zip
Bạn có thể sử dụng hàm Input để đọc n ký tự liên tiếp từ file
LinesFromFile = Input(n, FileNum)
I.2.8.3. Ghi file
Để ghi giá tr ị các biến ra file, m ở file ở chế độ Output (hoặc Append), sau đó sử dụng các
lệnh Print # để in các giá trị ra file. Chú ý rằng cách lệnh này sẽ in mỗi giá trị (xâu ký tự, số)
trên 1 dòng. Như vậy, muốn in nhiều giá trị trên 1 dòng với lệnh Print # thì bạn chuyển tất
cả thành xâu ký tự, nối chúng lại với nhau rồi in xâu ký tự kết quả đó ra.
Print #FileNum, TheBox.Text
AnyString = "AnyCharacters"
AnyNumber = 23445
Lines = AnyString & " " & AnyNumber
Print #FileNum, Lines
Như đã đề cập ở trên, có th ể sử dụng lệnh Input # để đọc liên ti ếp các giá tr ị từ file text.
Tuy nhiên, chỉ có những file text được tạo bởi lệnh Write # mới đọc được bằng lệnh Input
#.
Dim AnyString As String, AnyNumber As Integer
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
50
AnyString = "AnyCharacters"
AnyNumber = 23445
Write #FileNum, AnyString, AnyNumber
Với đoạn lệnh ví dụ ở trên, file kết quả sẽ có nội dung như sau
"AnyCharacters",23445
Có nghĩa là các giá trị sẽ được ghi cách nhau bởi dấu phẩy, các giá trị xâu ký tự sẽ được đặt
trong c ặp ngo ặc kép. Các c ấu trúc file text trong các ph ần m ềm phân tích k ết cấu thông
dụng thường không theo c ấu trúc này. Vì v ậy, để làm việc với các file text này chúng ta s ẽ
sử dụng các lệnh Line Input (đọc) và Print (ghi).
I.2.8.4. Một số kỹ thuật sử dụng để đọc file text
Phần này xin trình bày các k ỹ thuật đọc các cấu trúc file text mà chúng tôi th ường sử dụng.
Phương pháp đơn giản nhất là s ử dụng các l ệnh Line Input để đọc từng dòng, sau đó sử
dụng hàm split để tách dòng đó thành mảng các chuỗi ký tự.
Trong đoạn chương trình ví d ụ sau, chúng tôi ti ến hành đọc các thông s ố tọa độ của các
Joint của hệ kết cấu trong file s2k của SAP2000 v8.
- Chương trình sẽ lần lượt đọc từng dòng của file s2k cho đến khi gặp dòng [TABLE:
"JOINT COORDINATES"]
- Sau đó chương trình ti ếp tục đọc từng dòng cho đến khi g ặp dòng tr ống, với mỗi
dòng vì d ữ liệu được ghi theo t ừng cặp = nên chúng tôi s ử
dụng hàm DocFile(s As String) để đọc từng cặp này.
- Hàm DocFile phân tích xâu ký t ự s thành nhi ều cặp giá tr ị (sử dụng hàm split), v ới
mỗi cặp giá tr ị lại sử dụng hàm split tách thành và , sau đó
cặp dữ liệu này được đưa vào một Collection để xử lý.
Option Explicit
' Cấu trúc xâu s: " a=b c=d e=f... "
' Trả về Collection DocFile với
' DocFile(a) = b
' DocFile(c) = d
' DocFile(e) = f
Private Function DocFile(s As String) As Collection
Dim i As Integer
Dim vals As Variant, v2 As Variant
Set DocFile = New Collection ' Khởi tạo Collection
vals = Split(s, " ") ' Tách xâu s thành mảng
For i = LBound(vals) To UBound(vals)
If vals(i) "" Then ' Chỉ xử lý với phần tử không rỗng
v2 = Split(vals(i), "=") ' Tách cặp thành 2 phần
DocFile.Add v2(1), v2(0) ' Đưa giá trị nhận được vào Collection
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
51
End If
Next
End Function
' Ví dụ về dữ liệu
'....
'TABLE: "JOINT COORDINATES"
' Joint=1 CoordSys=GLOBAL CoordType=Cartesian XorR=0 Y=0 Z=0
SpecialJt=No GlobalX=0 GlobalY=0 GlobalZ=0
' Joint=2 CoordSys=GLOBAL CoordType=Cartesian XorR=10 Y=0 Z=0
SpecialJt=No GlobalX=10 GlobalY=0 GlobalZ=0
'
'TABLE: "CONNECTIVITY - FRAME"
' Frame=1 JointI=1 JointJ=2 IsCurved=No Length=10 CentroidX=5
CentroidY=0 CentroidZ=0
'....
Private Sub Command1_Click()
Dim FileNum As Integer
Dim s As String, val As Collection
Dim x As Double, y As Double, z As Double
FileNum = FreeFile
Open "c:\1.s2k" For Input As #FileNum
Do While Not EOF(FileNum)
Line Input #FileNum, s
If s = "TABLE: ""JOINT COORDINATES""" Then
' Dòng nhận biết bảng tọa độ nút
Do While Not EOF(FileNum)
Line Input #FileNum, s ' Đọc dòng kế tiếp
If Trim(s) = "" Then Exit Do ' Dừng nếu gặp dòng trống
Set val = DocFile(s) ' Đọc dữ liệu vào Collection
MsgBox val("GlobalX") & " " & val("GlobalY") & " " & val("GlobalZ")
' Hiển thị các dữ liệu đọc được
Loop
End If
Loop
Close FileNum
End Sub
I.3. Kỹ năng gỡ rối chương trình (debug)
Gỡ rối chương trình (debug) là k ỹ năng cơ bản nhất đối với mỗi lập trình viên. Tuy nhiên,
qua kinh nghiệm dạy và hướng dẫn sinh viên Tin học xây dựng làm đồ án tốt nghiệp, chúng
tôi nhận thấy kỹ năng này của sinh viên là rất yếu (nếu không nói là gần như không có).
Chương trình lập ra hoạt động không theo ý muốn của người lập trình (không hoạt động, có
lỗi khi ch ạy, hoạt động nhưng không cho k ết quả đúng) là điều hết sức bình thường (có l ẽ
nên coi đó là điều hiển nhiên). Khi ch ương trình ho ạt động không theo d ự kiến, cần phải
khoanh vùng xem l ỗi có th ể phát sinh t ừ phần nào c ủa chương trình. Sau đó, sử dụng các
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
52
công cụ gỡ rối để tìm hiểu hoạt động của chương trình tại vị trí đó để xác định cụ thể xem
lỗi bắt nguồn từ đâu.
Trong phần này xin gi ới thiệu những kiến thức và thao tác c ơ bản nhất để gỡ rối chương
trình trong VB.
I.3.1. Sử dụng MsgBox
Một trong những công cụ đơn giản nhất để gỡ rối chương trình. MsgBox được sử dụng để
hiển thị các giá tr ị trong khi chương trình đang hoạt động. Sau đây chúng ta cùng xem m ột
ví dụ
Private Sub Command1_Click()
Dim a As Integer
a = 10
a = a * a
a = a * a
a = a * a
MsgBox a
End Sub
Đoạn chương trình trên xem ra vô h ại, nhưng nếu bạn chạy nó sẽ báo lỗi. Nguyên nhân t ại
sao? Để biết được điều này chúng ta sửa lại chương trình như sau
Private Sub Command1_Click()
Dim a As Integer
a = 10
a = a * a
MsgBox a
a = a * a
MsgBox a
a = a * a
MsgBox a
End Sub
Khi chạy đoạn chương trình này, chúng ta sẽ thấy hộp thoại 100 hiện ra (đây là giá trị của a
= 10 * 10). Click OK, h ộp thoại 10000 hi ện ra ti ếp theo ( đây là giá tr ị của a = 100*100).
Click OK tiếp, chương trình báo l ỗi, có ngh ĩa là lệnh 10000*10000 không được thực hiện.
Đến đây chúng ta có th ể biết được lỗi này xuất hiện do giá tr ị 10000*10000 vượt quá khả
năng lưu trữ của số nguyên Integer. Để chương trình hoạt động đúng dự kiến, ta chỉ cần sửa
Integer thành Long.
I.3.2. Sử dụng cửa sổ Watch
MsgBox tuy đơn giản, dễ dùng và t ương đối hiệu quả, nhưng không ph ải lúc nào c ũng có
thể sử dụng. Xét ví dụ sau
Private Sub Command1_Click()
Dim a As Integer
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
53
Dim i As Integer
a = 20000
For i = 1 To 20000
a = a + 1
Next
End Sub
Đoạn chương trình này c ũng phát sinh l ỗi, tuy nhiên n ếu bạn sử dụng MsgBox để hiển thị
kết quả trong từng trường hợp thì sẽ là khủng khiếp khi bạn phải click OK cả vạn lần chỉ để
tìm một lỗi.
Trong trường hợp này, khi chương trình báo lỗi, bạn click vào nút Debug, ch ương trình sẽ
quay trở lại IDE của VB với một giao diện như sau
Trong đó, dòng "a=a+1" được hiển th ị với màu vàng và 1 m ũi tên bên trái, đây chính là
dòng và thời điểm mà chương trình gặp lỗi. Vậy trong thời điểm này thì giá tr ị của a là bao
nhiêu? Tại sao lệnh a=a+1 lại lỗi?
Đề trả lời các câu h ỏi trên, chúng ta s ử dụng cửa sổ Watch để xem giá tr ị của biến a. Cách
sử dụng như sau: bôi đen biến a, phải chuột tại vị trí đã bôi đen, chọn Add watch từ popup
menu, hộp tho ại Add watch (hình trái) hi ện lên, click OK để theo dõi giá tr ị của bi ến a
(hình phải). Cửa sổ Watches cho phép chúng ta bi ết được giá trị và kiểu của biến. Trong
trường hợp này ta thấy a có giá trị 32767 (đây là giá trị lớn nhất của số Integer), có nghĩa là
lệnh a=a+1 s ẽ phát sinh l ỗi tràn do giá tr ị vượt quá khả năng lưu trữ của số Integer. Cách
sửa lỗi cũng giống ví dụ trước, tức là sử dụng kiểu biến Long có phạm vi giá trị lớn hơn.
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
54
Chú ý: Với các giá trị biến đơn (số, xâu ký tự...) thì có thể xem giá trị của biến một cách rất
dễ dàng b ằng cách để con tr ỏ chuột tại v ị trí tên bi ến, sau kho ảng vài giây s ẽ có m ột
tooltip hiện lên cho bi ết giá trị của biến đó. Tuy nhiên cách này không th ể sử dụng với các
biến kiểu phức (mảng, kiểu người dùng định nghĩa, object), khi đó sử dụng cửa sổ Watch là
phương pháp hữu hiệu nhất.
Ngoài cửa sổ Watch, một công cụ rất mạnh khác là Immediate Window (phím tắt Ctrl+G)
cho phép bạn xem giá tr ị các biến, biểu thức, thực hiện các lệnh VB ngay lập tức trong khi
đang gỡ rối chương trình. (Xem phần I.1.2.8)
I.3.3. Đặt điểm dừng & chạy từng dòng lệnh
Ở phần trên, chúng ta đã dừng chương trình lại để xem giá tr ị các bi ến, tuy nhiên vi ệc
dừng chương trình là bị động (do có lỗi nên phải dừng lại). Trên thực tế, không phải lúc nào
chương trình cũng phát sinh lỗi. Ví dụ như khi kết quả sai do thuật toán lỗi, khi đó phải chủ
động dừng chương trình để quan sát giá tr ị các biến nhằm nắm được nguyên nhân của sai
sót. Xét ví dụ sau:
I.4. Sử dụng ActiveX trong Visual Basic
ActiveX là công ngh ệ cho phép người lập trình Windows có th ể sử dụng các thành ph ần
(component) do ng ười khác phát tri ển để áp d ụng trong ch ương trình c ủa mình. Công
nghệ ActiveX cho phép ng ười phát triển tận dụng được lao động của người khác, không
phải viết lại những chức năng thông dụng, tiết kiệm được rất nhiều sức lao động cũng như
làm tăng đáng kể sức mạnh của các chương trình (vì được phát triển chuyên môn hóa).
Tuy nhiên, mặt trái của việc sử dụng ActiveX là sự phức tạp khi cài đặt (rất hay xảy ra xung
đột version giữa phiên bản được cài đặt mới và phiên bản đã có sẵn trong máy tính). Ngoài
ra, tất cả các ActiveX của sinh viên sử dụng trong đồ án tốt nghiệp đều là những bản crack
(có nghĩa là sinh viên đang vi phạm pháp luật). Chúng tôi đưa ra hướng dẫn sử dụng các
ActiveX như là giải pháp tình th ế, trong tương lai sẽ tìm kiếm các component hợp pháp từ
nguồn phần mềm miễn phí hoặc phần mềm nguồn mở hay các component do sinh viên
trong Khoa tự phát triển.
I.4.1. Các ActiveX thông dụng
I.4.1.1. CommonDialog
Các hộp thoại thông d ụng trên Windows (H ộp thoại mở file, h ộp thoại ghi file, h ộp thoại
chọn font, hộp thoại in ấy, hộp thoại chọn màu...)
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
55
Để đưa ActiveX này vào trong project, click ph ải chu ột trên h ộp ToolBox, ch ọn
Components từ menu Popup. Trên h ộp thoại Components, đánh dấu vào m ục "Microsoft
Common Dialog Controls".
Sau đó trên ToolBox, ch ọn đối tượng CommonDialog để đưa vào form, v ới đối tượng
này bạn có thể sử dụng để hiển thị các hộp thoại thông dụng của Windows.
' Visual Basic 6.0
' Uses a CommonDialog control.
CommonDialog1.InitDir = "C:\Program Files"
CommonDialog1.ShowOpen
MsgBox CommonDialog1.FileName
Tên thuộc tính Kiểu Mô tả
DialogTitle String Tiêu đề của hộp thoại
FileName String Tên file được chọn (open hoặc save)
FileTitle String Tên file được chọn (không kèm theo đường dẫn)
InitDir String Thư mục ban đầu khi bật hộp thoại lên
MaxFileSize String Chiều dài lớn nhất cho phép lưu vào tên file (FileName)
Tên thao tác Mô tả
ShowColor Hiển th ị hộp thoại chọn màu (theo giá tr ị RGB) ho ặc chọn màu theo v ị trí trên b ảng
màu
ShowFont Hiển thị hộp thoại lựa chọn font chữ
ShowHelp Hiển thị hộp thoại trợ giúp
ShowOpen Hiển thị hộp thoại để lựa chọn file (mở file)
ShowPrinter Hiển thị hộp thoại lựa chọn máy in và các thông số của máy in
ShowSave Hiển thị hộp thoại Save as cho phép nhập vào tên file cần ghi
I.4.1.2. VSFlexGrid
Các ứng dụng trong ngành Tin học xây dựng thường liên quan rất nhiều đến bảng biểu. VB
có cung cấp Grid control cho phép làm vi ệc với bảng biểu. Tuy nhiên, Grid control của VB
không có đầy đủ các tính năng cần thiết cho các ứng dụng Tin học Xây dựng, các bạn có thể
sử dụng VSFlexGrid ( để thực hiện các chức năng này.
Với VSFlexGrid, có th ể thực hiện được rất nhiều chức năng: Đọc và l ưu dữ liệu trên file
Text, Excel. Lưu trữ được một số lượng lớn các ô dữ liệu, cho phép cập nhật (edit)...
Sau khi đã cài đặt VSFlexGrid, b ạn có th ể s ử d ụng b ằng cách đưa thêm component
"ComponentOne VSFlexGrid 8.0 (Light) " vào trong ToolBox c ủa VB (các b ước chi ti ết
xin xem trong ph ần CommonDialog). Chú ý r ằng với phiên bản mới nhất của VSFlexGrid,
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
56
bạn có nhi ều lựa chọn: Nếu ứng dụng kết nối CSDL, có th ể chọn b ản OLEDB ho ặc bản
DAO/RDO, nếu không thì chỉ cần sử dụng bản Light là đủ.
Sau đó, đưa VSFlexGrid control từ ToolBox vào form để sử dụng. Dưới đây là ví dụ với
grid control có tên là "VSFlexGrid1", ch ương trình t ạo ra b ảng có 3 dòng và 3 c ột (kể cả
dòng và cột tiêu đề). Việc gán thông tin vào grid ch ỉ đơn giản là gán giá tr ị vào thuộc tính
TextMatrix của control.
Private Sub Form_Load()
With VSFlexGrid1
.Rows = 3
.Cols = 3
.TextMatrix(0, 0) = "So TT"
.TextMatrix(0, 1) = "Ho dem"
.TextMatrix(0, 2) = "Ten"
.TextMatrix(1, 0) = 1
.TextMatrix(1, 1) = "Nguyen Van"
.TextMatrix(1, 2) = "A"
.TextMatrix(2, 0) = 2
.TextMatrix(2, 1) = "Tran Thi"
.TextMatrix(2, 2) = "B"
.Editable = True
End With
End Sub
Khi số lượng các ô l ớn, việc gán dữ liệu vào từng ô có th ể gây chậm chương trình, bạn có
thể sử dụng phương pháp khác là kết nối grid với một mảng 2 chiều các giá trị bằng cách sử
dụng thao tác BindToArray:
VSFlexGrid.BindToArray [ VariantArray As Variant ], [ RowDim As Long ], [ ColDim
As Long ], [ PageDim As Long ], [ CurrentPage As Long ]
Với thao tác BindToArray, dữ liệu sẽ được đưa rất nhanh từ mảng vào grid (nhanh hơn
rất nhiều lần so với việc bạn gán từng giá tr ị cho từng ô trong grid). Ngoài ra, n ếu dữ liệu
được bind vào (từ mảng [A]), sau đó thay đổi các thông số trong mảng [A], có th ể sử dụng
thao tác Refresh để cập nhật (xem ví dụ dưới đây).
Bộ môn Tin học Xây dựng – ĐHXD Tài liệu hướng dẫn thực tập tốt nghiệp
57
Private Sub Command1_Click()
Dim Dong(2, 2)
With VSFlexGrid1
.Rows = 3
.Cols = 3
Dong(0, 0) = "STT": Dong(0, 1) = "Ho dem": Dong(0, 2) = "Ten"
Các file đính kèm theo tài liệu này:
- Thuc_tap_Tin_hoc_xay_dung.pdf