Hôm nay mình wa phần tiếp theo về cái vụ này nhé.
:sifone:
CÁC SỰ KIỆN VÀ THỦ TỤC SỰ KIỆN THÔNG DỤNG ĐỐI VỚI CÁC CONTROL TRÊN FORM
Với một số sự kiện cùng tên với form như BeforeUpdate, AfterUpdate thì cũng tương tự, tuy nhiên có một số sự kiện đặc trưng cho các control mà khi các bạn điều khiển nó, các bạn sẽ làm được nhiều điều.
1. Các sự kiện phím:
Thông thường thì mỗi control sẽ tiếp nhận 3 trạng thái phím khi nó được focus. KeyDown, KeyUp và KeyPress.
KeyDown xảy ra khi người dùng nhấn một phím trong khi control đang focus. Nó cũng xảy ra khi bạn dùng hành động SendKeys (trong macro) hay lệnh SendKeys trong code.
KeyPress cũng vậy, nhưng có một chút khác biệt: nó xảy ra khi nhấn và nhả phím trong khi control đang focus. Và trong khi với KeyDown, bạn có thể kiểm tra được là nếu người dùng nhấn tổ hợp phím thì phím kết hợp sẽ là gì: CTRL, ALT, SHIFT một cách riêng biệt. Trong khi KeyPress thì không.
KeyUp là sự kiện xảy ra khi người dùng nhả phím ra. Nó giống như KeyDown, nghĩa là có thể kiểm tra được là nếu người dùng nhấn tổ hợp phím thì phím kết hợp sẽ là gì: CTRL, ALT, SHIFT một cách riêng biệt.
Tùy theo tình hình cụ thể, các bạn có thể điều khiển sự kiện phím thích hợp.
Với sự kiện KeyDown, bạn có thuộc tính sự kiện OnKeyDown.
Thủ tục sự kiện tương ứng là control_KeyDown. Thủ tục này có 2 tham số:
KeyCode: tiếp nhận mã phím mà người sử dụng nhấn (không tính các phím kết hợp). Bạn có thể dùng các hằng định sẵn để xác định phím mà người dùng nhấn (vbKeyA - phím A, vbkeyReturn - phím Enter, ...). Các bạn chịu khó mở cửa sổ Object Browser (lúc đang ở cửa sổ VB Editor) xem lib VBA, mục KeyCode constants để biết nhiều hơn.
Nếu bạn ngăn không tiếp nhận sự kiện nhấn phím, bạn gán tham số này bằng 0.
Shift: xác định xem phím kết hợp nào được nhấn cùng.
Nhấn SHIFT: acShiftMask
Nhấn CTRL: acCtrlMask
Nhấn ALT: acAltMask
Một ví dụ để điều khiển sự kiện KeyDown:
VD: Kiểm tra xem, có nhấn phím CTRL xuống không, nếu không thì thoát thủ tục. Nếu có thì coi có nhấn phím F3 không. Nếu có thì cho hiển thị một cái form gì đó.
Private Sub mahocsinh_KeyCode(KeyCode As Integer, Shift As Integer)
If (Shift And acCtrlMask) > 0 Then
If KeyCode = vbKeyF3 Then
DoCmd.OpenForm "frmLylichHocsinh", acNormal
End If
End If
End Sub
VD2: Còn đây là ví dụ để bắt sự kiện KeyPress nghen. Thông thường thì nếu bạn dùng Format cho text box với ký tự > thì nội dung trong text box hiển thị dạng chữ hoa hết sau khi bạn rời focus khỏi text box, nhưng thực tế thì nội dung trong textbox vẫnlà chữ thường. bây giờ bạn muốn đổi sang Hoa thật sự thì bạn sẽ nhờ đến KeyPress. Chú ý: bạn cẩn thận khi dùng font Unicode.
Private Sub hoten_KeyPress(KeyAscii As Integer)
Dim strCharacter As String
strCharacter = Chr(KeyAscii)
KeyAscii = Asc(UCase(strCharacter))
End Sub
:sifone:
CÁC SỰ KIỆN VÀ THỦ TỤC SỰ KIỆN THÔNG DỤNG ĐỐI VỚI CÁC CONTROL TRÊN FORM
Với một số sự kiện cùng tên với form như BeforeUpdate, AfterUpdate thì cũng tương tự, tuy nhiên có một số sự kiện đặc trưng cho các control mà khi các bạn điều khiển nó, các bạn sẽ làm được nhiều điều.
1. Các sự kiện phím:
Thông thường thì mỗi control sẽ tiếp nhận 3 trạng thái phím khi nó được focus. KeyDown, KeyUp và KeyPress.
KeyDown xảy ra khi người dùng nhấn một phím trong khi control đang focus. Nó cũng xảy ra khi bạn dùng hành động SendKeys (trong macro) hay lệnh SendKeys trong code.
KeyPress cũng vậy, nhưng có một chút khác biệt: nó xảy ra khi nhấn và nhả phím trong khi control đang focus. Và trong khi với KeyDown, bạn có thể kiểm tra được là nếu người dùng nhấn tổ hợp phím thì phím kết hợp sẽ là gì: CTRL, ALT, SHIFT một cách riêng biệt. Trong khi KeyPress thì không.
KeyUp là sự kiện xảy ra khi người dùng nhả phím ra. Nó giống như KeyDown, nghĩa là có thể kiểm tra được là nếu người dùng nhấn tổ hợp phím thì phím kết hợp sẽ là gì: CTRL, ALT, SHIFT một cách riêng biệt.
Tùy theo tình hình cụ thể, các bạn có thể điều khiển sự kiện phím thích hợp.
Với sự kiện KeyDown, bạn có thuộc tính sự kiện OnKeyDown.
Thủ tục sự kiện tương ứng là control_KeyDown. Thủ tục này có 2 tham số:
KeyCode: tiếp nhận mã phím mà người sử dụng nhấn (không tính các phím kết hợp). Bạn có thể dùng các hằng định sẵn để xác định phím mà người dùng nhấn (vbKeyA - phím A, vbkeyReturn - phím Enter, ...). Các bạn chịu khó mở cửa sổ Object Browser (lúc đang ở cửa sổ VB Editor) xem lib VBA, mục KeyCode constants để biết nhiều hơn.
Nếu bạn ngăn không tiếp nhận sự kiện nhấn phím, bạn gán tham số này bằng 0.
Shift: xác định xem phím kết hợp nào được nhấn cùng.
Nhấn SHIFT: acShiftMask
Nhấn CTRL: acCtrlMask
Nhấn ALT: acAltMask
Một ví dụ để điều khiển sự kiện KeyDown:
VD: Kiểm tra xem, có nhấn phím CTRL xuống không, nếu không thì thoát thủ tục. Nếu có thì coi có nhấn phím F3 không. Nếu có thì cho hiển thị một cái form gì đó.
Private Sub mahocsinh_KeyCode(KeyCode As Integer, Shift As Integer)
If (Shift And acCtrlMask) > 0 Then
If KeyCode = vbKeyF3 Then
DoCmd.OpenForm "frmLylichHocsinh", acNormal
End If
End If
End Sub
VD2: Còn đây là ví dụ để bắt sự kiện KeyPress nghen. Thông thường thì nếu bạn dùng Format cho text box với ký tự > thì nội dung trong text box hiển thị dạng chữ hoa hết sau khi bạn rời focus khỏi text box, nhưng thực tế thì nội dung trong textbox vẫnlà chữ thường. bây giờ bạn muốn đổi sang Hoa thật sự thì bạn sẽ nhờ đến KeyPress. Chú ý: bạn cẩn thận khi dùng font Unicode.
Private Sub hoten_KeyPress(KeyAscii As Integer)
Dim strCharacter As String
strCharacter = Chr(KeyAscii)
KeyAscii = Asc(UCase(strCharacter))
End Sub