Mặc dù VINASA xếp game là một trong 3 định hướng công nghệ chiến lược của hiệp hội này trong giai đoạn 2006-2010, bên cạnh định hướng phần mềm nhúng và ERP bộ phần mềm hoạch định nguồn l
Trang 1MỤC LỤC
Lời nói đầu……… 2
Phần I .Giới thiệu Game Puzzle……….3
Phần II.Giới thiệu công nghệ Java và nền tảng J2SE……… 5
I Giới thiệu chung về Java……….5
II Máy ảo Java-JVM……… 7
III Giới thiệu J2SE……… 11
IV Giới thiệu gói javax.swing.*……… 11
Phần III .Phân tích thiết kế………17
I Sơ đồ phân rã chứa năng………17
II Sơ đồ luồng dữ liệu mức đỉnh………18
III Cấu trúc chương trình……….19
IV Đặc tả chương trinh………25
Phần IV .Kết luận……… 27
Trang 2LỜI NÓI ĐẦU
Nói đến game thì chắc phần lớn mọi người đều đồng ý đó là một loại hình giải trí có sức thu hút rất lớn,nhất là với giới trẻ hiện nay.Đặc biệt sau sự ra đời củaInternet,game online xuất hiện và nhanh chóng gây được sức hấp dẫn to lớn.Chúng
ta có thể chơi game online trên mạng,các game offline trên PC,các game trên các dòng máy chuyên như PS2,PS3 hiện nay game cũng đang được phát triển mạnh trên các thiết bị di động như điện thoại di động,các máy Xbox
Ở các nước phát triển như Nhật Bản,Mỹ có rất nhiều các công ty chuyên về sản xuất game như Nintendo,Sony,Sega và mỗi năm các công ty này đạt doanh thuhàng tỷ USD.Hay với các nước đi sau như Hàn Quốc,Trung Quốc cũng có được một ngành công nghê game rất mạnh nhờ có sự đầu tư đúng đắn và chiến lược pháttriển tốt
Mặc dù VINASA xếp game là một trong 3 định hướng công nghệ chiến lược của hiệp hội này trong giai đoạn 2006-2010, bên cạnh định hướng phần mềm nhúng và ERP (bộ phần mềm hoạch định nguồn lực doanh nghiệp) nhưng hiện tại thị trường game ở Việt Nam còn rất yếu.Chưa có nhiều công ty chuyên về lập trìnhgame,những công ty phát triển game online thì chủ yếu là cung cấp các game nhập
từ Hàn Quốc,Trung Quốc các game nội hầu như vắng bóng trên thị trường.Đúng như theo nhận định của một chuyên gia phát triển game của Hàn Quốc:“ngành công nghiệp game Việt Nam hiện nay giống như một đứa trẻ sơ sinh, rất cần được
sự giúp đỡ và nuôi nấng (của Chính phủ) để phát triển”.Chắc hẳn hiện nay có rất nhiều bạn trẻ đang theo đuổi ngành CNTT cũng muốn tham gia vào lĩnh vực này
và họ rất cần có được sự giúp đỡ và ủng hộ từ các nhà giáo dục,từ chính sách,định hướng phát triển của chính phủ.Đề tài tốt nghiệp này là làm trò chơi Puzzle sử dụng ngôn ngữ lập trình Java.Do mới tiếp cận về lập trình game nên chương trình còn có nhiều thiếu sót,mong các thầy giúp đỡ,góp ý để hoàn thiện hơn
Để hoàn thành bài tập này ngoài sự cố gắng của bản thân còn có sự tham gia góp ý,giúp đỡ của thầy giáo và bạn bè.Trước hết em xin gởi lời cảm ơn chân thành đến thầy giáo hướng dẫn Nguyễn Đức Tuấn đã nhiệt tình giúp đỡ để em hoàn thành đề tài.Ngoài ra xin cám ơn các bạn trong lớp,các bạn trong cộng đồng Java Việt Nam đã đóng góp ý kiến trong quá trình thực hiện đề tài
Trang 3PHẦN I:GIỚI THIỆU VỀ ĐỀ TÀI
TRÒ CHƠI PUZZLE.
Bản thân từ Puzzle có nghĩa là câu đố,đây là trò chơi thuộc thể loại game trí tuệ Trò chơi này cũng giống như các trò chơi xếp hình,đầu tiên với kích thước trò chơi là 9 ô,trạng thái ban đầu được khởi tạo ngẫu nhiên.Nhiệm vụ của người chơi là xếp 8 chữ số sao cho đạt được trạng thái win cho như sau:
Người chơi sẽ dịch chuyển các số theo các hướng lên xuống,sang trái phải khi ô cạnh nó là ô trống.Độ khó của trò chơi được qui định bằng giới hạn thời gian chơi và số lần dịch chuyển.Nghĩa là nếu người chơi chơi hết thời gian giới hạn hay
số lần dịch chuyển giới hạn sẽ bị thua
Người chơi cố gắng xếp 8 ô về trạng thái win càng nhanh càng tốt và càng dùng ít lần dịch chuyển càng tốt,khi win người chơi sẽ được một số điểm tínhtheo công thức:
Số giây ít hơn so với giây giới hạn*3+Số lần dịch chuyển ít hơn số lần cho phép*5
Nếu số điểm của bạn nằm trong top 5 người có điểm cao nhất thì bạn
sẽ được ghi danh vào top
Cách thức chơi có vẻ rất đơn giản.Khi tìm hiểu game này có một vấn
đề khá thú vị.Đó là có phải bao giờ bạn cũng có thể đưa game về trạng thái win như trên không?Trong game có một trạng thái mà không có ai có thể giải quyết,đó
là trạng thái sau:
1 2 3
4 5 6
7 8
Trang 4Đã có rất nhiều người tham gia giải quyết tình huống này nhưng đến nay chưa ai có thể thành công.Để biết rõ hơn về tình huống thú vị này bạn có thể xem them tại địa chỉ sau:http://www.holotronix.com/samlloyd15.php
Chương trình được xây dựng trên nền tảng J2SE của Java.Chủ yếu là lập trình GUI sử dụng Swing trong Java-sẽ được giới thiệu trong phần II dưới đây
1 2 3
4 5 6
8 7
Trang 5PHẦN II.GIỚI THIỆU VỀ JAVA VÀ NỀN TẢNG J2SE
I.Giới thiệu chung về Java.
1.Sự phát triển.
Java được xây dựng vào cuối năm 1990 bởi James Gosling và khi đó
nó có tên là Oak(Oak:cây sồi,vì cửa sổ phòng làm việc của Gosling nhìn ra một gốc sồi).Gosling được công ty Sun Microsystems giao nhiệm vụ xây dựng một phần mềm lập trình cho các mặt hàng điện dân dụng với mục tiêu là nhỏ gọn và tương thích được với nhiều loại thiết bị phần cứng khác nhau.Đầu tiên Oak được dung trong Dự án Xanh
Sau một chuyến du lịch của nhóm phát triển Oak đến đảo Java của Indonesia nổi tiếng về cà phê,Oak đã được đôi tên thành Java từ đó.Sau này chúng
ta có thể thấy nhiều khái niệm và hình tượng liên quan đến cà phê(như “bean” là hạt cà phê)
Sun, công ty đã phát minh ra ngôn ngữ Java, chính thức ban hành bản
http://vi.wikipedia.org/w/index.php?title=Java_Development_Kit&action=edit&redlink=1 Java
Development Kit (JDK) 1.0 vào năm 1995 hoàn toàn miễn phí để các nhà phát triển có thể tải về, học Java, xây dựng các ứng dụng Java và triển khai chúng trên các hệ điều hành có hỗ trợ Java Ban đầu, Java chủ yếu dùng để phát triển các Applet, các ứng dụng nhúng vào trình duyệt, góp phần làm sinh động các trang Web tĩnh vốn hết sức tẻ nhạt hồi dó Tuy nhiên, cùng với sự phát triển của công nghệ thông tin và nhu cầu của xã hội, Java applet đã dần mất đi vị trí của nó và thay vào đó, các công ty, cộng đồng ủng hộ Java đã phát triển nó theo một hướng khác Hiện nay, công nghệ Java được chia làm ba bộ phận:
J2SE
Gồm các đặc tả, công cụ, API của nhân Java giúp phát triển các ứng dụng trên desktop và định nghĩa các phần thuộc nhân của Java
J2EE
Gồm các đặc tả, công cụ, API mở rộng J2SE để phát triển các ứng dụng qui
mô xí nghiệp, chủ yếu để chạy trên máy chủ (server) Bộ phận hay được
Trang 6nhắc đến nhấtcủa công nghệ này là công nghệ Servlet/JSP: sử dụng Java để làm các ứng dụng web
J2ME
Gồm các đặc tả, công cụ, API mở rộng để phát triển các ứng dụng Java chạytrên điện thoại di động, thẻ thông minh, thiết bị điện tử cầm tay, robo và những ứng dụng điện tử khác
Java đã trải qua 3 bước phát triển quan trọng: Java 1.0 gắn liền với bản JDK đầu tiên, Java 2 gắn với JDK 1.2 và Java 5 gắn với J2SDK 1.5
Ngày nay, khi nhắc đến Java người ta không còn chỉ nhắc đến Java như
là một ngôn ngữ mà nhắc đến Java như là một công nghệ hay một nền tảng pháttriển Nó bao gồm các bộ phận:
• Máy ảo Java: JVM
• Bộ công cụ phát triển: J2SDK
• Các đặc tả chi tiết kĩ thuật (specifications)
• Ngôn ngữ lập trình (programming language)
2.Một số đặc điểm.
Java là một nền tảng phát triển các ứng dụng phần mềm có vị trí rất lớn trong những năm cuối thể kỷ 20 đầu thế kỷ 21 Đánh dấu sự trưởng thành của mô hình hướng đối tượng , nó được coi là một nền tảng mang tính chất cách mạng trong ngành phần mềm Mô hình máy ảo Virtual Machine đã cho phép các ứng dụng viết bằng Java có thể chạy trên nhiều hệ điều hành khác nhau.Khẩu hiệu nổi tiếng của Java là “Write one,Run anywhere” có thể hiểu là “Viết một lần,chạy khắp mọi nơi”
Java nhanh chóng được nhiều nhà lập trình công nhận Các câu lệnh và các biểu diễn tượng tự trong một số ngôn ngữ như C , C++ Mặc dù Java đã bổ sung khá nhiều điểm mới , nét phân biệt nhất của Java lại là những đặc điểm mà nó bỏ qua :
Trang 7Như so với C thì Java không có : Số học địa chỉ bộ nhớ (Con trỏ) , Bộ tiền
xử lý, Câu lệnh goto , chuyển đổi kiểu tự động , các biến và hàm tổng thể , các định danh xác định kiểu
So với C++ thi Java không có : đa thừa kế , đa ABI (Application Binary Interface – Giao diện nhị phân ứng dụng)
II.Máy ảo Java : Java Virtual Machine (JVM) :
Mã nguồn Java được biên dịch để sinh ra mã đối tượng gọi la ByteCode (Mãbyte ) ByteCode ở đây không phải là mã nhị phân của máy tính đang tồn tại thực
tế nào mà nó là một loại mã máy kiến tạo trung gian có thể dễ dàng dịch sang để chạy trên bất ký máy tính cụ thể nào Thông thường trong hầu hết các môi trường hiện tại (Hệ điều hành ) JVM được gọi thực thi bằng một chương trình có tên là Java JVM đọc chương trình bằng ByteCode và thông dich hoặc biên dịch nó ra theo hệ lênhk thực tế
Ðây là một đặc điểm có ý nghĩa rất lớn Chạy bytecode trên một JVM là lý do vì sao các phần mềm Java là "viết một lần, chạy khắp nơi" Các chương trình chạy được Java (Java executable) cung cấp một bộ mã nhị phân chạy trên mọi bộ xử lý Nói cách khác, một ứng dụng bằng Java của bạn chẳng hạn là chương trình xyz nào đó bằng Java sẽ chạy trên mọi hệ thống hỗ trợ Java mà không cần phải có
riêng "xyz cho DOS", "xyz cho Windows 3.1", "xyz cho Windows 95"
Bởi vì JVM có thể cài đặt trên hầu hết các hệ điều hành(HDH) khác nhau (Window, Linux, Mac OS ,…) nên cùng một tập tin class có thể chạy trên các hệ điều hành khác nhau đó Điều này nghĩa là với một file Java có thể chạy trên nhiều HDH khác nhau :
Trang 8Tính dễ chuyển mang và tính năng của phần mềm
công nghệ phần mềm Nó đã được nghiên cứu, tìm kiếm từ lâu nay nhưng chưa bao giờ thực sự đạt được Java làm cho ngành công nghệ này tiến lại gần tính dễ chuyển mang của phần mềm nhiều hơn tất cả các hệ thống trước đó Tại các cửa hàng bán phần mềm hiện nay, có lẽ bạn sẽ thấy chủ yếu là các phần mềm dùng choWindows (một số chỉ cho Windows 3.1, một số cho cả Windows 95 và Windows 3.1), một số ít cho Mac và một số rất ít (có thể là không có) cho Unix Khi Java trở thành ngôn ngữ phổ biến thì bạn có thể chọn từ tất cả các phần mềm có trong cửa hàng và phần mềm bạn chọn mua sẽ chạy trên tất cả các hệ thống máy tính mà bạn
có Lúc đó mọi người có được sự lựa chọn rộng rãi hơn và giá phần mềm cũng sẽ
hạ do các nhà cung ứng phần mềm có thể phân bổ chi phí phát triển trên một thị trường rộng lớn 250 triệu máy tính chứ không phải chỉ cho 91 triệu hệ thống
Windows 3.1 hoặc cho 20 triệu hệ thống Macintosh hoặc cho 8 triệu hệ thống Unix
Máy ảo Java phải được triển khai cho mỗi hệ thống máy tính và sau đó mọi bytecode sẽ chạy được trên hệ thống đó Ðiểm quan trọng ở đây là bytecode có khả
Trang 9năng chuyển mang tổng hợp Ðương nhiên vấn đề đặt ra là làm sao để có các JVM thích hợp cho từng môi trường Có lẽ vấn đề này cũng tương tự như quá trình để cho các máy tính cá nhân (PC) là tương thích DOS trước đây.
Một điều lý thú là bytecode không phải chỉ dành riêng cho Java Nếu sửa đổi một chương trình dịch đối với một số ngôn ngữ khác như Ada hay Visual Basic để
nó sinh ra được bytecode thì cũng có thể chạy bytecode đó "ngon lành" trên JVM trên bất kỳ máy tính nào Ðây là một hướng mà các nhà cung ứng phần mềm đang quan tâm Khả năng chạy được mã trên mọi hệ thống máy tính trên hành tinh là lý
do mạnh mẽ để cải cách ý tưởng về JVM hỗ trợ đắc lực cho hướng cải cách này
Java có những đảm bảo tính dễ chuyển mang, bao gồm việc cung cấp cùng một giao diện người lập trình ứng dụng (API, Application Programmer Interface) trên mọi loại nền; cùng một giao diện nhị phân ứng dụng (ABI, Application BinaryInterface), cụ thể là máy ảo Java, trên mọi loại nền Ngoài ra ngôn ngữ Java còn cóqui định bắt buộc một số điểm lâu nay vẫn để tuỳ thuộc vào sự cụ thể hoá của người viết chương trình dịch Bằng cách yêu cầu rằng các toán hạng được đánh giátheo thứ tự nghiêm ngặt từ trái qua phải và qui định kích thước của tất cả các kiểu
cơ bản (kiểu nguyên là 32 bit, kiểu chính xác gấp đôi là 64 bit v.v) Java đáp ứng không những tính dễ chuyển mang mà còn cả cách xử lý đồng nhất của chương trình trên các hệ thống khác nhau Java dùng Unicode là tập ký tự chuẩn có thể biểu diễn các ký hiệu, ký tự trong hầu hết các bảng chữ cái trên thế giới, kể cả các
ký tự tiếng Việt cũng như các loại chữ tượng hình của châu A' Trong thời gian sắptới, nếu chuẩn tiếng Việt cho công nghệ thông tin của Việt nam dựa trên Unicode thì chắc chắn Java dễ dàng hỗ trợ cho chuẩn đó
Một điều có thể dễ nhận thấy rằng việc bảo đảm tính dễ chuyển mang có thể ảnh hưởng tới tính năng thực hiện của phần mềm Tuy nhiên, ta có một sự cân nhắcđáng giá Bạn hãy hình dung xem, nếu tất cả các hệ thống được xây dựng trong nhiều năm qua không cố gắng tiết kiệm chi phí của hai byte "thừa" và lưu giữ các con số năm bằng 4 byte chứ không phải là 2 byte thì chúng ta đã không gặp phải sự
cố đau đầu "vấn đề năm 2000" Với Java, có thể thấy một số điểm là hơi "cồng kềnh" hoặc "dư thừa" Tuy nhiên, những qui định chặt chẽ và chuẩn hoá của Java chính là để đảm bảo tính dễ chuyển mang và tính năng của nó trong một tương lai dài lâu
Trang 10
Java với việc quản lý bộ nhớ
Trong lập trình, một vấn đề rất nặng nề được đặt ra là việc quản lý bộ nhớ động, trong đó có việc "dọn dẹp bộ nhớ" - tức là việc giải phóng những phần bộ nhớ mà chương trình đã dùng xong để dành cho những mục đích khác Khi một chương trình chạy, nó sẽ phân bổ bộ nhớ để lưu giữ các đối tượng mới Khi sự tồn tại của các đối tượng này đã kết thúc thì không gian bộ nhớ dành cho chúng cần được giải phóng và dùng lại cho các đối tượng khác Nếu bộ nhớ không được giải phóng thì quá trình (chương trình) sẽ ngày càng lớn lên và sẽ có thể chiếm hết tất
cả không gian nhớ, gây tràn Một số ngôn ngữ như COBOL-74 không trang bị khả năng quản lý bộ nhớ động (do vậy một số chương trình hết sức khó viết hoặc
không thể viết được) Một số ngôn ngữ khác như Pascal, C, C++ lại trút gánh nặng quản lý bộ nhớ lên vai người lập trình Thậm chí người lập trình còn phải quan tâmxem phần nào của bộ nhớ đang được sử dụng và phải giải phóng phần nào của bộ nhớ khi cần thiết Những chuyện này dẫn đến nhiều loại lỗi khác nhau của các chương trình, phổ biến là lỗi không giải phóng được bộ nhớ gây ra các "lỗ hổng" không bao giờ được khai báo lại trong bộ nhớ Còn tệ hơn là các lỗi gây ra do việc
cố giải phóng những phần bộ nhớ còn đang sử dụng dẫn đến hỏng hoặc mất dữ liệu.
Các chương trình Java được quản lý về bộ nhớ ở mức hệ thống và người lập trình không bao giờ phải lo lắng về chuyện đó Thư viện thời gian chạy của Java sẽgiám sát các cấu trúc dữ liệu Khi không còn một tham chiếu nào tới một cấu trúc
dữ liệu thì nó không thể là đang được sử dụng vì chương trình không có cách gì để đọc hoặc ghi nó Lúc đó nó sẽ là đối tượng của việc dọn dẹp bộ nhớ
Java hướng tới việc dọn dẹp bộ nhớ tự động Việc dọn dẹp bộ nhớ tự động ảnh hưởng tới tính năng vì nó liên quan đến các quá trình khác chạy trong nền sau
để giám sát việc sử dụng bộ nhớ Tuy nhiên thực tế đã chỉ ra rằng, ở đây cũng có một sự cân nhắc đáng giá Một hệ thống nhỏ thực hiện dọn dẹp bộ nhớ tự động đã dẫn tới sự cải thiện rất lớn thông qua việc gỡ bỏ một loạt các lỗi của các chương trình Java Có thể so sánh, các chương trình C++ chịu trách nhiệm quản lý các đống (heap) bộ nhớ của riêng chúng do vậy chúng phải có mã dài hơn, mất nhiều thời gian gỡ rối hơn và các chương trình lớn thường dẫn tới các lỗi rất khó phát hiện và xử lý về việc dọn dẹp bộ nhớ.
Trang 11III.Giới thiệu nền tảng J2SE
J2SE : là viết tắt của Java 2 Standard Edition - Vừa là một đặc tả , vừa là một nền tảng thực thi (bao gồm cả phát triển và triển khai) cho các ứng dụng Java J2SE cung cấp các API , các kiến trúc chuẩn , các thư viện và các công cụ cốt lõi nhất để xây dựng các ứng dụng Java
Mặc dù J2SE là nền tảng thiên về phát triển các sản phẩm chạy trên máy tính
để bàn nhưng những tính năng của nó, bao gồm phần triển khai ngôn ngữ Java lớp gốc, các công nghệ nền như JDBC để truy vấn dữ liệu chính là chỗ dựa để Java tiếp tục mở rộng và hỗ trợ các thành phần mạnh mẽ hơn dùng cho các ứng dụng hệ thống quy mô xí nghiệp và các thiết bị nhỏ
J2SE gồm 2 bộ phận chính là: Java 2 Runtime Environment, Standard
Edition http://vi.wikipedia.org/w/index.php?title=JRE&action=edit&redlink=1(JRE) và Java 2 Software Development Kit, Standard Edition (SDK) Môi trường thực thi hay JRE cung cấp các Java API, máy ảo Java và các thành phần cần thiết khác để chạy các Applet và ứng dụng viết bằng ngôn ngữ lập trình Java Môi trường thực thi Java không có các công cụ và tiện ích như là các trình biên dịch hay các trình gỡ lỗi để phát triển các applet và các ứng dụng
Java 2 SDK là một tập mẹ của JRE, và chứa mọi thứ nằm trong JRE, bổ sung thêm các công cụ như là trình biên dịch và các trình gỡ lỗi cần để phát triển applet và các ứng dụng
Phiên bản J2SE mới nhất tính đến thời điểm hiện tại là J2SE 1.5 hay còn gọi
là J2SE 5.0 theo như cách đặt tên phiên bản của Sun Microsystems
IV Giới thiệu về gói javax.swing.*;
1 Giới thiệu JFC (Java Foundation Class):
- Là thư viện lập trình đồ họa được thiết kế và đóng gói theo mô hình hướng đối tượng
- JFC có khả năng tạo nên các giao diện uyển chuyển linh hoạt.Nó không chỉ cho phép chương trình chạy tương thích trên nhiều hệ điều hành khác nhau mà còn cho phép giao diện của chương trình thay đổi cách nhìn ngay trên một hệ điều hành Windows duy nhất.Có nghĩa là trên môi trường Windows của Microsoft chẳng hạn,chương trình của ta vẫn có thể mang dáng dấp của giao diện trên máy Macsintosh hay máy Unix,ngoài
Trang 12giao diện chuẩn của Windows mà ta thường thấy.Để làm được điều này thư viện JFC đưa ra một khái niệm gọi là “cảm quan”(Look and Feel) cácthành phần đồ họa xây dựng bằng JFC có khả năng biến đổi theo dáng dấp của giao diện do lập trình viên chỉ định.
- Có sẵn trong thư viện chuẩn JDK từ bản 1.2 trở lên
2 javax.swing :
- Là một gói nằm trong thư viện JFC gồm nhiều Class và giao diện
(Interfaces) hỗ trợ mạnh cho việc lập trình giao diện đồ họa trên JDK
Các thành phần của Swing thường được bắt đầu bằng chữ J : Jbutton,
JTextField , Jlabel , JcheckBox , JRadioButton,…
3.Một số gói điển hình của Lớp Swing :
viền được định nghĩa Border không phải là những thành phần, thay vì thế, chúng
là những yếu tố đồ họa đặc biệt mà Swing sử dụng như những thuộc tính và đặt chúng xung quanh các thành phần Nếu như bạn muốn tạo ra border của riêng bạn, bạn có thể tạo lớp con từ những border có sẵn trong gói này, hoặc bạn có thể viết
mã cho một lớp mới.
4 javax.swing.colorchooser
Trang 13Hỗ trợ cho thành phần JColorChooser
5 javax.swing.event
Swing sử dụng để giao tiếp thông tin với các class
6 javax.swing.filechooser
7 javax.swing.plaf
Swing Trong gói này chứa các gói con là javax.swing.plaf.basic,
javax.swing.plaf.metal và javax.swing.plaf.multi
8.javax.swing.table
sắp xếp thông riêng biệt trong định dạng lưới với sự xuất hiện tương tự như bảng tính.