I. Mô hình lớp
4. Thiết kế giao diện một số Form chính
4.1 Form đăng nhập
Các chức năng chính của hệ thống chỉ được sử dụng khi người dùng đăng nhập thành công. Vì thế, khi bắt đầu chạy chương trình thì hệ thống luôn hiện ra trang đăng nhập để người dùng đăng nhập vào hệ thống.
Người dùng phải ghi đầy đủ thông tin trên hai textField:
Account và Password. Click để truy cập vào hệ thống.
Khi công việc đăng nhập của người dùng không thành công (do sai tên hay mật khẩu) thì hệ thống sẽ hiện ra thông báo sau:
Người dùng click vào nút để thực hiện lại việc đăng nhập. Khi đăng nhập thành công, thì người dùng mới được vào bên trong và làm việc với hệ thống.
* Chức năng Nhập dữ liệu của chương trình sắp thời khoá biểu bao gồm các thao tác sau: nhập môn học, nhập lớp, nhập giảng viên, nhập phòng, xét ràng buộc môn học (với môn học vừa nhập sẽ được thực hành ở phòng máy nào). Các chức năng này hỗ trợ người dùng trong việc nhập thời khóa biểu từ cấp trên đưa xuống.
Chú ý: Toàn bộ công việc nhập dữ liệu cho Thời khóa biểu cần được tiến hành xong trước khi tiến hành việc xếp Thời khóa biểu.
*Nhập môn học:
Khi nhấn nút Nhập môn học sẽ xuất hiện cửa sổ trên, người dùng phải nhập đầy đủ thông tin về môn học như: mã môn học, tên môn học,
tín chỉ lý thuyết, tín chỉ thực hành. Sau đó nhấn nút dữ liệu sẽ được chèn xuống cơ sở dữ liệu, đồng thời xuất hiện thông báo.
Nhấn để thực hiện lại việc nhập thông tin về môn học. Nếu bạn muốn xoá thông tin môn học nào thì check vào hàng
tương ứng trên bảng sau đó nhấn nút để thực hiện xoá thông tin môn học đó.
Sau khi thực hiện xong thao tác nhập môn học, muốn thoát khỏi giao diện này bạn nhấn nút để kết thúc.
* Tương tự cho cửa sổ nhập Lớp, nhập Giảng viên, nhập Phòng, xét Ràng buộc môn học…
* Khi chọn xét ràng buộc Giảng Viên sẽ hiển thị giao diện sau:
Ví dụ: Thầy Vũ Văn Nam bận vì lý do riêng vào thứ hai (tiết1-5) và thứ 6 (tiết 6-10) sẽ check vào các ô tương ứng như sau: Khi nhấn nút
sẽ hỏi có muốn lưu xuống cơ sở dữ liệu không.
Nếu muốn nhập lại ràng buộc, nhấn . Ngược lại khi nhấn nút sẽ lưu xuống cơ sở dữ liệu:
Khi nhấp nút sẽ xuất hiện cửa sổ sau:
Người dùng sẽ nhập lịch học lý thuyết từ các thông tin mà chương trình hỗ trợ sẵn, nếu không có các thông tin về lớp, môn học, phòng hay giảng viên người dùng sẽ trở về các giao diện nhập lớp, nhập môn học, nhâp phòng, nhập giảng viên… để tiến hành nhập thêm các thông tin, rồi quay lại giao diện này thực hiện tiếp.
Khi đã nhập đầy đủ các thông tin yêu cầu, nếu môn học có thực hành thì phải phân giảng viên canh thực hành cho môn học đó. Đồng thời, với số lượng phòng hạn chế như hiện nay, giáo vụ có thể giảm số phòng thực hành cho từng lớp ứng với mỗi môn học có thực hành.
Nếu phòng học, thứ ngày và tiết học trong tuần đã được sắp trước đó thì khi nhấn nút sẽ hiển thị thông báo:
Nếu lớp học, thứ ngày và tiết học trong tuần đã được sắp trước đó thì khi nhấn nút sẽ hiển thị thông báo:
Nếu phòng học không đủ chỗ cho lớp học thì khi nhấn nút sẽ hiển thị thông báo:
Nếu giáo viên được sắp lịch đã bận khi thêm vào Bảng ràng buộc giảng viên, hoặc đã được sắp giờ dạy theo thứ ngày và tiết học trước đó thì khi nhấn nút sẽ hiển thị thông báo:
Nếu môn học có thực hành mà khi nhập giáo vụ quên phân công thực hành, khi nhấn nút sẽ hiển thị thông báo.
Chọn thì môn học đó sẽ không được phân thời gian thực hành. Chọn thì sẽ quay lại phân công thực hành như giao diện sau:
Sau khi nhập đầy đủ các thông tin về lịch và phân công giảng viên canh thực hành, nhấn nút bên dưới để lưu xuống cơ sở dữ liệu.
* Cập nhật phân công thực hành:
Nếu giáo vụ muốn cập nhật lại danh sách giảng viên canh thực hành hay số phòng thực hành, phải đánh dấu check vào tương ứng với dòng muốn cập nhật. Đối với môn học không có thực hành mà giáo vụ click vào dòng lịch đó sẽ hiển thị thông báo.
Ngược lại đối với môn học có thực hành, nếu muốn thay đổi giảng viên canh thực hành nào, thì check vào tên giảng viên đó, nhấn nút
để xoá đi giảng viên đó trong danh sách giảng viên canh thực hành, nhấn sẽ hiện ra giao diện :
Nếu muốn thay đổi thời khóa biểu của môn thực hành nào, thì check vào tên môn đó, nhấn nút để xoá đi lịch thực hành của môn đó trong danh sách thực hành, kèm theo đó ràng buộc giảng viên canh thực hành cũng được xóa.
Nếu muốn sắp thời khóa biểu thực hành cho môn nào , thì check vào tên môn đó, sau đó điền đầy đủ thông tin cần thiết kèm theo ràng buộc như lịch học lý thuyết.
Nhấn nút để lưu vào cơ sở dữ liệu, nếu thành công thì hiện thông báo:
Nhấn nút sau đó nhấn nút để trở về giao
diện trước.
* Hiển thị lịch học lý thuyết:
Bên cạnh đó, người dùng còn có thể chọn để xem lại các thông tin thời khóa biểu của giảng viên, lớp, phòng từ thời khóa biểu sau khi nhập đầy đủ các thông tin và lưu xuống cơ sở dữ liệu rồi.
Từ cửa sổ này hay với chức năng Xem thời khóa biểu từ giao diện trước, người dùng có thể chọn xem Thời khóa biểu theo Phòng, theo Giảng viên, theo Lớp…bằng thao tác click chuột vào những Tab sau, có trên giao diện.
5. Công cụ cài đặt:
Phần mềm “Quản lý thời khóa biểu” được phát triển sử dụng các công cụ và môi trường sau:
- Môi trường lập trình:
+ Microsoft Visual Studio 2005: là bộ công cụ phát triển phần mềm mạnh, có thể xây dựng trọn vẹn giải pháp tổng thể. Đây cũng là bộ công cụ hỗ trợ hoàn toàn bộ mã Unicode.
Visual Studio 2005 dựa trên nền tảng NET framework với mục tiêu mọi ứng dụng viết bằng .NET chạy được mọi nơi độc lập với platform như phần cứng, hệ điều hành . Các máy tính chỉ cần có .NET framework là chạy được ứng dụng mà không cần phải dịch lại. Ứng dụng bằng .NET có thể viết bằng bất cứ ngôn ngữ nào như: VB, C++, C#... một cách dễ dàng ngay cả trong cùng một ứng dụng.
- Ngôn ngữ lập trình C#:
+ Ngôn nữ C# khá đơn giản,chỉ khoảng 80 từ khóa và hơn mười mấy kiểu dữ liệu được xây dựng sẵn. Tuy nhiên, ngôn ngữ C# bao gồm tất cả những hỗ trợ cấu trúc, thành phần, lập trình hướng đối tượng.
- Cơ sở dữ liệu:
+ Microsoft SQL Server 2005: Đây là một hệ quản trị CSDL mạnh, đảm bảo tính an toàn dữ liệu cao, có thể lưu trữ lượng dữ liệu lớn, đảm baot thông tin được an toàn.
Phiên bản SQL Server 2005 hỗ trợ hoàn toàn việc sử dụng tiếng Việt theo chuẩn Unicode.
Chương 4: Thực nghiệm, đánh giá tổng kết và hướng phát triển.
4.1 Thực nghiệm:
Chương trình đã được thử để sắp xếp thời khóa biểu của các khoa trong Đại học Vinh….
Đồng thời, chương trình cũng đã thực hiện để thử sắp xếp thời khóa biểu riêng cho khoa Công nghệ thông tin trường Đại Học Vinh và các lớp thuộc khoa khác có môn học liên quan đến khoa công nghệ thông tin.
4.2 Kết quả:
Chương trình có khả năng sắp xếp được thời khóa biểu của các môn học lý thuyết thực hành thỏa mãn hầu hết các ràng buộc, như ràng buộc giảng viên, ràng buộc phòng, và thời gian học … đã được đề cập đến khi nhập dữ liệu.
Chương trình còn có thể thống kê được các môn học có tín chỉ thực hành đã được sắp xếp lịch và phòng học để thực hành hay chưa.
Hệ thống đã giúp Giáo Vụ khoa có thể sắp lịch thực hành cho các lớp vào đầu mỗi học kỳ, hầu hết các chức năng sau khi xử lý xong đều hoạt động tốt, đáp ứng được yêu cầu đặt ra.
Bước đầu giải quyết được tình trạng thực tế của khoa CNTT là thiếu phòng thực hành và thiếu giảng viên canh thực hành.
Với số liệu thực nghiệm có được ( từ 4 học kỳ) phương pháp thể hiện tính khả thi.
4.3 Đánh giá:
Kết quả thực hiện của chương trình dùng để sắp xếp thời khóa biểu học lý thuyết và thực hành là rất khả quan, tốc độ và kết quả chấp nhận được.
Tuy nhiên trong phần sắp thời khóa biểu thực hành, khuyến nghị người dùng nên cố gắng sắp xếp thời gian rải đều cho phòng học thực hành bắt đầu ngay từ đầu cho đến cuối học kỳ, tránh tình trạng các phòng thực hành đầu kỳ thì vắng nhưng đến giữa cuối kỳ thì lại quá tải. Vì điều kiện cơ sở vật chất và trang thiết bị tốn kém nên phòng thực hành là hạn chế.
4.4 Hướng phát triển trong tương lai:
+ Sắp thời khóa biểu thực hành theo nhiều mức độ ưu tiên hơn( ưu tiên cho giảng viên….).
+ Trong tương lai, phần mềm cần được kết hợp với giải thuật di truyền để cho ra đời sản phẩm: “Phần mềm sắp xếp thời khóa biểu thực hành tự động”, với thời gian sắp xếp có thể kéo dài hơn (khoảng hơn 20 phút) nhưng đảm bảo ít sai sót và tối ưu hơn.
+ Cũng có thể áp dụng các thuật toán trong chương trình để cho ra đời các sản phẩm phần mềm sắp xếp thời khóa biểu cho các trường cao đẳng, và các trường THPT …
Tài liệu tham khảo
[1] Phạm Hữu Khang, Trần Tiến Dũng, C# 2005 Lập trình cơ sở dữ liệu, Nhà xuất bản Lao Động Xã Hội. 2008.
[2] Windows Form Programing With C#, Version 1.0 © 2007 Aptech Linited.