Luận văn Nghiên cứu hệ thống biểu quyết điện tử số

Tài liệu Luận văn Nghiên cứu hệ thống biểu quyết điện tử số: 1 ĐẠI HỌC QUỐC GIA HÀ NỘI TRƯỜNG ĐẠI HỌC CÔNG NGHỆ NGUYỄN HỒNG PHÚC NGHIÊN CỨU HỆ THỐNG BIỂU QUYẾT ĐIỆN TỬ SỐ Nghành: Công nghệ Điện tử- Viễn Thông Chuyên nghành: Kỹ thuật Điện tử Mã số: 60.52.70 LUẬN VĂN THẠC SĨ NGƯỜI HƯỚNG DẪN KHOA HỌC PGS.TS Trần Quang Vinh Hà Nội- 2009 2 LỜI CÁM ƠN Em xin cám ơn toàn thể các thầy, cô giáo khoa Công nghệ Điện tử - Viễn thông Trường Đại học Công Nghệ đã nhiệt tình giảng dạy, hướng dẫn em hoàn thành khóa học. Đặc biệt là lòng kính trọng và sự biết ơn sâu sắc của em tới thầy giáo PGS.TS.Trần Quang Vinh, người đã tận tình hướng dẫn em trong suốt quá trình hoàn thành luận văn này. Tôi xin cám ơn đến Lãnh đạo Văn phòng Quốc hội, Cục Quản trị, Vụ Tổ chức - Cán bộ đã tạo điều kiện thuận lợi để tôi được đi học; cám ơn các anh, chị công tác tại Viện Điện tử - Viễn thông Bộ Quốc phòng đã giúp đỡ, cung cấp các tài liệu cần thiết, giúp tôi hoàn thành bản luận văn này. Nhân đây,Tôi xin cảm ơn gia đình và bạn bè là ...

pdf67 trang | Chia sẻ: haohao | Lượt xem: 1092 | Lượt tải: 0download
Bạn đang xem trước 20 trang mẫu tài liệu Luận văn Nghiên cứu hệ thống biểu quyết điện tử số, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
1 ĐẠI HỌC QUỐC GIA HÀ NỘI TRƯỜNG ĐẠI HỌC CÔNG NGHỆ NGUYỄN HỒNG PHÚC NGHIÊN CỨU HỆ THỐNG BIỂU QUYẾT ĐIỆN TỬ SỐ Nghành: Công nghệ Điện tử- Viễn Thông Chuyên nghành: Kỹ thuật Điện tử Mã số: 60.52.70 LUẬN VĂN THẠC SĨ NGƯỜI HƯỚNG DẪN KHOA HỌC PGS.TS Trần Quang Vinh Hà Nội- 2009 2 LỜI CÁM ƠN Em xin cám ơn toàn thể các thầy, cô giáo khoa Công nghệ Điện tử - Viễn thông Trường Đại học Công Nghệ đã nhiệt tình giảng dạy, hướng dẫn em hoàn thành khóa học. Đặc biệt là lòng kính trọng và sự biết ơn sâu sắc của em tới thầy giáo PGS.TS.Trần Quang Vinh, người đã tận tình hướng dẫn em trong suốt quá trình hoàn thành luận văn này. Tôi xin cám ơn đến Lãnh đạo Văn phòng Quốc hội, Cục Quản trị, Vụ Tổ chức - Cán bộ đã tạo điều kiện thuận lợi để tôi được đi học; cám ơn các anh, chị công tác tại Viện Điện tử - Viễn thông Bộ Quốc phòng đã giúp đỡ, cung cấp các tài liệu cần thiết, giúp tôi hoàn thành bản luận văn này. Nhân đây,Tôi xin cảm ơn gia đình và bạn bè là nguồn lực tinh thần đã động viên khích lệ tôi vượt qua mọi khó khăn để hoàn thành luận văn. Hà Nội, ngày 24 tháng 12 năm 2009 Nguyễn Hồng Phúc 3 LỜI CAM ĐOAN Tôi xin cam đoan đề tài luận văn của tôi không trùng lặp với các đề tài khóa trước đã thực hiện và nội dung luận văn không sao chép của bất kỳ luận văn nào khác. Nếu có bất kỳ sự gian lận nào, tôi xin hoàn toàn chịu trách nhiệm. Người cam đoan Nguyễn Hồng Phúc 4 MỤC LỤC LỜI CÁM ƠN .................................................................................................... 2 LỜI CAM ĐOAN .............................................................................................. 3 MỤC LỤC ......................................................................................................... 4 DANH MỤC CÁC KÝ HIỆU, CÁC TỪ VIẾT TẮT ......................................... 6 DANH MỤC CÁC BẢNG ................................................................................. 7 MỞ ĐẦU ......................................................................................................... 10 CHƯƠNG 1:TỔNG QUAN VỀ HỆ THỐNG BIỂU QUYẾT ĐIỆN TỬSỐ (DCN) .............................................................................................................. 11 1.2. Giới thiệu tổng quan hệ thống biểu quyết điện tử số DCN......................... 12 1.2.1 Thiết bị phân tập ..................................................................................... 13 1.2.2 Thiết bị điều khiển trung tâm CCU .......................................................... 13 1.3. Định tuyến hệ thống âm thanh trong hệ DCN ............................................ 14 1.4. Nguyên lý hoạt động của hệ thống biểu quyết số ....................................... 15 1.4.1 Sơ đồ nguyên lý hoạt động của hệ thống biểu quyết điện tử số ................ 15 1.4.2 Cấu trúc Bộ điều khiển trung tâm CCU ................................................... 15 1.4.3 Nguyên lý hoạt động của hệ thống biểu quyết điện tử số DCN ................ 16 1.5. Các phần mềm ứng dụng điều khiển hệ thống biểu quyết điện tử số DCN: 17 CHƯƠNG 2: CẤU HÌNH HỆ THỐNG BIỂU QUYẾT ĐIỆN TỬ SỐ DCN .. 18 2.1 Cấu hình hệ thống biểu quyết số DCN....................................................... 18 2.1.2 Hệ thống biểu quyết điện tử số DCN Multi- CCU.................................. 18 2.2 Thông số các cổng của CCU khi kết nối với PC và kết nối với camera..... 20 2.3 Thông số kỹ thuật cổng nối tiếp RS 232 ..................................................... 21 2.3.1 Truyền thông giữa hai nút ........................................................................ 25 2.3.2 Truy xuất trực tiếp thông qua cổng COM ................................................ 26 CHƯƠNG 3:GIAO DIỆN ĐIỂU KHIỂN TỪ XA ĐẾN HỆ THỐNG DCN ..... 27 3.1 Mô hình hệ thống điều khiển từ xa ............................................................. 27 3.2 Các thông số điều khiển từ xa ..................................................................... 27 3.2.1 Kiểu thông báo định dạng........................................................................ 27 3.2.2 Kiểu định dạng thông báo cơ bản ............................................................ 28 3.2.3 Định dạng yêu cầu điều khiển từ xa ........................................................ 28 3.2.4 Định dạng đáp ứng điều khiển từ xa ........................................................ 29 3.2.5 Định dạng thông báo cập nhật MDSC_NOTIFY .................................... 29 3.2.6 Định dạng thông số truyền thông ............................................................ 30 3.3. Thủ tục truyền thông của bộ điều khiển trung tâm ..................................... 30 3.3.1 Đặc tính của giao thức truyền thông Full ................................................ 31 3.3.2 Tham số nhận biết thông tin .................................................................... 33 3.3.3 Giao thức truyền thông ............................................................................ 34 3.3.3.1 Gói dữ liệu không trả lời ...................................................................... 35 3.3.3.2 Giá trị thời gian của kết nối đường truyền............................................. 36 CHƯƠNG 4: XÂY DỰNG PHẦN MỀM BIỂU QUYẾT ................................ 37 4.1 Chức năng đăng ký đại biểu ....................................................................... 37 4.1.1 Đăng ký tham dự...................................................................................... 37 5 4.1.2 Điều khiển truy cập hệ thống.................................................................... 37 4.1.4 Kết hợp giữa đăng ký tham dự với truy cập hệ thống............................... 38 4.1.5 Thông số chức năng................................................................................. 38 4.2 Điều khiển microphone trong hệ thống biểu quyết điện tử số ..................... 38 4.2.1 Các bước đăng ký phát biểu..................................................................... 38 4.2.2 Chương trình kiểm soát danh sách đại biểu ............................................. 39 4.3 Biểu quyết điện tử ...................................................................................... 41 4.3.1 Các kiểu loại biểu quyết điện tử số .......................................................... 41 4.3.2 Các bước thực hiện biểu quyết điện tử số ................................................ 41 4.3.3 Xây dựng chương trình hiển thị kết quả biểu quyết ................................. 43 4.4 Kết quả ghép nối giữa máy tính với bộ điều khiển trung tâm...................... 51 KẾT LUẬN...................................................................................................... 55 TÀI LIỆU THAM KHẢO ................................................................................ 56 PHỤ LỤC ........................................................................................................ 57 6 DANH MỤC CÁC KÝ HIỆU, CÁC TỪ VIẾT TẮT TỪ VIẾT TẮT NỘI DUNG Ý NGHĨA ACN Audio Communication Network Mạng truyền âm thanh AT Attendance Registration Đăng ký điểm danh CCU Central Control Unit. Bộ điều khiển trung tâm DCN Digital Congress Network Mạng hội nghị số EIA Electronics Industry Associations Hiệp hội điện tử công nghiệp Mỹ LCD Liquid Crystal Display Màn tinh thể lỏng PA Public Address Hệ thống công cộng PC Personal Computer Máy vi tính PRAEDIC Profession Audio Encoding Decoding Intergrated Circuit Vi mạch mã hóa và giải mã tín hiệu tiếng chuyên dụng remote controller Device (e.g. PC) connected to the CCU Bộ điều khiển từ xa RFS Remote Function Services Gói dịch vụ chức năng điều khiển từ từ xa SC System Configuration Cấu hình hệ thống SI System Installation Cài đặt hệ thống UnitId Unit identification, also called unit- number. Thiết bị được khai báo trong hệ thống DCN. VT Voting application Ứng dụng biểu quyết 7 DANH MỤC CÁC BẢNG Tên bảng Nội dung Bảng 1.1 Thông số kỹ thuật của chuẩn RS232 Bảng 1.2 Chức năng cổng nối tiếp Bảng 1.3 Các ngắt cổng COM Bảng 1.4 Thông số kết nối đường truyền Bảng 1.5 Sự kiện comevent Bảng 1.6 Bảng các sự kiện Bảng 1.7 Bảng thiết lập giao thức bắt tay 8 DANH MỤC CÁC HÌNH VẼ Hình Tên hình 1.1 Sơ đồ tổng quan hệ thống biểu quyết số 1.2 Sơ đồ định tuyến âm thanh trong hệ thống biểu quyết số DCN 1.3 Sơ đồ nguyên lý hệ thống biểu quyết điện tử số DCN 1.4 Hình ảnh bên trong của bộ điều khiển trung tâm CCU 1.5 Hình ảnh bên ngoại của bộ điều khiển trung tâm CCU 2.1 Kết nối hệ thống DCN độc lập 2.2 Kết nối hệ thống biểu quyết điện tử số Multi CCU 2.3 Tín hiệu truyền của ký tự ‘A’ 2.4 Sơ đồ chân cổng nối tiếp 2.5 Kết nối đơn giản trong truyền thông nối tiếp 2.6 Kết nối trong truyền thông nối tiếp dùng tín hiệu bắt tay 3.1 Sơ đồ ghép nối với bộ điều khiển từ xa 3.2 Sơ đồ trạng thái truyền trong thủ tục truyền “ FULL” 4.1 Giao diện chính phần mềm biểu quyết 4.2 Giao diện Danh sách đăng ký phát biểu 4.3 Giao diện hiển thị kết quả biểu quyết 4.4 Cơ sở dữ liệu đại biểu 4.5 Cơ sở dữ liệu các tỉnh, thành phố 4.6 Toàn cảnh phiên họp Quốc hội 4.7 Hệ thống biểu quyết tại Hội trường Bộ Quốc phòng 4.8 Giao diện điều khiển Mic và biểu quyết 9 4.9 Tra cứu thông tin đại biểu 4.10 Hiển thị danh sách đăng ký phát biểu 4.11 Kết quả bắt đầu biểu quyết 4.12 Kết quả biểu quyết khi hết thời gian biểu quyết 10 MỞ ĐẦU Ngày nay, lĩnh vực Công nghệ thông tin và truyền thông (ICT) đang được phát triển mạnh mẽ với những công nghệ hiện đại mới được ra đời. Nó đã xâm nhập vào mọi lĩnh vực của đời sống xã hội. Việc xã hội hoá thông tin trong đó phát triển từ phần cứng, phần mềm, hệ thống mạng viễn thông cho tới các hệ thống dành cho xử lý thông tin, hệ thống truyền thông, các hệ thống điều khiển từ xa, v.v…đã góp phần nâng cao chất lượng, độ tin cậy, hiệu quả công việc tiết kiệm về mặt thời gian, không gian, địa điểm với khoảng cách xa có thể kết nối điều khiển từ xa. Hệ thống biểu quyết điện tử số DCN sử dụng các công nghệ kỹ thuật số hiện đại cho việc điều khiển các hội nghị với hàng nghìn người. Hệ thống này đạt được hiệu quả ưu việt từ điều khiển âm thanh, đăng ký đại biểu, phân quyền người truy cập, truyền đa ngôn ngữ, biểu quyết điện tử, ghép nối điều khiển từ xa đều đã được tích hợp vào hệ thống. Với phương thức biểu quyết truyền thống bằng hình thức giơ tay, bỏ phiếu kín thì mất nhiều công sức và thời gian kiểm phiếu mất thời gian, dễ sai sót. Biểu quyết điện tử số cho kết quả biểu quyết nhanh chóng, độ tin cậy cao và có khả năng lưu trữ trạng thái biểu quyết. Đề tài Luận văn “Nghiên cứu Hệ thống biểu quyết điện tử số” có nội dung nghiên cứu một hệ thống với các tính năng nổi trội, độ tin cậy về kỹ thuật, các thông số truyền dẫn, ghép nối điều khiển từ xa với trung tâm điều khiển. Qua đó, ta có thể phát triển nhiều ứng dụng nhằm khai thác hệ thống tốt nhất như điều khiển hội nghị từ xa, biểu quyết điện tử từ xa. Luận văn gồm 4 chương. Chương 1: Tổng quan hệ thống biểu quyết điện tử số DCN. Chương 2: Cấu hình hệ thống biểu quyết số DCN và Giao tiếp cổng nối tiếp RS232. Chương 3: Nghiên cứu các thủ tục truyền thông của hệ thống biểu quyết điện tử số DCN. Chương 4: Xây dựng phần mềm biểu quyết. 11 CHƯƠNG 1 TỔNG QUAN VỀ HỆ THỐNG BIỂU QUYẾT ĐIỆN TỬSỐ (DCN) 1.1. Sơ đồ tổng quan hệ thống biểu quyết điện tử số DCN Hình 1.1: Sơ đồ tổng quan hệ thống biểu quyết số. Hệ thống biểu quyết điện tử số sử dụng công nghệ kỹ thuật điện tử viễn thông mới nhất hiện nay. Hệ thống biểu quyết điện tử DCN bao gồm như hình 1.1: 1. Trung tâm điều khiển. Bộ vi xử lý trung tâm, Bộ xử lý số tín hiệu, Bộ nhớ EPROM,… Quản lý cơ sở dữ liệu đại biểu, Quản lý điều khiển microphone đại biểu: danh sách đăng ký phát biểu, danh sách phát biểu, điều khiển tắt mở microphone, Điều khiển biểu quyết điện tử: khởi tạo thời gian, biểu quyết, huỷ biểu quyết, hiển thị kết quả biểu quyết, quản lý điểm danh đại biểu v.v… 2. Hệ thống ghép nối âm thanh mở rộng. Hệ thống này tạo đường âm thanh chất lượng cao ghép nối với hệ thống âm thanh ngoài: mixer, bộ khuyếch đại công suất (amplifier), loa. 3. Hệ thống phát hồng ngoại. 12 Hệ thống phiên dịch hồng ngoại sử dụng sóng hồng ngoại để phát các kênh dịch riêng lẻ. Ứng với mỗi kênh hồng ngoại là một ngôn ngữ dịch. Qua bộ thu hồng ngoại người nghe lựa chọn ngôn ngữ phù hợp với ngôn ngữ của mình. 4. Hệ thống mạng. Hệ thống này sử dụng để kết nối điều khiển từ xa, chẳng hạn: truyền hình hội nghị, điều khiển từ xa hệ thống biểu quyết điện tử số DCN, mạng máy tính điều khiển, hiển thị thông tin đại biểu, kết quả biểu quyết, thông báo hội nghị, nhắn tin… 1.2. Giới thiệu tổng quan hệ thống biểu quyết điện tử số DCN: Hệ thống biểu quyết điện tử số DCN cung cấp các phương tiện điều khiển linh động, mềm dẻo cho các loại hội nghị, từ hội thảo nhỏ đến hội nghị quốc tế, hội nghị đa ngôn ngữ với hàng trăm đại biểu. Hệ thống DCN cung cấp các dịch vụ từ quản lý điều khiển microphone, nhận dạng đại biểu, đăng ký đại biểu, biểu quyết điện tử, hiển thị thông tin đến các thiết bị phân phối, hiển thị và mở rộng hệ thống phiên dịch đồng thời và điều khiển camera tự động. Toàn bộ các thiết bị DCN bao gồm: 1. Thiết bị phân bố gồm: microphone đại biểu, microphone chủ toạ…. Thiết bị phân bố thực hiện các chức năng cơ bản như sau: - Chức năng biểu quyết điện tử theo các trạng thái: điểm danh, biểu quyết, không biểu quyết, không tán thành. - Chức năng đọc thẻ chíp - Chức năng microphone: đăng ký, hủy đăng ký phát biểu. - Chức năng thông tin hội nghị. - Chức năng chủ tọa hội nghị. 2. Thiết bị điểu khiển trung tâm CCU: Bao gồm bộ vi xử lý, bộ xử lý số, bộ nhớ và các đường bus ACN1, ACN2. Bộ điều khiển trung tâm quản lý, điều khiển microphone, Biểu quyết, truyền thông đến phần mềm điều khiển, bộ điều khiển từ xa… 3. Thiết bị phiên dịch và thiết bị phân phối dịch: Thiết bị sử dụng để truyền tải, phân phối ngôn ngữ theo các kênh dịch để đại biểu trong hội nghị lựa chọn ngôn ngữ cho phù hợp với ngôn ngữ của mình. 4. Thiết bị hiểu thị thông tin: Bảng hiển thị kết quả biểu quyết Hall Display, Màn hiển thị điều khiển, Màn hình lớn: để hiển thị thông báo, hình ảnh, quá trình biểu quyết, kết quả biểu lên màn hình. 13 5. Các gói phần mềm ứng dụng: - Quản lý vị trí lắp đặt thiết bị. - Quản lý cơ sở dữ liệu. - Quản lý điều khiển microphone. - Quản lý danh sách đại biểu. - Quản lý điều khiển biểu quyết điện tử số. 6. Các thiết bị lắp đặt: - Hộp kết nối đa mục đích, - Bộ khuyếch đại - Bộ điều khiển microphone - Bộ điểu khiển biểu quyết. - Hộp đọc thẻ. Ngoài ra, thiết bị DCN có thể mở rộng một cách thích nghi với các hệ thống như hệ thống video, hiển thị dữ liệu, hệ thống Camera TV, PC, hệ thống giám sát hiển thị, hệ thống khuếch đại PA, hệ thống loa và hệ thống in ấn. 1.2.1 Thiết bị phân lập Bao gồm các thiết bị thực hiện các chức năng như sau: Nghe, đăng ký phát biểu, phát biểu, nhận thông tin thông báo trên màn hình, liên lạc nội bộ giữa các đại biểu và thực hiện biểu quyết, cắm thẻ đại biểu. Chẳng hạn như: Hộp microphone chủ toạ, Hộp microphone đại biểu, bàn phiên dịch… 1.2.2 Thiết bị điều khiển trung tâm CCU Thiết bị điều khiển trung tâm CCU là trái tim của hệ thống DCN. Bộ điều khiển trung tâm CCU có thể hoạt động điều khiển hội nghị độc lập. - CCU có thể hoạt động thông qua máy tính sử dụng phần mềm điều khiển. - CCU có khả năng điều khiển 240 thiết bị phân tập; - Khi tăng dung lượng điều khiển thì có thể mở rộng CCU slave kết nối tối đa 16 có nghĩa là có khả năng điều khiển mở rộng hệ thống lên 3840 thiết bị tương ứng với hội nghị có 3840 đại biểu. - CCU cho phép quản lý điểu khiển microphone, hệ thống dịch đồng bộ, biểu quyết điện tử, nhiều phương tiện khác như các kênh tiếng số, kênh dữ liệu và kênh truyền thông. - CCU thực hiện các chức năng như: phiên dịch, điều khiển microphone, thông báo message, hiển thị kết quả biểu quyết, thủ tục biểu quyết, liên lạc nội bộ (intercom) tạo cơ sở dữ liệu, đăng ký đại biểu, xử lý tiếng nói và điều khiển Camera tự động. 14 1.3. Định tuyến hệ thống âm thanh trong hệ DCN Định tuyến âm thanh trong hệ thống biểu quyết điện tử DCN theo hình 1.2 như sau: Hình 1.2: Sơ đồ định tuyến âm thanh trong hệ thống biểu quyết số DCN. Tín hiệu âm thanh Voice từ người phát biểu được thu bởi microphone, tín hiệu microphone được qua bộ chuyển đổi A/D rồi qua ghép kênh truyền dẫn đến bộ trộn âm thanh Audio Mixer rồi đến bộ chuyển đổi D/A đưa ra đến bộ khuyếch đại công suất rồi đến Loa ( loa đại biểu, loa PA,…). 15 1.4. Nguyên lý hoạt động của hệ thống biểu quyết số 1.4.1 Sơ đồ nguyên lý hoạt động của hệ thống biểu quyết điện tử số Sơ đồ nguyên lý hoạt động của hệ thống biểu quyết số được trình bày trên hình 1.3 dưới đây. Hình 1.3: Sơ đồ nguyên lý hệ thống biểu quyết điện tử số DCN. Chi tiết các khối như sau: 1.4.2 Cấu trúc bộ điều khiển trung tâm CCU Bộ điều khiển trung tâm CCU bao gồm: - Vi xử lý trung tâm. - Bộ xử lý tín hiệu số (DSP). - Bộ nhớ FLash. - Bộ nhớ EFROM. - ACN1 : Audio control Network 1 - ACN2: Audio Control Network 2 - Praedic: Bộ tiền xử lý tiếng và ghép kênh. - Bảng điều khiển điều khiển. Các khối chức năng được kết nối với nhau thông qua đường dây mạng. 16 1.4.3 Nguyên lý hoạt động của hệ thống biểu quyết điện tử số DCN - Kiến trúc mạng dây hệ thống cung cấp đường truyền thông kết nối đa phương tiện giữa vi xử lý trung tâm đến các thiết bị ghép nối vào CCU. - Việc truyền thông thông qua hệ thống dây mạng để kết nối các thiết bị với nhau và truyền thông của CCU với các khối IC chức năng được thực hiện trên nguyên tắc truyền thông giữa các khối truyền thông mạng và âm thanh ACN1, ACN2 và ACN3 với nhau. - ACN1 được lắp đặt trong các thiết bị đại biểu, chủ toạ, bàn phiên dịch ACN1 kết nối với CCU thông qua ACN2, bằng việc gửi và nhận (hoạt động hay không hoạt động, kích hoạt hay thụ động). - ACN2 nhận thông tin từ ACN1 và ACN3 và truyền đến bộ vi xử lý trung tâm. - ACN3 có chức năng chỉ nhận dữ liệu chẳng hạn bộ chọn kênh chỉ nhận thông tin. - PREADIC ( Profession Audio Encoding Decoding Intergrated Circuit) là bộ xử lý tích hợp bộ chuyển đổi tương tự ra số và bộ chuyển đổi số sang tương tự: chẳng hạn tín hiệu từ microphone qua A/D để xử lý tương tự ra tín hiệu số rồi qua bộ mã hóa để mã hóa tín hiệu số rồi truyền đi, còn tín hiệu số nhận được qua bộ giải mã đến bộ D/A để xử lý số ra tương tự rồi khuếch đại ra loa. - Để đưa kết quả biểu quyết ra bảng hiển thị thì bộ điều khiển trung tâm truyền dữ liệu qua cổng COM theo chuẩn RS 232. - Để dùng máy vi tính PC điều khiển, kết nối với bộ điều khiển trung tâm thông qua Card mạng kết nối chuyên dụng. - Để đưa hình ảnh camera ra màn hình ngoài thông qua đường video của hệ thống chuyển mạch camera. Hình ảnh bên trong thiết bị trung tâm CCU như trình bày trên hình 1.4. Hình 1.4: Hình ảnh bên trong của bộ điều khiển trung tâm CCU. 17 Hình ảnh bên ngoài thiết bị điều khiển trung tâm CCU như hình 1.5 dưới đây Hình 1.5: Hình ảnh bên ngoài cùa bộ điều khiển trung tâm CCU. 1.5. Các phần mềm ứng dụng điều khiển hệ thống biểu quyết điện tử số DCN: Hệ thống phần mềm điều khiển hệ thống DCN bao gồm các module phần mềm như sau: + Phần mềm khởi tạo hệ thống. Phần mềm này có tác dụng khởi động kết nối đường truyền với hệ thống DCN để chạy các ứng dụng: thiết lập vị trí địa chỉ cứng cho đại biểu. + Phần mềm cơ sở dữ liệu là phần mềm lưu trữ thông tin của đại biểu: tên, pin, code, quyền truy cập đó là đại biểu được biểu quyết hay không biểu quyết, được phát biểu hay không được phát biểu hoặc dự thính. + Phần mềm biểu quyết điện tử là phần mềm điều khiển hệ thống DCN biểu quyết: đặt chế độ biểu quyết: nghị viện kín hay nghị viện công khai, thời gian biểu quyết, khởi tạo biểu quyết, tạm dừng quá trình biểu quyết, kết thúc quá trình biểu quyết, huỷ bỏ quá trình biểu quyết và hiện thị kết quả biểu quyết. + Phần mềm hiển thị kết quả biểu quyết là phần mềm đưa ra số liệu biểu quyết. + Phần mềm quản lý Microphone là phần mềm cho phép đại biểu đăng ký phát biểu vào danh sách đại biểu, huỷ đăng ký, thêm đăng ký, điều khiển phát biểu, vào danh sách phát biểu…Điều khiển DCN hoạt động ở các chế độ microphone: chế độ đăng ký phát biểu, chế độ tự động bật microphone, chế độ chiếm microphone (FIFO)… + Phần mềm quản lý vắng mặt, điểm danh là phần mềm kiểm tra số lượng đại biểu có mặt, vắng mặt, hiển thị thông tin đại biểu đăng nhập hệ thống, thoát khỏi hệ thống. 18 CHƯƠNG 2 CẤU HÌNH HỆ THỐNG BIỂU QUYẾT ĐIỆN TỬ SỐ DCN VÀ GIAO TIẾP CỐNG NỐI TIẾP RS232 2.1 Cấu hình hệ thống biểu quyết số DCN Tuỳ thuộc vào số lượng đại biểu mà lựa chọn cấu hình hệ thống biểu quyết điện tử số DCN đơn giản hay phức tạp. Với số lượng đại biểu khoảng 240 đại biểu thì ta lựa chọn cấu hình hệ thống DCN single CCU. Còn số lượng đại biểu nhiều hơn 240 đại biểu thì sử dụng hệ thống DCN Multi CCU. 2.1.1 Hệ thống biểu quyết điện tử số DCN Single CCU Hình 2.1: Kết nối hệ thống DCN độc lập. Hệ thống DCN này dùng 1 bộ điều khiển trung tâm, dùng cho hội nghị nhỏ khoảng 240 đại biểu. Bộ điều khiển trung tâm CCU kết nối cổng (port) 1 với máy tính điều khiển PC kết nối theo chuẩn ghép nối nối tiếp với thông số cổng: (8,N,1) với tốc độ 115.2 kbps, giao thức truyền Full. - Bộ chuyển mạch điều khiển camera được kết nối vào (port) 2 của bộ điều khiển trung tâm CCU theo thông số cổng: (8,N,1) với tốc độ 19.2 kbps, giao thức protocol: CAMERA. Bằng kết nối này, hệ thống biểu quyết điện tử số sẽ tự động tìm đến vị trí đại biểu khi đại biểu bật microphone. 2.1.2 Hệ thống biểu quyết điện tử số DCN Multi- CCU Khi hội nghị có số lượng lớn đại biểu tham dự thì hệ thống biểu quyết 19 điện tử số cần được mở rộng bằng cách sử dụng kết nối nhiều bộ điều khiển trung tâm được kết nối theo hình 2.2 Hình 2.2: Kết nối hệ thống biểu quyết điện tử số Multi CCU Cấu hình máy tính điều khiển: Cài đặt hệ điều hành được từ window 95 trở lên. Hệ thống được thiết lập trên có đầy đủ các chức năng của hệ thống biểu quyết điện tử số: điều khiển microphone hội nghị, biểu quyết, chuyển mạch video theo vị trí microphone được bật, với số lượng điều khiển lên đến 3840 microphone đại biểu. Hệ thống biểu quyết điện tử số được kết nối như sau: - CCU kết nối với PC điều khiển thông qua port 1 của CCU với thông số cổng COM: 115.2 kbps với giao thức (protocol): Full. - CCU kết nối với hệ thống điều khiển camera qua cổng port 2 của CCU với thông số cổng COM: 19200bps. 20 2.2 Thông số các cổng của CCU khi kết nối với PC và kết nối với camera Thông số cổng COM khi sử dụng hệ điều hành OS2. - Thiết lập số cổng: Serial Port Number 1 or 2 Cổng lôgic 1 hoặc 2 Portnumber 0 1 – 2 tắt truyền thông nối tiếp số cổng nối tiếp của PC ( OS2) (COM1 – COM2) Thiết lập tốc độ truyền dẫn: Serialspeed Number 1 or 2 cổng lôgic 1 hoặc 2 Baudrate 19200 Các giá trị: 9600,19200,57600 và 115200 Các kiểu thủ tục truyền thông: Serial protocol Number 1 or 2 Cổng lôgic 1 hoặc 2 Terminal cổng sử dụng mã ACII Simple Thủ tục truyền simple Full Thủ tục truyền Full Type Camera Cổng sử dụng chuyển mạch video Thông số 2 cổng COM: Chức năng cổng COM Remote control ( Điều khiển từ xa) Camera control ( Điều khiển Camera) DCN PC control ( Máy tính điều khiển DCN) Port 1: Remote SERIALPORT2 1 SERIALSPEED2 SERIALPORT1 2 SERIALSPEED1 Không ứng dụng 21 control Port 2: camera control 19200 SERIALPROTOCOL 2 SIMPLE 19200 SERIALPROTOCO L1 CAMERA Port 1: DCN PC control Port 2 Camera control SERIALPORT1 2 SERIALSPEED1 19200 SERIALPROTOCOL 1 CAMERA Không ứng dụng SERIALPORT2 1 SERIALSPEED2 115200 SERIALPROTOCOL 2 FULL 2.3 Thông số kỹ thuật cổng nối tiếp RS 232 Cổng nối tiếp được sử dụng để truyền dữ liệu hai chiều giữa máy tính và ngoại vi có các ưu điểm sau: - Khoảng cách truyền xa hơn truyền song song. - Số dây kết nối ít. - Có thể ghép nối với vi điều khiển hay PLC (Programmable Logic Device). - Cho phép nối mạng. - Có thể tháo lắp thiết bị trong lúc máy tính đang làm việc. - Có thể cung cấp nguồn cho các mạch điện đơn giản Các thiết bị ghép nối chia thành 2 loại: DTE (Data Terminal Equipment) và DCE (Data Communication Equipment). DCE là các thiết bị trung gian như MODEM còn DTE là các thiết bị tiếp nhận hay truyền dữ liệu như máy tính, PLC, vi điều khiển, … Việc trao đổi tín hiệu thông thường qua 2 chân RxD (nhận) và TxD (truyền). Các tín hiệu còn lại có chức năng hỗ trợ để thiết lập và điều khiển quá trình truyền, được gọi là các tín hiệu bắt tay (handshake). Ưu điểm của quá trình truyền dùng tín hiệu bắt tay là có thể kiểm soát đường truyền. Tín hiệu truyền theo chuẩn RS-232 của EIA (Electronics Industry Associations). Chuẩn RS-232 quy định mức logic 1 ứng với điện áp từ -3V đến -25V (mark), mức logic 0 ứng với điện áp từ 3V đến 25V (space) và có khả năng cung cấp dòng từ 10 mA đến 20 mA. Ngoài ra, tất cả các ngõ ra đều có đặc tính chống chập mạch. Chuẩn RS-232 cho phép truyền tín hiệu với tốc độ đến 20.000 bps nhưng nếu cáp truyền đủ ngắn có thể lên đến 115.200 bps. 22 Các phương thức nối giữa DTE và DCE: - Đơn công (simplex connection): dữ liệu chỉ được truyền theo 1 hướng. - Bán song công (half-duplex): dữ liệu truyền theo 2 hướng nhưng mỗi thời điểm chỉ được truyền theo 1 hướng. - Song công (full-duplex): số liệu được truyền đồng thời theo 2 hướng. Định dạng của khung truyền dữ liệu theo chuẩn RS-232 như sau: Start D0 D1 D2 D3 D4 D5 D6 D7 P Stop 0 1 Khi không truyền dữ liệu, đường truyền sẽ ở trạng thái mark (điện áp - 10V). Khi bắt đầu truyền, DTE sẽ đưa ra xung Start (space: 10V) và sau đó lần lượt truyền từ D0 đến D7 và Parity, cuối cùng là xung Stop (mark: -10V) để khôi phục trạng thái đường truyền. Dạng tín hiệu truyền mô tả như sau (truyền ký tự A): Hình 2.3: Tín hiệu truyền của ký tự ‘A’. 23 Các đặc tính kỹ thuật của chuẩn RS-232 như sau: Chiều dài cable cực đại 15m Tốc độ dữ liệu cực đại 20 Kbps Điện áp ngõ ra cực đại  25V Điện áp ngõ ra có tải  5V đến  15V Trở kháng tải 3K đến 7K Điện áp ngõ vào  15V Độ nhạy ngõ vào  3V Trở kháng ngõ vào 3K đến 7K Bảng 1.1: Thông số kỹ thuật của chuẩn RS 232 Các tốc độ truyền dữ liệu thông dụng trong cổng nối tiếp là: 1200 bps, 4800 bps, 9600 bps và 19200 bps. - Sơ đồ chân: Hình 2.4: Sơ đồ chân cổng nối tiếp. Cổng COM có hai dạng: đầu nối DB25 (25 chân) và đầu nối DB9 (9 chân). Ý nghĩa của các chân cổng nối tiếp RS232 được mô tả theo bảng 1.2 sau: D25 D9 Tín hiệu Hướng truyền Mô tả 1 - - - Protected ground: nối đất bảo vệ 2 3 TxD DTE->DCE Transmitted data: dữ liệu truyền 3 2 RxD DCE->DTE Received data: dữ liệu nhận 4 7 RTS DTE->DCE Request to send: DTE yêu cầu truyền dữ liệu 5 8 CTS DCE->DTE Clear to send: DCE sẵn sàng nhận dữ liệu 24 6 6 DSR DCE->DTE Data set ready: DCE sẵn sàng làm việc 7 5 GND - Ground: nối đất (0V) 8 1 DCD DCE->DTE Data carier detect: DCE phát hiện sóng mang 20 4 DTR DTE->DCE Data terminal ready: DTE sẵn sàng làm việc 22 9 RI DCE->DTE Ring indicator: báo chuông 23 - DSRD DCE->DTE Data signal rate detector: dò tốc độ truyền 24 - TSET DTE->DCE Transmit Signal Element Timing: tín hiệu định thời 15 - TSET DCE->DTE Transmitter Signal Element Timing: tín hiệu định thời 17 - RSET DCE->DTE Receiver Signal Element Timing: tín hiệu định thời 18 - LL Local Loopback: kiểm tra cổng 21 - RL DCE->DTE Remote Loopback: Tạo ra bởi DCE khi tín hiệu nhận 14 - STxD DTE->DCE Secondary Transmitted Data 16 - SRxD DCE->DTE Secondary Received Data 19 - SRTS DTE->DCE Secondary Request To Send 13 - SCTS DCE->DTE Secondary Clear To Send 12 - SDSRD DCE->DTE Secondary Received Line Signal Detector 25 - TM Test Mode 9 - Dành riêng cho chế độ test 10 - Dành riêng cho chế độ test 11 Không dùng Bảng 1.2: Chức năng các chân của cổng nối tiếp. 25 2.3.1 Truyền thông giữa hai nút Các sơ đồ khi kết nối dùng cổng nối tiếp: Hình 2.5: Kết nối đơn giản trong truyền thông nối tiếp Khi thực hiện kết nối như trên là kết nối không móc nối, quá trình truyền phải bảo đảm tốc độ ở đầu phát và thu giống nhau. Khi có dữ liệu đến DTE, dữ liệu này sẽ được đưa vào bộ đệm và tạo ngắt. Ngoài ra, khi thực hiện kết nối giữa hai DTE theo cách móc nối cứng, ta dùng sơ đồ sau: Hình 2.6: Kết nối trong truyền thông nối tiếp dùng tín hiệu bắt tay Khi DTE1 cần truyền dữ liệu thì cho DTR tích cực tác động lên DSR của DTE2 cho biết sẵn sàng nhận dữ liệu và cho biết đã nhận được sóng mang của MODEM (ảo). Sau đó, DTE1 tích cực chân RTS để tác động đến chân CTS của DTE2 cho biết DTE1 có thể nhận dữ liệu. Khi thực hiện kết nối giữa DTE và DCE, do tốc độ truyền khác nhau nên phải thực hiện điều khiển lưu lượng. Quá trinh điều khiển này có thể thực hiện bằng phần mềm hay phần cứng. Quá trình điều khiển bằng phần mềm thực hiện bằng hai ký tự Xon có giá trị 11h và Xoff có giá tri 13h. Ký tự Xon được DCE gửi đi khi rỗi (có thể nhận dữ liệu). Nếu DCE bận thì sẽ gửi ký tự Xoff. Quá trình điều khiển bằng phần cứng dùng hai chân RTS và CTS. Nếu DTE muốn truyền dữ liệu thì sẽ nâng đường tín hiệu 26 RTS lên mức cao để yêu cầu truyền rồi kiểm tra trạng thái dây CTS cho đến khi CTS ở mức cao, khi CTS ở mức thấp có nghĩa bên thu vẫn bận chưa nhận được dữ liệu.Khi bên thu nhận xong dữ liệu từ bộ đệm của nó thì RTS nối với CTS của bên phát sẽ nhảy lên mức cao. Quá trình nhận dữ liệu cũng giống như quá trình truyền. Khi DCE muốn phát tới DTE , DSR bên thu sẽ trở nên tích cực. Nếu bên thu không thể nhận dữ liệu thì DSR ở trạng thái không tích cực. 2.3.2 Truy xuất trực tiếp thông qua cổng COM Các cổng nối tiếp trong máy tính được đánh số là COM1, COM2, COM3, COM4 với các địa chỉ như sau: Tên Địa chỉ Ngắt Vị trí chứa địa chỉ COM1 3F8h 4 0000h:0400h COM2 2F8h 3 0000h:0402h COM3 3E8h 4 0000h:0404h COM4 2E8h 3 0000h:0406h Bảng 1.3: Các ngắt cổng COM 27 CHƯƠNG 3 GIAO DIỆN ĐIỂU KHIỂN TỪ XA ĐẾN HỆ THỐNG DCN 3.1 Mô hình hệ thống điều khiển từ xa Sơ đồ ghép nối điều khiển từ xa hệ thống biểu quyết điện tử được trình bày trên hình 3.1 dưới đây. Hình 3.1: Sơ đồ ghép nối với bộ điều khiển từ xa. Bộ điều khiển từ xa hệ thống DCN được kết nối qua đường RS 232 đến bộ điều khiển trung tâm CCU. Để bộ điều khiển từ xa điều khiển được CCU phải thông qua các giao thức truyền dẫn (protocol) simple hoặc (protocol) Full của bộ điều khiển trung tâm CCU. 3.2 Các thông số điều khiển từ xa Thiết bị (PC, bộ điều khiển, …) kết nối với cổng nối tiếp là bộ điều khiển hệ thống thứ hai đến bộ điểu khiển trung tâm CCU. Các thiết bị này được gọi là bộ điều khiển từ xa. Trên hình vẽ máy tính điều khiển DCN kết nối qua kênh ACN hoặc qua cổng COM. Bộ điều khiển từ xa điều khiển các ứng dụng từ xa sử dụng đường nối tiếp của bộ điều khiển trung tâm. Chẳng hạn như: điều khiển từ xa, điều khiển biểu quyết, hiển thị kết quả biểu quyết… Các phần mềm điều khiển từ xa này sử dụng giao thức ghép nối từ xa với bộ điều khiển trung tâm CCU. 3.2.1 Kiểu thông báo định dạng: Truyền thông giữa bộ điều khiển từ xa và bộ điều khiển trung tâm CCU dựa trên bản tin thông báo( Message format). 28 3.2.2 Kiểu định dạng thông báo cơ bản: Type Length Data Khai báo cấu trúc được định nghĩa như sau: typedef struct { BYTEbyType; // Loại thông báo WORDwLength; // Độ dài thông báo BYTEbyData []; // Dữ liệu thông báo. } T_MESSAGE; where: byType Loại thông báo. Các kiểu thông báo truyền thông với bộ điều khiển trung tâm CCU:  MDSC_REMOTEPROCEDURE_REQ  MDSC_REMOTEPROCEDURE_RSP  MDSC_NOTIFY wLength Độ dài thực sự của dữ liệu trong dãy dữ liệu được truyền phát có giới hạn = 5000. byData [] Dãy dữ liệu truyền đi phụ thuộc vào loại thông báo. 3.2.3 Định dạng yêu cầu điều khiển từ xa Định dạng yêu cầu điều khiển từ xa này là một thông báo luôn được truyền tới bộ điều khiển trung tâm. Thông báo MDSC_REMOTEPROCEDURE_REQ này có cấu trúc như sau: typedef struct { WORD wFnId; // khai báo chức năng. REQSTRUC tStructure; // Tham số chức năng } RSMT_REMOTEPROCEDURE_REQ; wFnId khai báo chức năng. tStructure Tham số chức năng. Sau khi yêu cầu chức năng điều khiển từ xa gửi tới bộ điều khiển trung tâm, bộ điều khiển trung tâm luôn luôn gửi lại một đáp ứng dựa trên việc nhận chức năng điều khiển từ xa. Bộ điều khiển từ xa sẽ đợi chắc chắn đáp ứng được trả lời trước khi gửi các chức năng điều khiển từ xa khác đến bộ điều khiển 29 trung tâm CCU. 3.2.4 Định dạng đáp ứng điều khiển từ xa Dựa trên việc nhận chức năng điều khiển từ xa bộ điều khiển trung tâm CCU sẽ xử lý các chức năng yêu cầu và tạo ra một đáp ứng tương ứng với chức năng điều khiển từ xa đó. Cấu trúc đáp ứng trả lời chức năng điều khiển từ xa như sau: typedef struct { Word wFnId; // định nghĩa chức năng. Word wError; // trả mã lỗi Tstructure; } RSMT_REMOTEPROCEDURE_RSP; trong đó: wFnId Khai báo chức năng. wError Trả về mã lỗi của hàm chức năng. Nểu giá trị là khác không thì nội dung của tham số ‘tStructure’ là không hợp lệ. tStructure Cấu trúc chứa thông tin đáp ứng sau khi xử lý chức năng điều khiển từ xa. 3.2.5 Định dạng thông báo cập nhật MDSC_NOTIFY: - Dựa vào trạng thái cập nhật thông tin bộ điều khiển trung tâm CCU sẽ gửi một thông điệp cập nhật đến bộ điểu khiển từ xa. Bộ điều khiển trung tâm chờ trả lời lại của bộ điều khiển từ xa trên cơ sở các thông điệp đó. - Việc cập nhật thông điệp luôn luôn được cập nhật từ bộ điểu khiển từ xa CCU và chỉ gửi đến bộ điều khiển từ xa nếu có đăng ký cho ứng dụng. typedef struct { WORD wFnId; NTFSTRUC tStructure; } RSMT_NOTIFY; wFnId Khai báo thông báo The notification identifier. tStructure Cấu trúc chứa thông tin cập nhật. 30 3.2.6 Định dạng thông số truyền thông DSC_COMMUNICATION_PARAMS Trong thủ tục (protocol) Full có rất nhiều tham số để điều khiển các chức năng của thủ tục. Một số chức năng này có thể thay đổi chức năng điều khiển từ xa với thời gian tốt hơn dựa vào hệ thống sử dụng bộ điều khiển từ xa. - Khi truyền thông tin có thể chuyển từ bộ điều khiển từ xa 1 đến bộ điều khiển từ xa 2 khi này bộ điều khiển thứ 1 từ chối công việc mà không mất mát thông tin liên lạc. Thời gian heart – beat time lớn hơn thời gian chuyển mạch. Để thay đối thông số truyền thông thì sử dụng tham số truyền thông như sau: typedef struct {WORDwFnId; WORDwHeartbeatTime; WORDwNrRetries; WORDwRetryTime; } RSMT_COMMUNICATION_PARAMS; wFnId Đặt thông số truyền thông. Thông số này phải đặt giá trị RSMC_SET_COMMUNICATION_PARAMS cho việc thiết lập thông số truyền thông. wHeartbeatTime Thời gian heartbeat time là số giây được sử dụng có giá trị thay đổi từ 0-1000. Giá trị 0 để gán cho chức năng tắt kiểm tra thời gian heartbeat. wNrRetries Số lượng lần thực hiện lại trước khi gói dữ liệu bị loại bỏ, giá trị thay đổi từ 0-10. Số đếm này là số lần truyền lại dựa vào gói NAK. wRetryTime Thời gian thực hiện lại khi không nhận các đáp ứng trả lời.Giá trị thay đổi từ 1 - 100. 3.3. Thủ tục truyền thông của bộ điều khiển trung tâm: Tất cả các thông báo nêu trên phải được truyền giữa bộ điều khiển trung tâm CCU và bộ điều khiển từ xa. Kỹ thuật truyền dẫn sử dụng các thủ tục phát hiện lỗi đường truyền. Truyền thông nối tiếp trong CCU có 3 loại giao thức truyền: - Giao thức truyền đầu cuối dữ liệu (Terminal protocol ): Giao thức này ít được sử dụng để truyền dữ liệu.Thiết lập này được sử dụng cho đầu cuối dữ liệu ASCII. - Giao thức truyền Camera (camera protocol): Giao thức này được sử dụng truyền thông giữa hệ thống chuyển mạch video đến bộ điều khiển trung tâm CCU. 31 - Giao thức đầy đủ (Full protocol): bao gồm phát hiện lỗi và truyền lại thông tin. kỹ thuật kiểm tra được sử dụng truyền thông là heart beat. - Giao thức đơn giản (Single protocol): Chỉ kiểm tra lỗi đường truyền. - Kiểu gói dữ liệu: Truyền thông cơ bản giữa bộ điều khiển trung tâm với bộ điều khiển từ xa được dựa trên gói cơ bản như sau: Tiêu đề (header) Thông tin (message) Bít kiểm tra chksum 3.3.1 Đặc tính của giao thức truyền thông Full Trong hệ thống biểu quyết điện tử số DCN sử dụng giao thức truyền thông Full cung cấp đầy đủ chức năng giao thức bao gồm truyển lại và kiểm tra truyền thông. Trong hệ thống Multi - CCU thì đòi hỏi số lượng lớn bộ nhớ khi sử dụng giao thức này. Đặc tính của giao thức truyền Full: - Ưu tiên sử dụng phát hiện header bằng việc sử dụng escape handling. - Thủ tục cung cấp thông tin ACK và NACK - Thông tin được gửi bằng một khối. Bộ điều khiển trung tâm kiểm tra nếu mỗi byte nhận được trong 50 ms của byte trước. Nếu không thì gói NACK được gửi đi. - Dựa vào việc nhận gói NACK sau đó thông tin được gửi lại. - Mỗi thông tin bao gồm một số tuần tự. Việc nhận sử dụng dãy tuần tự này để nhận thông tin. - Khi không có gói ACK được nhận trong 2 giây sau khi kết thúc việc truyền dữ liệu thì sẽ truyền lại.Tổng số truyền lại thông tin là 2 lần trước khi truyền gói dữ liệu bị huỷ bỏ. - Kiểm tra kết nối sử dụng heartbeat. Mỗi gói nhận được có giá trị heart beat chính xác. Khi vượt qua thời gian heartbeat thì truyền thông sẽ dừng lại. Tất cả gói dữ liệu bị tạm dừng sẽ bị huỷ bỏ. Trên các ứng dụng sẽ thông báo đến bộ điều khiển từ xa là truyền thông lỗi, thất bại. - Trong trường hợp đặc biệt thay đổi thông số truyền thông được thiết lập thông qua MDSC_COMMUNICATION_PARAMS: sau khi truyền thông tin này hệ thống đợi trả lời. Điều này giảm thông số truyền qua. 1. Định dạng thông tin header: Header có kiểu như sau: Escape Header type Sequence 32 typedef struct { BYTEbyEscape; // có giá trị 0xC8 BYTEbyHeaderType; BYTEbySequence; } RSMT_HEADER; byEscape Escape byte dùng cho nhận dạng phần header. Dạng escape byte kết hợp cùng với loại tiêu đề để định nghĩa ra mục đích của gói dữ liệu. byHeaderType Thông tin loại gói dữ liệu bySequence Thông tin tuần tự khi gói dữ liệu được kích hoạt 2.Định nghĩa kiểu gói dữ liệu: Đặc tính giao thức Full sử dụng nhiều loại header để nhận biết thông tin truyền đi. Sau đây là các loại headertypes: ‘$’ Gói chứa thông tin dữ liệu. ‘@’ Gói thông tin xác nhận ACK. Gói dữ liệu này chỉ chứa header và checksum. ‘#’ Gói không xác nhận trả lời NAK. Gói dữ liệu này chỉ chứa header và checksum không có thông tin trong gói này. Gói này yêu cầu truyền lại dữ liệu xác định với số tuần tự trong header. ‘?’ Gói dữ liệu heartbeat . Khi số tuần tự được truyền qua thì số tiếp theo của gói tiếp được truyền. Gói này được sử dụng để kiểm tra truyền thông. 3.Tính toán kiểm tra lỗi Checksum: Gói dữ liệu kết thúc bằng vùng checksum. Kiểm tra tất cả thông tin bên trong header và dữ liệu. Gói checksum có cấu tạo: correction checksum typedef struct { BYTEbyCorrection; BYTEbyChecksum; 33 } RSMT_CHECKSUM; byCorrection Giá trị chính xác này tính toán bằng giá trị 0xC8. Cũng có thể giá trị này gồm: 0x00 hoặc 0x13. byCheck Tính toán checksum thông qua header, thông tin dữ liệu và giá trị xác định. The Checksum được tính toán theo thứ tự như sau: 1. Đặt byte chính xác bằng giá trị 0x00. 2. Tính tổng tất cả các bytes với tiêu đề, thông tin và kiểm lỗi. 3. Đảo bít của checksum để đưa về module 256. 4. Kiểm tra lại checksum có bằng giá trị (0xC8). Khi bằng: a. Gán giá trị kiểm lỗi bằng 0x13. b. Trừ giá trị cũ bằng giá trị (0x00) và cộng giá trị mới (0x13) rồi tính tổng như bước 2. c. Đưa module 256 vào tính toán checksum và thực hiện đảo ngược bit của checksum. Kết quả không bao giờ bằng giá trị escape. Việc tính toán checksum này gửi đi phụ thuộc vào gói dữ liệu. Việc nhận được thực hiện chỉ ở bước 2 và 3 . 3.3.2 Tham số nhận biết thông tin Để nhận ra thông tin tiêu đề header trong luồng dữ liệu bytes là rất khó, bởi vì dữ liệu có thể là các số tuần tự giống nhau trong header. Vì lý do đó escape byte để phân biệt the header. Escape byte có giá trị 0xC8.Bởi vì dữ liệu được tryền cũng chứa giá trị escape. Điều này thể hiện dữ liệu phải quét chuyển giá trị escape thành các chuỗi escape. Giao thức ‘full’ sử dụng giá trị 0xC8 như là chuỗi escape. Chuỗi escape luôn theo sau các ký tự khác, nó thông tin chính xác các byte. 0xC8 Chuỗi bytes 0xC8 này sử dụng trong dữ liệu nếu dữ liệu chứa 0xC8 trong quá trình chuẩn bị thông tin ‘$’ Định nghĩa header của gói dữ liệu mới. Sau header sẽ là thông tin và checksum. ‘@’ Định nghĩa gói xác nhận thông tin ACK. ‘#’ Gói thông tin xác nhận không trả lời ‘?’ Gói dữ liệu heartbeat. others.... Các giá trị khác báo lỗi và phớt lờ sau khi truyền thông tin NAK. 34 3.3.3 Giao thức truyền thông Giao thức bắt tay kết nối giữa bộ điểu khiển trung tâm CCU và bộ điều khiển từ xa sử dụng giao diện RS - 232. Dữ liệu được kiểm tra lỗi bằng việc nhận checksum và thông tin xác nhận ACK. Giao thức truyền thông “Full” được thể hiện qua sơ đồ trạng thái truyền dẫn như hình vẽ : Hình 3.2: Sơ đồ trạng thái truyền trong thủ tục truyền “ FULL” Giao thức truyền thông full được thực hiện như sau: - Trước khi chấp nhận bất kỳ dữ liệu thông tin nào thì gói dữ liệu heartbeat được nhận trước. Bởi vì heartbeat bao gồm số tiếp theo của gói dữ liệu tiếp theo. Việc nhận chỉ kiểm tra nếu gói dữ liệu nhận được là chuỗi sau khi nhận heartbeat. - Số phân cách được tìm thấy cùng dữ liệu. - Mỗi gói dữ liệu được gửi cùng với checksum, sau mỗi thông tin được gửi, bộ phát đợi thông tin xác nhận ACK hoặc thông tin không xác nhận NACK từ bộ nhận. - Dựa vào việc nhận dữ liệu, checksum được kiểm tra và phản hồi gói dữ liệu ACK hoặc gói NAK gửi lại theo kết quả. - Sau khi gửi dữ liệu thông báo bộ phát sẽ đợi đúng giá trị ACK hoặc NAK. Không có bất kỳ dữ liệu được nhận chính xác trước khi thông báo ACK bị bỏ qua. - Bên gửi truyền lại dữ liệu dựa trên việc nhận NAK hoặc sau thời gian time - out. 35 - Tối đa 2 lần thực hiện lại. - Độ dài tối đa được hạn chế 5000 bytes. - Kiểm tra kết nối cơ khí khi thời gian trễ tối đa giữa 2 bytes là 50ms. 3.3.3.1 Gói dữ liệu không trả lời : Khi checksum lỗi, không chính xác thì NAK sẽ phát yêu cầu truyền lại gói dữ liệu. Để giúp bên gửi dữ liệu, bên nhận gửi gói chuỗi dữ liệu tuần tự. Chuỗi dữ liệu có các giá trị sau: - Số tuần tự nhận biết: Bên nhận đợi gói dữ liệu hoặc thông báo heartbeat. Trong trường hợp này, Bên nhận không có thông báo tạm hoãn, tạm treo ( trên hình vẽ không có thông báo được đánh dấu), vì vậy không có trả lời ACK đã chờ đợi. - Bên gửi dữ liệu: Đáp ứng gói NAK bằng việc yêu cầu phát lại dữ liệu. Khi không có gói dữ liệu bị treo heartbeat phải được truyền lại. 36 3.3.3.2 Giá trị thời gian của kết nối đường truyền Thông số kết nối đường truyền Giá trị Độ trễ tối đa giữa hai consecutive bytes of a message 50 ms Số lượng thông báo độc lập cho các thông báo, Thời gian đợi truyền gói ACK. 1 Số lượng thực hiện lại trước khi huỷ thông báo. Số này bao gồm số truyền lại sau khi nhận gói NAK. 2 Thời gian bắt đầu phát lại thông tin. Thời gian được tính sau byte cuối cùng được phát. 2 sec. Thời gian truyền giữa 2 consecutive heartbeat 5 sec. Thời gian heartbeat time-out. Sau thời gian không nhận bất kỳ gói dữ liệu nào 10 sec. Độ dài gói dữ liệu tối đa 5000 bytes Thời gian thực hiện chức năng điều khiển từ xa < 0,5 sec. Bảng 1.4: Thông số kết nối đường truyền 37 CHƯƠNG 4 XÂY DỰNG PHẦN MỀM BIỂU QUYẾT 4.1 Chức năng đăng ký đại biểu Để truy cập được hệ thống biểu quyết điện tử số DCN, đại biểu được gắn các quyền đăng nhập hệ thống như sau: - Đăng ký tham dự. - Kiểm tra quyền truy cập hệ thống. - Nhận biết đại biểu. Các chức năng này dùng để phân quyền truy cập cho đại biểu: - Dự thính. - Có quyền phát biểu với tư cách khách mời, không có quyền biểu quyết. - Đầy đủ các chức năng biểu quyết, phát biểu, truy cập hệ thống. 4.1.1 Đăng ký tham dự Đăng ký tham dự là một ứng dụng cho phép điều khiển từ xa để giữ lại những dấu hiệu sự hiện diện của các đại biểu trong hệ thống như thời gian bắt đầu truy cập hệ thống (có mặt) và thời gian thoát khỏi hệ thống (vắng mặt). - Để đăng nhập vào hệ thống biểu quyết điện tử, đại biểu phải tự đăng ký bằng cách sử dụng một trong những lựa chọn sau: - Nhấn nút điểm danh ở vị trí của mình. - Nhập mã nhận dạng PIN ở vị trí của mình. - Cài ID-card vào thiết bị đọc thẻ. - Để thoát khỏi hệ thống, đại biểu rút IC-card khỏi bộ đọc thẻ. 4.1.2 Điều khiển truy cập hệ thống Để truy cập hệ thống biểu quyết điện tử số, Đại biểu phải thực hiện các bước truy cập như sau: - Vào mã PIN tại vị trí đại biểu. - Cắm thẻ đại biểu ID – card vào hộp đại biểu. 4.1.3 Nhận biết đại biểu Chức năng này cung cấp thông tin vị trí ngồi của đại biểu cho hệ thống biểu quyết nhận biết đại biểu thông qua kết qủa của việc nhập ID card vào hoặc rút chúng ra khỏi vị trí đại biểu. 38 Nhận biết đại biểu có 2 khả năng: - Đại biểu ngồi đúng vị trí: Đại biểu phải ngồi đúng vị trí mới có quyền truy cập hệ thống: đăng ký phát biểu, phát biểu, biểu quyết. - Đại biểu ngồi không đúng vị trí: đại biểu không ngồi đúng vị trí không có quyền truy cập hệ thống ngoại trừ hệ thống biểu quyết thiết lập chế độ ngồi tự do. 4.1.4 Kết hợp giữa đăng ký tham dự với truy cập hệ thống Dựa vào có sự kết hợp này mà có thể kiểm soát được chặt chẽ hệ thống biểu quyết: Khi “Mã hiện diện” được lựa chọn để đánh dấu sự có mặt, việc điều khiển đường vào không thể hoạt động. - Khi đại biểu ngồi sai vị trí việc đăng ký tham dự sử dụng Mã hiện diện là không thể. 4.1.5 Thông số chức năng Thông số Ý nghĩa SeatAttend Xác định vị trí nơi đăng ký: vị trí míc, vị trí chỗ ngồi. SeatAccess Cho phép truy cập hay không được truy cập đến thiết bị. ControlType Xác định đại biểu đăng nhập vào hệ thống bằng cách: Ấn phím điểm danh, vào mã PIN, cài thẻ đại biểu ID Card hoặc cài thẻ đại biểu ID và mã PIN. 4.2 Điều khiển microphone trong hệ thống biểu quyết điện tử số 4.2.1 Các bước đăng ký phát biểu Khi đại biểu tham gia vào hội nghị, đại biểu có quyền đăng ký phát biểu, phát biểu thì đại biểu thực hiện các thao tác sau: - Ấn phím đăng ký phát biểu “Mic” tại hộp đại biểu để vào danh sách đăng ký phát biểu. - Hủy bỏ đăng ký phát biểu đại biểu ấn lại phím “Mic” tại hộp đại biểu. - Người quản trị hệ thống sẽ căn cứ vào chủ tọa điều hành mà điều khiển việc bật/ tắt microphone của đại biểu. - Kết thúc phát biểu thì đại biểu ấn nút “Mic”. 39 Lưu đồ điều khiển microphone như sau: 4.2.2 Chương trình kiểm soát danh sách đại biểu Khi phát biểu thảo luận hội nghị, phần quan trọng để điều hành hội nghị phải kiểm soát được danh sách đại biểu đăng ký phát biểu và biết đại biểu nào đang phát biểu. Do đó, ta xây dựng phần mềm hiển thị danh sách đăng ký phát biểu và danh sách phát biểu như sau: Thiết lập trạng thái Bắt đầu Kiểm tra yêu cầu và trạng thái micro Bật / tắt Kiểm tra điều khiển bật/tắt Kết thúc Dừng chương trình Không Có Có 40 Xây dựng giao diện chương trình chính bằng ngôn ngữ Visual Basic 6.0 như trên hình 4.1. Hình 4.1: Giao diện chính phần mềm biểu quyết. + Thiết kế form quản lý danh sách đăng ký và phát biểu như hình 4.2 Hình 4.2: Giao diện Danh sách đăng ký phát biểu. 41 4.3 Biểu quyết điện tử 4.3.1 Các kiểu loại biểu quyết điện tử số -Biểu quyết điện tử số tuỳ vào thực tế sử dụng mà người ta chia làm nhiều kiểu loại khác nhau như sau: -Biểu quyết nghị viện: Đại biểu tham dự biểu quyết với 3 trạng thái biểu quyết: tán thành, không tán thành, bỏ phiếu trống hoặc đại biểu không tham gia biểu quyết. -Biểu quyết For/Againt: Đại biểu chỉ bỏ phiếu với 2 trạng thái: đồng ý hoặc phản đối. -Biểu quyết đáp ứng một số vấn đề: có 5 loại câu hỏi để đại biểu trả lời: rất phản đối, phản đối, bỏ phiếu trống, đồng ý, rất đồng ý. Đại biểu lựa chọn các ý kiến. Hệ thống biểu quyết sẽ tính tỷ lệ để chỉ thị sự đồng ý với các trạng thái. Tại các kỳ họp Quốc hội nước ta sử dụng kiểu biểu quyết nghị viện với 3 trạng thái biểu quyết: Tán thành, không tán thành, không biểu quyết. 4.3.2 Các bước thực hiện biểu quyết điện tử số - Đặt các thông số biểu quyết: thời gian biểu quyết. - Chọn loại biểu quyết: nghị viện công khai. - Khởi tạo biểu quyết. - Hiển thị kết quả biểu quyết ra màn hình. - Kết thúc biểu quyết. 42 Quá trình biểu quyết điện tử số được thực hiện theo lưu đồ sau: Bắt đầu biểu quyết Kiểm tra biểu quyết Kiểm tra thời gian Thuật toán thống kê đưa ra màn hình Kết thúc Hết thời gian Còn thời gian 43 4.3.3 Xây dựng chương trình hiển thị kết quả biểu quyết + Xây dựng form màn hình hiển thị biểu quyết như sau: Hình 4.3: Giao diện hiển thị kết quả biểu quyết 4.4 Điều khiển MSComm trong Visual Basic Visual Basic 6 là ngôn ngữ lập trình hướng đối tượng có nhiều tính năng trong đó có điều khiển ActiveX MSComm dùng truyền thông nối tiếp. Các tính chất của điều khiển này được dùng để thiết lập giao tiếp với các thiết bị ngoại vi qua cổng RS232. Các tính chất của MSComm được sắp xếp theo chức năng: Thiết lập tham số cho cổng: + CommID: trả lại handles đồng nhất tới thiết bị truyền thông, có kiểu Long. Tính chất này không có lúc thiết kế mà chỉ có khi thi hành, thuộc tính này là ReadOnly. + CommPort: dạng object.CommPort = value. Value là chỉ số của cổng Com có giá trị từ 1 ‐> 16 và mặc định có giá trị =1. Thiết lập thông số này trước khi mở cổng. Sẽ có lỗi error 68 (Device unavailable) nếu như không mở được cổng này. + InBuferSize: thiết lập hoặc trả lại kích thước của bộ đệm nhận, tính = byte. Mặc định là 1024 byte. + InputLen: object.InputLen [= value] thiết lập hoặc trả lại số byte mỗi lần thuộc tính Input đọc trong bộ đệm nhận. Mặc định giá trị Value = 0 tức là thuộc tính Input sẽ đọc hết nội dung của bộ đệm nhận khi thuộc tính này được 44 gọi. Nếu số kí tự trong bộ đệm nhận không = InputLen thì thuộc tính Input sẽ trả lại kí tự rỗng. Vì thế, chọn cách kiểm tra InBufferCount để chắc chắn số kí tự yêu cầu đã có đủ trước khi dùng lệnh Input. Tính chất này có ích khi đọc dữ liệu một máy mà dữ liệu ra được định dạng bằng các khối có kích thước cố định. + InputMode: object.InputMode [ = value ]. Value = 0 hay = comInputModeText dữ liệu nhận được dạng văn bản kiểu kí tự theo chuẩn ANSI. Dữ liệu nhận được sẽ là một sâu. Value =1 hay = comInputModeBinary dùng nhận mọi kiểu dữ liệu như kí tự điều khiển nhúng, kí tự NULL,.. Giá trị nhận được từ Input sẽ là một mảng kiểu Byte. + NullDiscard: object.NullDiscard [ = value ] tính chất này quyết định kí tự trống có được truyền từ cổng đến bộ đệm nhận hay không. Nếu value= True kí tự này không được truyền. value = false kí tự trống sẽ được truyền. Kí tự trống được định nghĩa theo chuẩn ASCII là kí tự 0 – chr$(0). + OutBuferSize: giống như InBuferSize, mặc định là 512. + ParityReplace: thiết lập và trả lại kí tự thay thế kí tự không đúng trong lỗi giống nhau. + PortOpen: thiết lập và trả lại tính trạng của cổng (đóng hoặc mở). object.PortOpen [ = value ]. value = true cổng mở. value =false cổng đóng và xóa toàn bộ dữ liệu trong bộ đệm nhận và truyền. Cần phải thiết lập thuộc tính CommPort đúng với tên của cổng trước khi mở cổng giao tiếp. Thêm vào đó, cổng giao tiếp của thiết bị phải hỗ trợ giá trị trong thuộc tính Setting thì thiết bị mới hoạt động đúng, còn không thì chạy không tốt. Đường DTR và RTS luôn giữ lại trạng thái của cổng. + RthresHold: object.Rthreshold [ = value ] value kiểu số nguyên. Thiết lập số kí tự nhận được trước khi gây lên sự kiện comEvReceive. Mặc định = 0 tức là không có sự kiện OnComm khi nhận được dữ liệu. Thiết lập = 1 tức là sự kiện OnComm xảy ra khi bất kì kí tự nào được chuyển đến bộ đệm nhận. + Settings: object.Settings [ = value ] thiết lập hoặc trả lại các thông số truyền: baudrate, bít dữ liệu, bít chẵn lẻ, bít stop. Nếu Value không có giá trị khi mở sẽ gây ra lỗi 380 (Invalidproperty value). + SThreshold: thiết lập và và trả lại số kí tự nhỏ nhất được cho phép trong bộ đệm gửi để xảy ra sự kiện OnComm = comEvSend . Theo mặc định giá trị này = 0 tức là khi truyền sẽ không gây ra sự kiện OnComm. Nếu thiết lập thông số này =1 thì sự kiện OnComm xảy ra khi bộ đệm truyền rỗng. Sự kiện OnComm = comEvSend chỉ xảy ra khi mà số kí tự trong bộ đệm truyền nhỏ hơn hoặc = Sthreshold. Nếu số kí tự trong bộ đệm này luôn lớn hơn Sthreshold thì sự kiện này không thể xảy ra. Truyền nhận dữ liệu: + CommEvent: trả lại phần lớn sự kiện giao tiếp hoặc có lỗi. CommEvent xảy ra khi có lỗi hoặc khi xảy ra sự kiện nào đó. 45 Sau đây là một số hằng số lỗi: Sự kiện Giá trị Miêu tả sự kiện comEventBreak 1001 khi nhận được một tín hiệu Break. comEventFrame 1004 Lỗi hệ thống. Phần cứng phát hiện ra một lỗi hệ thống comEventOverrun 1006 Xảy ra khi cổng tự tràn( Overrun). Kí tự không được đọc từ phần cứng trước khi kí tự tiếp theo tới và do đó kí tự này bị mất. comEventRxOver 1008 Xảy ra khi bộ đệm nhận bị tràn. Không có đủ chỗ cho dữ liệu trong bộ đệm nhận. comEventRxParity 1009 Lỗi Parity. Phần cứng phát hiện ra một lỗi Parity. comEventTxFull 1010 Xảy ra khi bộ đệm truyền bị đầy. Bộ đệm truyền bị đầy trong khi ghi dữ liệu lớn vào bộ đệm comEventDCB 1011 Một lỗi không mong muốn khi đang khôi phục lại khối điều khiển thiết bị( DCB – Device Control Block) cho cổng Bảng 1.5: Sự kiện comevent Một số sự kiện : Sự kiện Giá trị Miêu tả sự kiện comEvSend 1 Xảy ra khi số kí tự trong bộ đệm truyền nhỏ hơn giá trị SthresHold. comEvReceive 2 Xảy ra khi bộ đệm nhận được số kí tự bằng giá trị RthresHold. Sự kiện này được tạo ra liên tục cho tới khi dùng thuộc tính Input để lấy hết dữ liệu từ trong bộ đệm nhận. RcomEvCTS 3 Xảy ra khi có thay đổi trong đường CTS( Clear To Send) comEvDSR 4 Xảy ra khi thay đổi trong đường DSR( Data Set Ready). Sự kiện này chỉ xảy ra khi đường DSR thay đổi từ 1 ‐> 0. 46 comEvCD 5 Xảy ra khi có thay đổi trong đường CD( Carrier Detect) comEvRing 6 Phát hiện chuông (Ring).Một số UART không hỗ trợ sự kiện này. comEvEOF 7 Xảy ra khi nhận được kí tự kết thúc file ( kí tự 26 trong bảng mã ASCII) Bảng 1.6: Bảng các sự kiện EOFEnable : object.EOFEnable [ = value ] quyết định các hành động nếu MSComm tìm thấy kí tự kết thúc file. Nếu value=true khi tìm thấy kí tự kết thúc file thì sẽ gây lên sự kiện comEvEOF trong OnCommEvent. Nếu value= false thì sẽ không gây lên sự kiện này. + InBufferCout: trả lại số kí tự đang có trong bộ đệm nhận, có thể xoá bộ đệm nhận bằng cách đặt thuộc tính này =0. Không nhầm với thuộc tính InBufferSize là tổng kích thước của bộ đệm nhận. + Input: nhận và xoá dữ liệu trong bộ đệm nhận. Nếu InputMode là comInputModeText thì giá trị trả về sẽ là một xâu tức có kiểu String, dữ liệu dạng text trong một biến kiểu Variant. Nếu InputMode = comInputModeBinary thì thuộc tính này sẽ trả lại dữ liệu dạng nhị phân dưới dạng một mảng kiểu byte trong một biến Variant. + OutBufferCount: trả lại số kí tự trong bộ đệm truyền. + Output: ghi dữ liệu vào bộ đệm truyền. có thể truyền kiểu text hoặc kiểu nhị phân. Nếu truyền bằng kiểu text thì cho một biến Variant = kiểu String, nếu truyền kiểu nhị phân thì cho Output= variant = một mảng kiểu Byte. Bắt tay( handshaking): + Break : thiết lập hoặc xoá tín hiệu. object.Break [ = value] value = true hoặc false. Khi set value= true thì thông số Break này sẽ gửi một tín hiệu break. Tín hiệu break trì hoãn việc truyền dữ liệu và đưa đường truyền vào trạng thái break tới khi mà value = false. + CDHolding: quyết định xem sự truyền này đến đâu bằng cách truy vấn đường CD( Carrier Detect). Carrier Detect là tín hiệu gửi từ modem tới máy tính kết nối với nó thông báo rằng nó đang online. Nếu giá trị = true thì nó đường CD đang ở mức cao, nếu = false thì đường dây này đang ở mức thấp. Tính chất này không có trong lúc thiết kế chỉ có trong khi chạy chương trình.Carrier Detect được biết như là Receive Line Signal Detect (RLSD). + CTSHolding: quết định khi nào gửi dữ liệu bằng cách truy vấn trạng thái đường Clear To Send (CTS). Thông thường tín hiệu CTS được gửi từ modem tới máy tính kết nối với nó để báo rằng đang quá trình truyền dữ liệu. Thuộc tính Readonly chỉ xuất hiện khi chạy chương trình. Đường Clear To Send dùng trong RTS/CTS (Request To Send/Clear To Send) bắt tay phần cứng. CTSHolding để tự tay dò đường Clear To Send để biết trạng thái của nó. 47 + DSRHolding: biết trạng thái của đường Data Set Ready (DSR). Tín hiệu Data Set Ready truyền từ modem tới máy tính nối với nó để thông báo rằng modem đã sẵn sàng hoạt động. Tính chất này dùng khi viết Data Set Ready/Data Terminal Ready handshaking routine cho máy Data Terminal Equipment (DTE)‐ máy trang bị đầu cuối dữ liệu. + DTREnable: tính chất này quyết định khi nào cho phép đường Data Terminal Ready (DTR) trong truyền thông. Tín hiệu DTR gửi từ máy tính tới modem để báo rằng máy tính sẵn sàng là nơi nhận dữ liệu. Khi DTREnable = true thì đường Data Terminal Ready set lên cao khi cổng mở, và thấp khi cổng đóng. Nếu DTREnable = false thì đường đó luôn mức thấp. Trong phần lớn trường hợp set đường Data Terminal Ready thành thấp để hang up telephone. + Handshaking: thiết lập và trả lại giao thức bắt tay phần cứng. object.Handshaking [ =value ]. Các giá trị của value: comNone 0 (Mặc định) Không bắt tay comXOnXOff 1 Bắt tay XON/XOFF comRTS 2 Bắt tay RTS/CTS (Request To Send/Clear To Send) comRTSXOnXOff 3 Dùng cả bắt tay Request To Send and XON/XOFF Bảng 1.7: Bảng thiết lập giao thức bắt tay Handshaking chỉ là giao thức truyền thông nội tại quyết định bởi dữ liệu nào được truyền từ cổng phần cứng tới bộ đệm nhận. Khi kí tự của dữ liệu tới cổng nối tiếp, thiết bị truyền thông sẽ chuyển nó vào trong bộ đệm nhận. Nếu không có bộ đệm dữ liệu hoặc cần đọc kí tự trực tiếp từ phần cứng, có thể mất dữ liệu bởi vì kí tự từ phần cứng đến rất nhanh. Giao thức Handshaking đảm bảo dữ liệu không bị mất, khi dữ liệu đến cổng quá nhanh thì thiết bị truyền thông sẽ chuyển dữ liệu vào trong bộ đệm nhận. + RTSEnable: quyết định khi nào cho phép đường Request To Send (RTS), Tín hiệu RTS từ máy tính tới modem để yêu cầu được tryền dữ liệu. Khi RTSEnable = true thì đường RTS mức cao khi cổng mở, tích mức thấp khi cổng đóng. Và hiển nhiên khi RTSEnable thì đường RTS luôn mức thấp.RTS dùng trong RTS/CTS hardware handshaking. RTSEnable cho phép dò đường RTS khi cần biết tình trạng của đường này. 48 + Đoạn chương trình sử dụng MSCom để bắt dữ liệu biểu quyết điện tử số từ cổng( port 1) của CCU: Private Sub MSComm1_OnComm() Dim dem As String Dim ii As Integer Dim CoMat As Integer Dim TanThanh As Integer Dim KhongTanThanh As Integer Dim KhongThamGia As String Dim KhongBieuQuyet As Integer If MSComm1.CommEvent = comEvReceive Then dem = MSComm1.Input ii = Asc(dem) 'Neu doc vao ma ket thuc=27 hoac xuong dong=32 thi bo qua 'Doc ky tu tiep theo If (ii = 27) Then ChuoiThu = "" dem = MSComm1.Input ii = Asc(dem) End If If (ii = 32) Then dem = MSComm1.Input ii = Asc(dem) End If 'Chuoi thu duoc ChuoiThu = ChuoiThu & Chr(ii) End If 'Reset bien If Check = 1 Then Me.LblThoiGian.Caption = "00:00" Me.lblCoMat.Caption = "0" Me.lblTanThanh.Caption = "0" Me.lblKhongTanThanh.Caption = "0" Me.lblKhongBieuQuyet.Caption = "0" Me.lblCoMat_PT.Caption = "0%" Me.lblTanThanh_PT.Caption = "0%" Me.lblKhongTanThanh_PT.Caption = "0%" Me.lblKhongBieuQuyet_PT.Caption = "0%" End If 'Xu ly thoi gian 49 Me.LblThoiGian.Caption = Mid(ChuoiThu, 4, 4) Phut = Mid(Me.LblThoiGian.Caption, 1, 2) Giay = Mid(Me.LblThoiGian.Caption, 3, 2) Me.LblThoiGian.Caption = Phut & ":" & Giay 'Xu ly chuoi thu duoc If Len(ChuoiThu) = 28 Then CoMat = CInt(Trim(Mid(ChuoiThu, 8, 4))) Me.lblCoMat.Caption = CoMat TanThanh = CInt(Trim(Mid(ChuoiThu, 12, 4))) Me.lblTanThanh.Caption = TanThanh KhongTanThanh = CInt(Trim(Mid(ChuoiThu, 16, 4))) Me.lblKhongTanThanh.Caption = KhongTanThanh KhongBieuQuyet = CInt(Trim(Mid(ChuoiThu, 20, 4))) + Trim(Mid(ChuoiThu, 24, 4)) Me.lblKhongBieuQuyet.Caption = KhongBieuQuyet 'Tinh phan tram bieu quyet Me.lblCoMat_PT.Caption = Round(CoMat * 100 / 493, 2) & "%" Me.lblTanThanh_PT.Caption = Round(TanThanh * 100 / 493, 2) & "%" Me.lblKhongTanThanh_PT.Caption = Round(KhongTanThanh * 100 / 493, 2) & "%" Me.lblKhongBieuQuyet_PT.Caption = Round(KhongBieuQuyet * 100 / 493, 2) & "%" End If 50 Sử dụng Access 97 để thiết kế cơ sở dữ liệu như sau: - Cơ sở dữ liệu đại biểu Table/Delegate: Hình 4.4: Cơ sở dữ liệu đại biểu - Cơ sở dữ liệu các tỉnh, thành phố.Table\ GroupID: Hình 4.5: Cơ sở dữ liệu các tỉnh, thành phố 51 4.4 Kết quả ghép nối giữa máy tính với bộ điều khiển trung tâm: Toàn cảnh phiên họp Quốc hội: Hình 4.6: Toàn cảnh phiên họp Quốc hội Toàn cảnh hệ thống biểu quyết điện tử số: 52 Hình 4.7: Hệ thống biểu quyết tại Hội trường Bộ Quốc phòng Màn hình điều khiển hệ thống biểu quyết điện tử số: Hình 4.8: Giao diện điều khiển microphone và biểu quyết 53 Phần mềm biểu quyết điện tử được xây dựng bằng ngôn ngữ Visual Basic 6, cơ sở dữ liệu đại biểu được xây dựng bằng Access 97 với các tính năng chính sau: 1. Tra cứu thông tin Đại biểu Quốc hội: Hình 4.9: Tra cứu thông tin đại biểu 2.Hiển thị Danh sách đăng ký phát biểu: Hình 4.10: Hiển thị danh sách đăng ký phát biểu 54 3. Hiển thị kết quả biểu quyết: Hiển thị kết quả biểu quyết khởi tạo biểu quyết: Hình 4.11: Kết quả bắt đầu biểu quyết Hiển thị kết quả biểu quyết sau khi hết thời gian biểu quyết: Hình 4.12:Kết quả biểu quyết khi hết thời gian biểu quyết 55 KẾT LUẬN Bản luận văn đi sâu nghiên cứu hệ thống biểu quyết điện tử số DCN với nguyên lý hoạt động, định tuyến âm thanh, thông số truyền thông, giao thức truyền giữa bộ điều khiển trung tâm CCU với các thiết bị điều khiển từ xa. Luận văn nêu tổng quan hệ thống biểu quyết số và nêu bật được các đặc tính truy cập hệ thống, các loại biểu quyết điện tử, các bước thực hiện điều khiển microphone, biểu quyết điện tử số và chuẩn ghép nối RS 232C, đi sâu tìm hiểu trình điểu khiển MS Com trong ngôn ngữ Visual Basic 6. Đặc biệt, việc xây dựng phần mềm biểu quyết trong luận văn đã hiển thị được kết quả biểu quyết điện tử của hệ thống biểu quyết điện tử số DCN tại phiên họp của Quốc hội, Danh sách đăng ký đại biểu Quốc hội, truy cập thông tin đại biểu Quốc hội. Việc thực hiện ghép nối giữa máy tính với hệ thống biểu quyết số qua cổng port 1 của bộ điều khiển trung tâm trong hệ thống biểu quyết số tại hội trường Bộ Quốc phòng sử dụng trình điều khiển MS Com của Visual Basic 6. Trong luận văn này xây dựng phần mềm biểu quyết căn bản đã hiển thị được kết quả biểu quyết, danh sách đăng ký phát biểu. Vì vậy, cần hoàn thiện phần mềm biểu quyết thêm các tính năng về cơ sở dữ liệu đại biểu có kèm theo hình ảnh, lưu trữ chi tiết kết quả biểu quyết, tìm kiếm đại biểu theo tỉnh, thành phố, tên đại biểu v.v… làm cho phần mềm hoàn thiện hơn. Trên cơ sở nghiên cứu nguyên lý cơ bản của hệ thống biểu quyết điện tử số, hướng nghiên cứu tiếp của đề tài luận văn là thiết kế mạch biểu quyết ứng dụng thực tế. 56 TÀI LIỆU THAM KHẢO Tiếng Việt 1. Phạm Văn Ất (2008), Hướng dẫn sử dụng Access 2003 - 2007, NXB Giao thông vận tải, Hà Nội. 2. Phạm Thị Ngọc Mai (2005), Microsoft Visual Basic 6.0 & lập trình cơ sở dữ liệu, NXB Lao động - Xã hội, Hà Nội. 3. Trần Quang Vinh (2008), Cấu trúc máy vi tính, NXB Đại học Quốc gia Hà Nội, Hà Nội. Tiếng Anh 4. Bosch Security System (2003), General Remote Interface Description. 5. Bosch Security System (2003), AT Remote Interface Description. 6. Bosch Security System (2003), VT Remote Interface Description. 7. Bosch Security System (2003), MM Remote Interface Description. 8. Philips Comunication, Security & Image (2002), Digital Congress Network DCN Instalation & Operating Manual. 9. Bosch Security System (2003), SC &SI Remote Interface Description. 10. MSDN Library (2001), Visual Tools and Languages/ Visual Studio 6.0 Documentation / Visual Basic Documentation / Reference/ Control Reference / ActiveX Control/ MSComm Control. 57 PHỤ LỤC Khai báo các biến giá trị theo hệ thống biểu quyết số: Sub InitCommandTable() CmdTable(cmdMicroOn) = "$1" CmdTable(cmdMicroOff) = "$2" CmdTable(cmdAllMicroOff) = "$3" CmdTable(cmdPrioMicroOn) = "$4" CmdTable(cmdPrioMicroOff) = "$5" CmdTable(cmdRemainSpeech) = "$6" CmdTable(cmdRequestOn) = "&1" CmdTable(cmdRequestOff) = "&2" CmdTable(cmdAllRequestOff) = "&3" CmdTable(cmdVoteIndYes) = "#1" CmdTable(cmdVoteIndNo) = "#2" CmdTable(cmdVoteIndAbstain) = "#3" CmdTable(cmdVoteIndNoVoted) = "#4" CmdTable(cmdVoteTotal) = "%1" CmdTable(cmdVoteTotalResYes) = "%2" CmdTable(cmdVoteTotalResNo) = "%3" CmdTable(cmdVoteTotalResAbstain) = "%4" CmdTable(cmdVoteTotalResNoVoted) = "%5" CmdTable(cmdCardIn) = "!1" CmdTable(cmdCardOut) = "!2" End Sub Sub GetCommand() Dim CRLF As String Dim tmp As TCmd Dim i As Integer Dim j As Integer Dim s As String Dim n As Integer Dim cmd As String Dim Idx As Integer CRLF = Chr(13) j = InStr(InputBuffer, CRLF) While j > 0 s = Left(InputBuffer, j) InputBuffer = Right(InputBuffer, Len(InputBuffer) - j) n = Len(s) 58 For i = 1 To n - 2 cmd = Mid(s, i, 2) Select Case cmd Case CmdTable(cmdMicroOn) tmp.CmdID = cmdMicroOn tmp.Seat = Val(Mid(s, i + 2, 4)) tmp.Index = ConvertToInt(Mid(s, i + 6, 4)) SendCmdToAllUser tmp Exit For Case CmdTable(cmdMicroOff) tmp.CmdID = cmdMicroOff tmp.Seat = Val(Mid(s, i + 2, 4)) tmp.Index = ConvertToInt(Mid(s, i + 6, 4)) SendCmdToAllUser tmp Exit For Case CmdTable(cmdVoteIndYes) Idx = ConvertToInt(Mid(s, i + 2, 4)) If Idx < MaxDelegate - 1 Then VoteIndTable(Idx) = cmdVoteIndYes End If Exit For Case CmdTable(cmdVoteIndNo) Idx = ConvertToInt(Mid(s, i + 2, 4)) If Idx < MaxDelegate - 1 Then VoteIndTable(Idx) = cmdVoteIndNo End If Exit For Case CmdTable(cmdVoteIndAbstain) Idx = ConvertToInt(Mid(s, i + 2, 4)) If Idx < MaxDelegate - 1 Then VoteIndTable(Idx) = cmdVoteIndNoVoted End If Exit For Case CmdTable(cmdVoteIndNoVoted) Idx = ConvertToInt(Mid(s, i + 2, 4)) If Idx < MaxDelegate - 1 Then VoteIndTable(Idx) = cmdVoteIndNoVoted End If Exit For Case CmdTable(cmdVoteTotal) tmp.CmdID = cmdVoteTotal tmp.Total = Val(Mid(s, i + 2, 4)) SendCmdToAllUser tmp Exit For Case CmdTable(cmdVoteTotalResYes) tmp.CmdID = cmdVoteTotalResYes 59 tmp.Total = Val(Mid(s, i + 2, 4)) SendCmdToAllUser tmp Exit For Case CmdTable(cmdVoteTotalResNo) tmp.CmdID = cmdVoteTotalResNo tmp.Total = Val(Mid(s, i + 2, 4)) SendCmdToAllUser tmp Exit For Case CmdTable(cmdVoteTotalResAbstain) tmp.CmdID = cmdVoteTotalResAbstain tmp.Total = Val(Mid(s, i + 2, 4)) SendCmdToAllUser tmp Exit For Case CmdTable(cmdCardIn) tmp.CmdID = cmdCardIn tmp.Card = Val(Mid(s, i + 2, 4)) tmp.Seat = Val(Mid(s, i + 6, 4)) tmp.Index = ConvertToInt(Mid(s, i + 10, 4)) SendCmdToAllUser tmp Exit For Case CmdTable(cmdCardOut) tmp.CmdID = cmdCardOut tmp.Card = Val(Mid(s, i + 2, 4)) tmp.Seat = Val(Mid(s, i + 6, 4)) tmp.Index = ConvertToInt(Mid(s, i + 10, 4)) SendCmdToAllUser tmp Exit For End Select Next i j = InStr(InputBuffer, CRLF) Wend End Sub Sub SendCmdToAllUser(cmd As TCmd) Dim i As Integer For i = 0 To cUser - 1 SendCmdToUser i, cmd Next i End Sub Sub SendCmdToUser(uid As Integer, cmd As TCmd) Dim n As Integer n = UserCmds(uid).Pointer + UserCmds(uid).Counter If n >= BufferLen Then UserCmds(uid).Buffer(n - BufferLen) = cmd Else UserCmds(uid).Buffer(n) = cmd End If 60 UserCmds(uid).Counter = UserCmds(uid).Counter + 1 If UserCmds(uid).Counter = BufferLen Then UserCmds(uid).Counter = UserCmds(uid).Counter - 1 UserCmds(uid).Pointer = UserCmds(uid).Pointer + 1 If UserCmds(uid).Pointer = BufferLen Then UserCmds(uid).Pointer = 0 End If End If End Sub Sub SendMsgToUser(uid As Integer, Sender As String, Msg As String) Dim n As Integer n = UserMsgs(uid).Pointer + UserMsgs(uid).Counter If n >= MaxMsgNote Then UserMsgs(uid).Sender(n - MaxMsgNote) = Sender UserMsgs(uid).MsgNote(n - MaxMsgNote) = Msg Else UserMsgs(uid).Sender(n) = Sender UserMsgs(uid).MsgNote(n) = Msg End If UserMsgs(uid).Counter = UserMsgs(uid).Counter + 1 If UserMsgs(uid).Counter = MaxMsgNote Then UserMsgs(uid).Counter = UserMsgs(uid).Counter - 1 UserMsgs(uid).Pointer = UserMsgs(uid).Pointer + 1 If UserMsgs(uid).Pointer = MaxMsgNote Then UserMsgs(uid).Pointer = 0 End If End If End Sub Function ConvertToInt(s As String) As Integer Dim ch As String Dim tmp As Integer Dim rate(5) As Integer Dim n As Integer Dim i As Integer Dim x As Integer rate(4) = 1 rate(3) = 16 rate(2) = 16 * 16 rate(1) = 16 * 16 * 16 tmp = 0 s = Trim(s) If s = "????" Then ConvertToInt = 0 Exit Function End If 61 n = Len(s) For i = n To 1 Step -1 x = Asc(Mid(s, i, 1)) - Asc("0") If x >= 0 And x <= 15 Then tmp = tmp + x * rate(i) Else tmp = 0 Exit For End If Next i If tmp > 255 And tmp < 384 Then tmp = tmp - 128 End If If tmp > 511 And tmp < 640 Then tmp = tmp - 256 End If If tmp > 767 Then tmp = tmp - 384 End If ConvertToInt = tmp End Function Function SendCmdToFile(uid As Integer, cmd As TCmd) As Boolean Dim hf As Integer Dim fn As String On Error Resume Next fn = UserCmdFileName(uid) If Trim(fn) = "" Then SendCmdToFile = False Exit Function End If If Dir(fn) = "" Then hf = FreeFile Open fn For Binary As hf 'Len = LenB(cmd) Put hf, , cmd Close hf SendCmdToFile = True Else SendCmdToFile = False End If End Function Function SendMsgToFile(uid As Integer, Sender As String, Msg As String) As Boolean Dim hf As Integer Dim fn As String Dim s As String * 60 62 Dim s1 As String * 255 On Error Resume Next s = Trim(Sender) s1 = Trim(Msg) fn = UserMsgFileName(uid) If Trim(fn) = "" Then SendMsgToFile = False Exit Function End If If Dir(fn) = "" Then hf = FreeFile Open fn For Binary As hf Put hf, , s Put hf, , s1 Close hf SendMsgToFile = True Else SendMsgToFile = False End If End Function Sub InitComm(ComObj As Control, ComPort As Integer, Setting As String) On Error Resume Next ComObj.CommPort = ComPort ComObj.Settings = UCase(Setting) ComObj.InputLen = 0 ComObj.PortOpen = True InputBuffer = "" End Sub Sub ComEvent(ComObj As MSComm) Dim s As String s = ComObj.Input InputBuffer = InputBuffer & s GetCommand 'InputBuffer End Sub Đoạn chương trình hiển thị Danh sách đăng ký phát biểu: Private Sub cmdRegister_Click() Dim tmp As TCmd Dim i As Integer Dim c As Integer If tCardNumber.Text = "" Then Exit Sub If IndexToSeat(Val(tCardNumber.Text)) = 0 Then Exit Sub 63 c = lbRequestOn.ListCount For i = 0 To c - 1 If Val(tCardNumber.Text) = LRequestIndex(i).Index And _ Val(tOrder.Text) > c Then tOrder.Text = c + 1 tCardNumber.Text = "" tCardNumber.SetFocus Exit Sub End If Next i ' Request On tmp.CmdID = cmdRequestOn tmp.cmdIndex = Val(tOrder.Text) - 1 tmp.Index = Val(tCardNumber.Text) tmp.Seat = IndexToSeat(Val(tCardNumber.Text)) SendCmdToAllUser tmp 'lblInfo.Caption = "" tCardNumber.Text = "" tCardNumber.SetFocus End Sub Private Sub Form_Activate() Dim c As Integer c = lbRequestOn.ListCount ' tCardNumber.SetFocus tOrder.Text = Trim(Str(c + 1)) End Sub Private Sub lbMicroOn_GotFocus() If Me.Visible Then lbMicroOn.ListIndex = -1 tCardNumber.SetFocus End If End Sub Private Sub lbrequeston_GotFocus() If Me.Visible Then tCardNumber.SetFocus End If End Sub Private Sub SSFrame2_Click() 64 End Sub Private Sub tCardNumber_Change() Dim dInfo As TDelegate Dim s As String Dim i As Integer If Len(Trim(tCardNumber.Text)) > 3 Or _ Val(tCardNumber.Text) > MaxDelegate Or _ Val(tCardNumber.Text) < 0 Then tCardNumber.Text = "" ' lblInfo.Caption = "" Exit Sub End If For i = 1 To Len(tCardNumber.Text) If Asc(Mid(tCardNumber.Text, i, 1)) < Asc("0") Or _ Asc(Mid(tCardNumber.Text, i, 1)) > Asc("9") Then tCardNumber.Text = "" ' lblInfo.Caption = "" Exit Sub End If Next i If IndexToSeat(Val(tCardNumber.Text)) > 0 Then i = DelegateSearch(Val(tCardNumber.Text)) If i = -1 Then ResetDelegateInfo dInfo Else dInfo = DelegateTable(i) End If s = Padr(Trim(dInfo.DelegateName), 25, " ") + _ Padr(Trim(dInfo.GroupName), 25, " ") + _ "Sè ghÕ : " + Padr(Trim(Str(IndexToSeat(dInfo.CardNumber))), 4, " ") + _ " Micro : " + Trim(Str(STML(IndexToSeat(dInfo.CardNumber)))) 'lblInfo.Caption = s Else ' lblInfo.Caption = "" End If End Sub Private Sub tCardNumber_KeyDown(KeyCode As Integer, Shift As Integer) Dim tmp As TCmd Dim Idx As Integer Dim i As Integer Dim Shiftdown As Integer Dim c As Integer ' Arrow Up was pressed If KeyCode = vbKeyUp And lbRequestOn.ListCount > 0 Then If lbRequestOn.ListIndex = -1 Then lbRequestOn.ListIndex = 0 65 ElseIf lbRequestOn.ListIndex > 0 Then lbRequestOn.ListIndex = lbRequestOn.ListIndex - 1 End If End If ' Arrow Down was pressed If KeyCode = vbKeyDown And lbRequestOn.ListCount > 0 Then If lbRequestOn.ListIndex = -1 Then lbRequestOn.ListIndex = 0 ElseIf lbRequestOn.ListIndex < lbRequestOn.ListCount - 1 Then lbRequestOn.ListIndex = lbRequestOn.ListIndex + 1 End If End If ' Home key was pressed If KeyCode = vbKeyHome And lbRequestOn.ListCount > 0 Then lbRequestOn.ListIndex = 0 End If ' End key was pressed If KeyCode = vbKeyEnd And lbRequestOn.ListCount > 0 Then lbRequestOn.ListIndex = lbRequestOn.ListCount - 1 End If If Trim(tCardNumber.Text) = "" Or _ Val(tCardNumber.Text) > 999 Then tCardNumber.Text = "" Exit Sub End If Shiftdown = (Shift And vbShiftMask) > 0 Idx = Val(tCardNumber.Text) c = frmTMicro.lbRequestOn.ListCount ' Delete key was pressed ' Xoa mot dong trong Danh sach dai bieu DANG KY PHAT BIEU If Not Shiftdown And KeyCode = vbKeyDelete Then If c > 0 Then For i = 0 To lbRequestOn.ListCount - 1 If Idx = LRequestIndex(i).Index Then 'off current request tmp.CmdID = cmdRequestOff tmp.cmdIndex = Idx tmp.Index = Val(tCardNumber.Text) tmp.Seat = IndexToSeat(tmp.Index) SendCmdToAllUser tmp ' lblInfo.Caption = "" tCardNumber.Text = "" 66 tCardNumber.SetFocus End If Next i End If End If ' Shift + Delete key pressed ' Xoa mot dong trong Danh sach dai bieu PHAT BIEU If Shiftdown And KeyCode = vbKeyDelete And _ lbMicroOn.ListCount 0 Then For i = 0 To lbMicroOn.ListCount - 1 If Idx = LMicroIndex(i, 0) Then 'off current micro tmp.CmdID = cmdMicroOff tmp.Index = LMicroIndex(i, 0) tmp.Seat = LMicroIndex(i, 1) SendCmdToAllUser tmp tCardNumber.Text = "" tCardNumber.SetFocus Exit For End If Next i End If ' shift + Insert ket was pressed If Shiftdown And KeyCode = vbKeyInsert Then For i = 0 To lbMicroOn.ListCount - 1 If Idx = LMicroIndex(i, 0) Then tCardNumber.Text = "" Exit Sub End If Next i ' On new micro tmp.CmdID = cmdMicroOn tmp.Seat = IndexToSeat(Idx) tmp.Index = Val(tCardNumber.Text) SendCmdToAllUser tmp tCardNumber.Text = "" tCardNumber.SetFocus End If End Sub Private Sub tOrder_Change() Dim c As Integer Dim i As Integer 67 c = frmTMicro.lbRequestOn.ListCount If Len(tOrder.Text) > 2 Or _ Val(tOrder.Text) > 99 Or _ Val(tOrder.Text) <= 0 Or _ Val(tOrder.Text) > c + 1 Then tOrder.Text = Trim(Str(c + 1)) tOrder.SelStart = 0 tOrder.SelLength = 3 Exit Sub End If For i = 1 To Len(tOrder.Text) If Asc(Mid(Trim(tOrder.Text), i, 1)) < Asc("0") Or _ Asc(Mid(Trim(tOrder.Text), i, 1)) > Asc("9") Then tOrder.Text = Trim(Str(c + 1)) tOrder.SelStart = 0 tOrder.SelLength = 3 Exit Sub End If Next i End Sub Private Sub tOrder_GotFocus() tOrder.SelStart = 0 tOrder.SelLength = 3 End Sub Đoạn chương trình hiển thị thông tin đại biểu: Private Sub Form_Load() Dim s As String For i = 0 To TotalDelegate - 1 s = Padr(DelegateTable(i).DelegateName, 25, " ") + _ Padr(DelegateTable(i).GroupName, 25, " ") + _ Padr(Str(DelegateTable(i).CardNumber), 4, " ") lDelegate.AddItem s Next i End Sub

Các file đính kèm theo tài liệu này:

  • pdfLUẬN VĂN-NGHIÊN CỨU HỆ THỐNG BIỂU QUYẾT ĐIỆN TỬ SỐ.pdf
Tài liệu liên quan