Mục l ục
Lời cảm ơn.5
I. Giới thiệ u .6
1. Tác giả .6
2. Chương trình ML Dict .6
3. Giới thiệ u chức năng.7
 Chức năng tra từ, phát âm .7
 Chức năng thêm/bớt từ đi ển .7
 Chức năng ghi nhớ từ vừa tra: .7
 Chức năng dị ch văn bản .7
 Chức năng trợ giúp .7
 Các tùy chọn .8
 Lưu cấu hình cho phiên làm vi ệc sau. .8
II. Hướng dẫn sử dụng: .8
1. Sử dụng me nus: .8
1.1. Me nu Từ Đi ể n: .8
1.2. Me nu Tùy Chỉnh .9
1.3. Me nu Công Cụ .9
1.4. Me nu Trợ Giúp .9
2. Hướng dẫn tra từ. .10
3. Tạo các file dữ li ệ u cho từ đi ển. .11
Lưu ý: .11
4. Cài thê m từ đi ể n .12
5. Gỡ bớt từ đi ể n .12 
6. Tra từ online .13
7. Trợ giúp .13
7.1. Giới thiệ u chương trình: .13
7.2. Hướng dẫn sử dụng: .13
III. Các kỹ thuật cài đặt .14
1. Tổ chức dữ li ệ u .14
a. Đánh giá .14
b. Giải pháp. .15
2. Cách thức tra từ .16
3. Cách thức xử lý v ấn đ ề load danh sách .16
a. Đánh giá. .16
b. Giải pháp .17
4. Me nu động.18
a. Ý tưởng.18
b. Giải pháp. .18
5. Đối sánh chuỗi, tìm ki ế m .19
a. Đánh giá .19
b. Giải pháp. .19
6. Phát âm .20
7. Tra hình minh họa.21
a. Phân tích. .21
b. Kế t quả thực hi ệ n. .21
8. Dịch văn bản online .23
a. Phân tích. .23
b. Kế t quả thực hi ệ n . .23
IV. Những hạn ch ế và đ ề xuất giải pháp .24 
1. Khởi động chậm .24
2. Phát âm không chuẩn.24
V. Những chức năng chưa thực hi ện được .25
1. Thiế u chứ c năng thêm, xóa, s ửa .25
a. Những trở ngại khi thê m từ .25
b. Những trở ngại khi xóa từ .26
c. Những trở ngại khi sửa từ .27
2. Thiế u chứ c năng Click and See: .27
VI. Tài liệ u tham khảo .28
1. Bài giảng chuyê n đ ề CNPM 1 – Lập Trình Hi ệ n Đại .28
2. Bài viế t v ề s ản phẩm sp dict .28
3. Phát âm
(trở về)
.28
4. Lớp Ope nFileDialogEX. .28
5. Dịch văn bản online .29
6. Hướng dẫn thao tác với hastable .29
VII. Lời kết .29
                
              
                                            
                                
            
 
            
                
29 trang | 
Chia sẻ: netpro | Lượt xem: 1887 | Lượt tải: 1
              
            Bạn đang xem trước 20 trang tài liệu Đề tài Từ điển đa ngôn ngữ trên PocketPC ( ML Dict), để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
h – Đỗ Thị Hồng Thu. 5 | 2 9 
Lời cảm ơn 
Lời đầu tiên, xin kính gửi tới thầy Trần Minh Triết và các thầy cô hướng dẫn thực 
hành môn Chuyên đề CNPM1- Lập Trình Hiện Đại, khoa Công Nghệ Thông Tin, 
trường ĐH KHTN, T.P Hồ Chí Minh lời chúc sức khỏe và lòng biết ơn sâu sắc. Xin 
cám ơn thầy đã tận tâm truyền đạt những kiến thức quý báu và tạo điều kiện để nhóm 
chúng em hoàn thành được đồ án này. 
Trong quá trình thực hiện đồ án, nhóm đã được tham khảo nhiều ý kiến thảo luận 
trên diễn đàn môn học, rất cảm ơn tinh thần học hỏi và đóng góp của các bạn. Ngoài 
ra, các bài viết hết sức bổ ích của các tác giả Bùi Đức Tiến, José Gallardo Salazar, 
Piyush Shah, Mahesh Chand … cũng có ý nghĩa với đồ án này rất nhiều. 
Xin chân thành cám ơn! 
Nhóm tác giả. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 6 | 2 9 
I. Giới thiệu 
1. Tác giả 
 Họ Tên: ................................. Nguyễn Minh Bình 
MSSV:.................................... 0612023 
Điện thoại: ............................ 0906 637 538 
Email: ..................................... ihnel48@gmail.com 
 Họ Tên: ................................. Đỗ Thị Hồng Thu 
MSSV:.................................... 0612400 
Điện thoại: ............................. 01677557054 
Email: ..................................... do.hongthu@yahoo.com.vn 
2. Chương trình ML Dict 
ML Dict (Multilaguage dictonary) là phần mềm từ điển đa ngôn ngữ cho pocket 
PC chạy trên hệ điều hành windows CE và .Net Compack Framwork. 
Phần mềm này được xây dựng theo yêu cầu đồ 
án của môn Chuyên Đề Công Nghệ Phần Mềm 1 
- Lập Trình Hiện Đại do thầy Trần Minh Triết và 
thầy Bùi Tấn Lộc phụ trách. Trong quá trình thực 
hiện đồ án này, nhóm đã gặp không ít khó khăn 
và bỡ ngỡ trong nhiều công đoạn do đây là lần 
đầu tiên nhóm làm việc với môi trường lập trình 
trên dot Net CF. Hơn nữa, từ điển là một loại 
phần mềm làm việc với những file dữ liệu lớn, 
yêu cầu phải xử lý nhanh. Những yêu cầu này thật 
sự khắt khe và không hề dễ dàng. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 7 | 2 9 
Mục đích của đồ án này là nhằm ứng dụng những lý thuyết, phương pháp đã học 
vào một phần mềm cụ thể để kiểm tra, trao dồi và học hỏi thêm những kỹ thuật mới. 
Những chức năng mà nhóm đã làm được vẫn chỉ dừng lại ở mức bình thường và chắc 
hẳn còn nhiều điều thiếu sót. Mọi ý kiến đóng góp, chia sẻ hay thắc mắc về chương 
trình sẽ luôn được đón nhận và ghi nhớ. 
3. Giới thiệu chức năng 
 Chức năng tra từ, phát âm 
Cũng như những phần mềm từ điển khác, ML Dict cũng có chức năng cơ bản 
là tra từ và phát âm từ vừa tra. 
Người dùng có thể lựa chọn nhiều cách khác nhau để tìm và tra một từ vựng. 
(xem hướng dẫn sử dụng). 
 Chức năng thêm/bớt từ điển 
Chương trình cho phép người dùng cài thêm từ điển mới hoặc bỏ bớt từ điển 
trong số những từ điển đã cài đặt tùy theo nhu cầu sử dụng. 
 Chức năng ghi nhớ từ vừa tra: 
Nhờ chức năng này, người dùng có thể nhanh chóng tra lại những từ vừa tra. 
Danh sách các từ vừa tra sẽ được lưu lại vào bộ nhớ. Theo đó, có thể dùng các 
phím mũi tên hoặc các button hình mũi tên ở góc trên, bên phải để tra. 
 Chức năng dịch văn bản 
Nếu máy đã được kết nối internet, chương trình 
cung cấp thêm một chức năng bổ ích là dịch văn 
bản online. Chức năng này hoạt động dựa trên sự 
hỗ trợ bởi công cụ dịch online của google. 
 Chức năng trợ giúp 
Nếu không hiểu hoặc không biết sử dụng chức 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 8 | 2 9 
năng nào đó của chương trình, người dùng có thể tham khảo thông tin trợ giúp 
qua menu Trợ giúp… 
 Các tùy chọn 
Với các tùy chọn được hỗ trợ, việc sử dụng 
chương trình sẽ trở nên rất linh động. Có thể lựa 
chọn cho phép chương trình tự động hiển thị phiên 
âm của từ đang tra, phát âm, hiện ví dụ, hình minh 
họa cho từ đó hay không… 
Nếu lựa chọn hiện danh sách từ tự động, mỗi khi user nhập từ cần tra vào ô 
nhập liệu, một danh sách các từ gần đúng sẽ được tự động hiển thị hỗ trợ cho 
người dùng tìm từ nhanh hơn. 
 Lưu cấu hình cho phiên làm việc sau. 
Chức năng này sẽ lưu xuống file những thông tin liên quan đến trạng thái làm 
việc của chương trình: các tùy chọn, danh sách từ điển đã cài … 
II. Hướng dẫn sử dụng: 
1. Sử dụng menus: 
1.1. Menu Từ Điển: 
Menu Từ điển chứa các lệnh cho phép thao 
tác với các từ điển: 
 Thoát chương trình: thoát và lưu lại 
thông tin về các bộ từ điển đã cài. 
 Thêm hoặc xóa từ điển: user tự do quản lý các từ điển mà mình muốn 
sử dụng, có thể thêm hay bớt các từ điển tùy theo nhu cầu. 
 Các dòng còn lại là tên của các từ điển đã được cài đặt vào dữ liệu 
của chương trình. Từ điển nào đang được sử dụng sẽ có dấu check ở phía 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 9 | 2 9 
trước trong menuItems tương ứng. Các menuItems này là “động” . Nghĩa là 
chúng sẽ tự sinh ra và mất đi tùy thuộc vào các từ điển được cài hay gỡ bỏ. 
1.2. Menu Tùy Chỉnh 
 Hiện phiên âm: Hiện hay ẩn phần phiên 
âm của từ được tra. 
 Hiện ví dụ: Hiện hay ẩn ví dụ trong 
phần nghĩa của từ được tra. 
 Phát âm khi tra: khi một từ được tra , 
có tự động phát âm từ đó hay không. 
 Hiện danh sách từ tự động: Khi user nhập từ cần tra, có tự động hiển 
thị danh sách từ gần đúng hay không. 
 Hình minh họa: khi tra một từ, có tự động search hình ảnh minh họa 
liên quan đến từ đó hay không. Chức năng này chỉ hoạt động được khi đã 
kết nối internet. 
1.3. Menu Công Cụ 
 Dịch văn bản online: User được hỗ trợ trong 
việc dịch một từ hoặc một đoạn văn bản online (dựa 
vào trang translate.google.com) 
 Đọc từ đang tra: Phát âm lại từ mà user vừa tra. 
1.4. Menu Trợ Giúp 
 Giới thiệu: Giới thiệu chung về phần mềm ML 
Dict, giới thiêu chức năng. 
 Hướng dẫn sử dụng: Hỗ trợ cách thao tác step 
by step chương trình ML Dict. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 10 | 2 9 
2. Hướng dẫn tra từ. 
ML Dict hỗ trợ nhiều cách tra từ khác nhau. 
Người dùng có thể tùy ý lựa chọn trong nhiều 
trường hợp. 
 User dùng soft keyboard, nhập từ cần tra vào 
ô nhập liệu ở góc trên bên trái. Sau khi nhập xong 
bấm vào button có hình kính lúp hoặc nhấn Enter 
để tra từ. Nghĩa của từ cần tra sẽ hiển thị ở vùng không gian bên dưới. 
 Trong quá trình nhập từ cần tra, chương trình sẽ 
tự động dò tìm với những ký tự đã gõ trong ô nhập liệu 
và cho ra nghĩa của từ gần giống với những ký tự đã 
gõ nhất. Nếu từ đang được select trong danh sách đúng 
với từ mà người dùng muốn tìm thì chỉ cần click 
hoặc nhấn enter để tra mà không cần phải gõ các ký tự 
còn lại. 
 Thay vì nhập các ký tự, user có thể click vào 
mũi tên bên phải ô nhập liệu . Sẽ có một danh sách 
các từ được xổ xuống và user có thể tìm từ cần tra 
bằng cách duyệt danh sách, select từ muốn tra tra như 
cách trên. 
 Ngoài ra, user còn có thể tra từ bằng cách click vào các button: . Quá 
trình tra từ của user sẽ được lưu lại trong history. Nếu user muốn tra lại từ trước hay sau 
trong danh sách history thì click vào . Hoặc nếu user muốn tra từ liền trước hay 
liền sau trong từ điển theo thứ tự alphabet thì click vào . 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 11 | 2 9 
3. Tạo các file dữ liệu cho từ điển. 
 Chạy công cụ Tạo index cho từ điển. ( công cụ này chạy trên máy desktop). 
 Click nút Tìm... để chỉ ra đường dẫn file dữ liệu đầu vào dạng *.xml 
 Click nút Tạo... để tiến hành tạo dữ liệu hoặcThoát để hủy bỏ quá trình tạo 
dữ liệu 
Lưu ý: 
- Dữ liệu từ điển thường là một file rất lớn do đó thời gian để công cụ tạo 
index cho từ điển chạy có thể sẽ rất lâu. Thời gian để công cụ này tạo xong các 
file dữ liệu sẽ nhiều hay ít tùy thuộc vào số lượng từ trong từ điển đó. Ví dụ: từ 
điển anh việt với 108854 từ sẽ mất khoảng 15 phút trong khi các từ điển khác 
khoảng vài chục ngàn từ chỉ mất vài giây. 
- Đầu vào của công cụ này là file dữ liệu từ điển dạng xml. Đầu ra là một bộ 
gồm 3 file cho mỗi từ điển. Ví dụ: input là : anh-viet.xml thì đầu ra tương ứng 
sẽ là: anhviet.dat, anhviet1.idx, anhviet2.idx. Chúng ta sẽ dùng 3 tập tìn này để 
cài đặt vào hệ thống ML Dict 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 12 | 2 9 
4. Cài thêm từ điển 
 Từ màn hình giao diện chương trình, bấm menu :Từ điển , chọn Thêm hoặc 
xóa từ điển. 
 Click chọn thẻ Thêm. 
 Nhập tên cho từ điển muốn thêm. Tiếp tục bấm nút Duyệt để trỏ tới file dữ 
liệu cho từ điển (có dạng *.dat ) đã tạo ra bằng công cụ Tạo Index cho Từ điển . 
 Click chọn nút Thêm để cài từ điển này vào dữ liệu của chương trình hoặc 
click nút Bỏ qua để hủy bỏ tiến trình cài đặt. 
5. Gỡ bớt từ điển 
 Từ màn hình giao diện chương trình, bấm menu :Từ điển , chọn Thêm hoặc 
xóa từ điển. 
 Click chọn thẻ Gỡ bỏ. 
 Trong danh sách các từ điển đã cài, chọn từ điển 
muốn gỡ bỏ và click nút Gỡ. Có thể gỡ bỏ một lúc nhiều từ 
điển bằng cách lặp lại thao tác này nhiều lần. 
 Click nút Lưu để chấp nhận gỡ bỏ hoặc Bỏ qua để 
hủy tiến trình gỡ bỏ. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 13 | 2 9 
6. Tra từ online. 
 Mở kết nối internet 
 Click chọn menu Công cụ, chọn tiếp Tra Từ 
Online 
 Gõ đoạn văn bản cần dịch ở ô textbox phía trên 
 Chọn ngôn ngữ nguồn và ngôn ngữ đích cho 
thích hợp. 
 Click button Dịch 
 Phần văn bản sau khi dịch sẽ được hiển thị ở 
khung bên dưới. 
7. Trợ giúp 
7.1. Giới thiệu chương trình: 
 Click chọn menu Trợ giúp, chọn 
tiếp Giới thiệu 
 Trang Giới thiệu cung cấp thông tin 
về nhóm tác giả và lời cảm ơn đến 
mọi người đã nhiệt tình giúp đỡ 
trong suốt quá trình làm. 
7.2. Hướng dẫn sử dụng: 
 Trong menu Trợ giúp, chọn tiếp 
Hướng dẫn sử dụng 
 Trang Hướng dẫn sử dụng giới thiệu 
đầy đủ về chương trình và các tính năng 
hiện có. Người dùng được hướng dẫn 
chi tiết cách sử dụng chương trình bằng 
hình minh họa từng bước, cụ thể 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 14 | 2 9 
III. Các kỹ thuật cài đặt 
1. Tổ chức dữ liệu 
a. Đánh giá 
Trong các phần mềm từ điển nói chung, công đoạn tổ chức dữ liệu cho phần 
mềm quyết định tính thành công của phần mềm đó. Tổ chức dữ liệu từ điển sao cho 
có thể truy cập tức thời là một yêu cầu không phải dễ dàng ngay cả với những phần 
mềm chạy trên desktop với bộ nhớ lên tới hàng gigabyte. Với pocket PC, bộ nhớ tí 
hon của nó quả thật là một thách thức lớn hơn rất nhiều cho công đoạn này. 
Với một từ điển thông thường khoảng vài chục ngàn từ đến vài trăm ngàn từ thì 
dữ liệu của nó chiếm khoảng vài MB đến vài chục MB (đo dưới dạng text). Do vậy, 
load toàn bộ dữ liệu lên bộ nhớ là vô phương với bộ nhớ tí hon của pocket PC. 
Điểm mấu chốt ở đây là phải tổ chức dữ liệu sao cho có thể truy xuất một phần 
của file dữ liệu thay vì đọc toàn bộ. Và bởi lẽ dữ liệu từ điển là quá lớn để truy 
xuất tuần tự nên khả năng truy xuất ngẫu nhiên file dữ liệu cũng quan trọng 
không kém. 
Các bộ dữ liệu từ điển được thầy Trần Minh Triết cung cấp là những file xml có 
cấu trúc rất dễ hiểu, dễ thao tác trong lập trình. Đồng thời, với một file xml đã load 
thành công lên bộ nhớ thì việc truy các node bên trong nó là hoàn toàn ngẫu nhiên 
và nhanh chóng. Tuy nhiên, như đã nói ở trên, load toàn bộ dữ liệu lên bộ nhớ của 
Pocket PC là không thể trong khi không có cách nào ổn thỏa để có thể đọc một phần 
dữ liệu của file xml. 
Một điều nữa, những tập tin được đọc, ghi bởi lớp FileStream lại cho phép 
truy xuất ngẫu nhiên file (file vật lý) và đọc một phần nhỏ dữ liệu của file lên bộ 
nhớ. Tuy tốc độ truy xuất file với FileStream không phải là nhanh, các thao tác với 
FileStream cũng không phải là đơn giản, nhưng so với hai lợi ích lớn mà nó mang 
lại thì những khó khăn này vẫn nhỏ hơn rất nhiều. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 15 | 2 9 
b. Giải pháp. 
Với những nhận xét trên, giải pháp khả thi nhất là chuyển đổi dữ liệu từ dạng 
xml sang dạng file được đọc/ghi bởi FileStream. Vì mục đích học tập của đồ án này, 
nhóm chọn loại file đầu ra ở dạng text cho dễ kiểm tra, chỉnh sửa. 
Công cụ CreateIndex (tạo index cho từ điển) được viết và đính kèm theo từ 
điển có chức năng chuyển đổi file dữ liệu dưới dạng *.xml sang dạng *.dat, đồng 
thời tạo hai file index nhằm hỗ trợ cho các thao tác với file *.dat được tốt hơn. Mỗi 
từ điển sau khi chuyển đổi sẽ gồm một tập 3 file có quan hệ với nhau như hình bên 
dưới. 
 File nghĩa có tên dạng *.dat gồm các đoạn dữ liệu nghĩa liên tục nhau. File 
này có kích thước khoảng vài MB đến vài chục MB. 
 File Index1 có tên file dạng *1.idx là file chỉ mục cho file nghĩa. Nội dung 
của file là một danh sách tất cả các từ vựng có trong từ điển. Kèm theo mỗi từ là 
thông tin cho biết vị trí bắt đầu và vị trí kết thúc của phần nghĩa tương ứng trong file 
nghĩa. Số dòng của file này bằng với số từ có trong từ điển và đã được sắp xếp tăng 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 16 | 2 9 
dần theo alphabet. Kích thước của nó vẫn chưa đủ nhỏ để có thể load lên bộ nhớ và 
xử lý trong Pocket PC. Với từ điển anh-việt 108854 từ thì file anhviet1.idx của nó có 
kích thước khoảng 3.4MB.  
 File Index2 là file có dạng *2.idx. File này là chỉ mục cho file index1. Nội 
dung của file là danh sách các chỉ mục trỏ tới các block từ trong index1. Một block 
từ được định nghĩa là một nhóm các từ vựng liền nhau theo thứ tự alphabet và có đặc 
điểm chung là 3 ký tự đầu của mỗi từ thành viên đều giống nhau. Một số trường hợp 
đặc biệt, những từ gồm 1 hoặc 2 ký tự cũng được nhóm riêng thành một nhóm. 
Kích thước của file index2 là đủ nhỏ ( <100KB) để có thể load toàn bộ lên bộ 
nhớ phục vụ cho xử lý. Toàn bộ dữ liệu của index2 sẽ được load lên và “gắn” vào 
một HashTable với key là 3 ký tự đầu của nhóm, value là chuỗi chứa thông tin bắt 
đầu và kết thúc của block từ tương ứng trong file index1. Bằng cách này, hoàn toàn 
có thể truy xuất ngẫu nhiên nội dung index2 (đã load lên bộ nhớ). 
2. Cách thức tra từ 
 Để tra một từ bất kỳ, trước hết cần xác định từ đó thuộc block nào dựa vào 3 
ký tự đầu tiên của từ đó và lấy thông tin vị trí bắt đầu, kết thúc của block. 
 Mở file index1, nhảy tới vị trí bắt đầu block từ và đọc toàn bộ block lên bộ 
nhớ. 
 Search ra vị trí của từ trong block để lấy thông tin vị trí bắt đầu và kết thúc 
của phần nghĩa tương ứng. 
 Mở file nghĩa, nhảy tới vị trí bắt đầu phần nghĩa và load lên bộ nhớ. 
3. Cách thức xử lý vấn đề load danh sách 
a. Đánh giá. 
Theo cách nghĩ thông thường, việc load danh sách từ sẽ là load toàn bộ dữ liệu 
và hiển thị lên list box cho người dùng, người dùng có thể tự do chọn từ và kéo 
thanh trượt di chuyển lên xuống xuyên suốt lượng từ khổng lồ của từ điển. Tùy vào 
độ lớn của từng bộ dữ liệu từ điển mà thời gian load danh sách sẽ nhanh hay chậm. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 17 | 2 9 
Nếu chương trình từ điển cho phép sử dụng nhiều bộ từ điển, ví dụ như Anh_Việt, 
Việt_Anh, Việt_Pháp v.v…, thì trong mỗi khoảng thời gian xác định, chỉ có dữ liệu 
của bộ từ điển đó được load lên. Như vậy, khi người dùng muốn chuyển đổi qua lại 
giữa từ điển này và từ điển kia, sẽ mất nhiều thời gian cho việc load toàn bộ dữ liệu 
từ điển và hiển thị. 
Thêm vào đó, như đã phân tích ở phần „Tổ chức dữ liệu’, cách làm này chỉ 
thích hợp đối với hệ máy có dung lượng bộ nhớ … dư dả. chỉ riêng danh sách từ 
của một từ điển cũng đã lên đến vài MB, vượt quá khả năng cho phép của một 
pocket PC thông thường. 
Cách làm tốt và hợp lý hơn là chỉ load một phần dữ liệu thích hợp, vừa đủ để 
xem và hiển thị lên list box dựa vào từ mà người dùng đang gõ. Ví dụ người dùng 
gõ từ „singer‟, và trong từ điển thì vị trí từ này là khoảng 87485, nói nôm na, ta sẽ 
load và hiển thị lên danh sách một số từ nằm ở khoảng này. 
b. Giải pháp 
Để tiết kiệm chỗ trống cho màn hình giao diện, danh sách từ sẽ được thiết kế 
giả lập một combobox (gồm text box, listbox, vscrollbar và môt picture box). 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 18 | 2 9 
Như vậy sẽ phải xử lý theo 2 hướng. Hướng thứ nhất là khi người dùng tra từ, 
sau khi tìm được từ đó và hiện danh sách 12 từ lên listbox, phải xác định được vị trí 
của từ đó trong từ điển là bao nhiêu để đặt lại vị trí cho thanh VScrollbar, tạo cảm 
giác như toàn bộ từ trong từ điển đã được load hết vào listbox (nghĩa là mỗi khi tra 
đến từ nào, thanh VScrollbar „dừng‟ đúng vị trí của từ đó trong từ điển). Hướng thứ 
hai là khi người dùng không gõ từ vào listbox mà di chuyển thanh scrollbar lên 
xuống, phải tìm được từ trong dữ liệu từ điển có vị trí bằng với vị trí của thanh 
scrollbar. Sau đó load 12 từ phía sau từ này vào listbox. (Xem các phương pháp tra 
từ đã trình bày ở trên). 
4. Menu động 
a. Ý tưởng. 
Danh sách các menu hiện tên từ điển ứng với mỗi thao tác thêm hay bỏ bớt từ 
điển của người dùng sẽ thay đổi, nói cách khác, các menu này là „động‟. Đồng thời 
khi người dùng click chọn từ điển nào, menu ứng với từ điển đó sẽ có chức năng 
„thông báo‟ để chương trình load file index2 của từ điển lên. 
Thêm vào đó, các menu cần được lưu lại cho lần sử dụng sau của người dùng 
chứ không phải chỉ tồn tại trong lúc chương trình đang thực hiện rồi trở lại trạng 
thái ban đầu mỗi lần mở chương trình. 
b. Giải pháp. 
Các bộ từ điển và đường dẫn tới chúng được lưu vào trong file dictionaries.xml. 
Khi chương trình khởi động sẽ load file này và lấy thông tin về tên, đường dẫn của 
từ điển lưu vào một hashtable, với key là tên từ điển và value là đường dẫn. Như 
vậy, mỗi lần thêm hay xóa từ điển, chỉ cần thao tác trước với hashtable này, xây 
dựng danh sách các menu từ điển cũng dựa trên nó. 
Sau mỗi lần hoạt động, ta sẽ xóa bỏ nội dung cũ và cập nhật thông tin mới vè 
danh sách các từ điển trong file dictionaries.xml thông qua hashtable này. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 19 | 2 9 
5. Đối sánh chuỗi, tìm kiếm 
a. Đánh giá 
Trong các yếu tố phục vụ cho việc dò tìm từ, đối sánh chuỗi chính xác là quan 
trọng hơn cả. Trước hết, cần phải có một phép so sánh đủ chính xác để phát hiện 
một từ bất kỳ trong danh sách có phải là từ đang được tìm hay không. Sau nữa, để 
công việc dò tìm đạt hiệu quả, một danh sách được sắp xếp thứ tự phải là yêu cầu 
hàng đầu. Một danh sách từ vựng được sắp hỗn độn không thể nào thích hợp với 
phương pháp truy xuất ngẫu nhiên theo chỉ mục và cũng không thể tránh khỏi việc 
dò tìm trên toàn bộ dữ liệu mỗi khi cần tra từ. 
Thực tế, theo nhận định của nhóm, dot NET chưa thật sự hỗ trợ tốt trong khâu 
đối sánh chuỗi tiếng việt. Những chuỗi (kiểu string) bình thường, không dấu thì có 
thể dễ dàng compare với nhau với kết quả rất tốt. Tuy nhiên với những ký tự có dấu 
trong tiếng việt, tiếng pháp … thì hầu hết là sai. Một ví dụ điển hình, khi so sánh 
hai chuỗi “a”, “ả” bằng tất cả những phương pháp mà dot Net CF hỗ trợ 
(CultureInfo, string.Compare, phương thức Sort() của lớp List … ) thì kết quả 
đều cho thấy “a” đứng trước “ả”. Lặp lại tương tự với chuỗi “a dua”, “ả đào” 
thì kết quả là “a dua” dứng sau “ả đào”, một kết quả thật sự khó hiểu. 
Một ký tự trong bảng mã unicode tổ hợp chiếm 2bytes trong khi một ký tự 
tương đương trong unicode dựng sẵn chiếm 1byte. Các phương pháp so sánh mà 
dot Net hỗ trợ cho đến hiện nay chỉ làm việc tốt với unicode tổ hợp. Dữ liệu từ điển 
dạng file xml được cấp sẵn bởi thầy Trần Minh Triết được viết bằng bảng mã 
unicode dựng sẵn. Do đó, đối sánh theo cách thông thường là không hiệu quả. 
b. Giải pháp. 
Thêm một điều kỳ lạ nữa, tuy rằng kết quả so sánh các chuỗi unicode dựng sẵn 
không chính xác trong một số trường hợp như những nhận định trên nhưng khi tách 
rời chúng ra và tiến hành đối sánh lần lượt từng ký tự trong chuỗi thì lại cho kết 
quả chính xác. Đây cũng chính là phương pháp đối sánh được sử dụng trong đồ án 
này. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 20 | 2 9 
Có thể, phương pháp đối sánh chuỗi mà ML Dict sử dụng chưa phải là cách tốt 
nhất cả về thời gian thực thi lẫn hình thức. Tuy nhiên, để có được kết quả đối sánh 
chính xác thì hiện tại nhóm không còn cách nào hơn. 
Về vấn đề tìm kiếm, giải pháp được lựa chọn ở đây là tìm kiếm tuần tự một từ 
trong block của nó. Như đã trình bày ở phần giới thiệu chức năng, ML Dict hỗ trợ 
tìm từ gần đúng. Nghĩa là để tra một từ (có nhiều ký tự), người dùng chỉ cần nhập 
vào một số ký tự đầu tiên của từ đó là đã có thể tìm thấy từ cần tra. Với cách truy 
vấn mờ như thế cộng với tính chất sắp thứ tự (tăng dần) và gom nhóm của dữ liệu, 
phương pháp tìm kiếm nhị phân sẽ không còn thích hợp nữa. 
6. Phát âm 
Đối với chương trình viết trên desktop, việc thực hiện chức năng phát âm dạng 
Text to Speech là rất dễ vì chỉ cần thêm bộ thư viện có sẵn là Microsoft Speech 
Object Library(viết gọn là SpeechLib), sử dụng đối tượng SpVoice của thư viện này 
để đọc từ. Tuy nhiên trên pocket PC lại giới hạn không hỗ trợ bộ thư viện này. 
Để thực hiện chức năng phát âm, nhóm đã sử dụng lại 2 file .dll được chia sẻ 
bởi tác giả agraham là FliteDevice.dll và fliteDLL.dll. Dung lượng file 
FliteDevice.dll khoảng 4KB được để chung trong thư mục của chương trình và 
chương trình sẽ tham chiếu tới thư viện này. File fliteDLL.dll phải chép vào thư 
mục Windows trong máy pocketPC, file này có dung lượng 2,96MB. 
2 bộ thư viện này cung cấp sẵn đối tượng FliteDevice với phương thức 
Say(string) để thực hiện chức năng Text to Speech. Thực chất file FliteDevice.dll 
mà chương trình tham chiếu tới đóng vai trò như một chiếc cầu nối, cung cấp hàm 
dưới dạng đơn giản nhất, khi chương trình gọi hàm, nó sẽ liên kết tới file chính là 
fliteDLL.dll đã được chép trong thư mục Windows để tiếp tục xử lý, phát âm chuỗi 
từ. LINK THAM KHẢO FLITE 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 21 | 2 9 
7. Tra hình minh họa 
a. Phân tích. 
Dựa vào bộ máy tìm kiếm phổ biến nhất hiện nay là Google, đối với mỗi từ mà 
người dùng muốn hiển thị hình ảnh, chương trình sẽ tạo kết nối đến trang tìm hình 
của Google là images.google.com.vn. Tùy thuộc vào từ được tra, đường dẫn đến 
trang kết quả của Google sẽ khác nhau phần tham số bên trong. 
Khi tìm hình ảnh bằng Google, kết quả hình sẽ được phân chia thành nhiều 
trang, số lượng hình trong mỗi trang là 20. Đó chỉ là hình dạng thu nhỏ để người 
dùng nhìn nhanh, quyết định chọn hình nào để sử dụng. Khi mở từng hình kết quả 
trong một trang riêng, hình đó mới được thể hiện đúng với kích thước thật. 
Như vậy khi tra hình minh họa của một từ, trang kết quả sẽ chứa đường link của 
tập 20 hình này. Nhóm đã thử tìm kiếm nhiều chuỗi từ khác nhau, lưu lại trang kết 
quả của Google và mở source của trang kết quả này để phân tích, tìm vị trí bắt đầu 
của tập đường link các hình kết quả và lưu lại vào mảng chuỗi. 
b. Kết quả thực hiện. 
Sau bước phân tích và thử tìm kiếm với nhiều chuỗi từ khác nhau, nhóm đã tìm 
được cấu trúc đường link đến trang kết quả hình ảnh của Google. Đường link có 
dạng như sau: [...] . Khi cần 
tìm kiếm chuỗi từ nào, ta sẽ thay chuỗi từ đó vào vị trí […] và tạo đối tượng 
HttpWebRequest để kết nối tới. Tuy nhiên có sự khác nhau trong đường link kết quả 
khi tìm từ có khoảng trắng và tìm từ viết liền: từ có khoảng trắng sẽ được thay 
khoảng trắng đó bằng dấu „+‟. 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đại – Nguyễn Minh Bình – Đỗ Thị Hồng Thu. 22 | 2 9 
Ví dụ, tìm từ „computer‟ sẽ có đường link kết quả là 
 , 
Trong khi tìm từ khác có khoảng trắng, như từ „hòa bình‟, kết quả sẽ là: 
òa+bình 
Như vậy sau khi lấy được source của link kết quả, ta chỉ 
lấy phần chuỗi bắt đầu bằng từ khóa „dyn.setResults‟, sau 
đó tách cụm link tới từng hình ra thành từng phần và lưu vào 
mảng kết quả. Mảng chuỗi này sẽ được định lại thành dạng 
html và nối với chuỗi nghĩa khi người dùng tra từ, nếu có 
chọn chức năng tìm hình minh họa. Hình bên là một ví dụ 
khi tìm với từ khóa button 
Bắt đầu mảng chứa link 1 link kết quả 
Ví dụ về source của một trang kết quả tìm kiếm hình ảnh 
Khoa Công Nghệ Thông Tin – Đại Học Khoa Học Tự Nhiên. 
Lập Trình Hiện Đ
            Các file đính kèm theo tài liệu này:
Từ điển đa ngôn ngữ trên PocketPC.pdf