Thiết kế phần mềm trên Android

Một phần của tài liệu Quản lý, giám sát và điều khiển thiết bị bằng phần mềm trên Android thông qua mạng điện thoại di động (Trang 50)

4.3.1. Mô hình Usecase

Hình 4-3: Mô hình Usecase của phần mềm điều khiển

Trong đó:

Actor: Ngƣời dùng sử dụng phần mềm điều khiển trên thiết bị Android.

Add Device: Chức năng thêm mới một thiết bị có thể đƣợc quản lý và điều

khiển bởi phần mềm.

Update Device: Chức năng thay đổi các thông số của thiết bị điều khiển.

Manage Device: Chức năng quản lý thiết bị, có thể xem báo cáo, gửi các lệnh

điều khiển, xem các thông số, trạng thái mà thiết bị gửi lên.

Message Content: Xem dữ liệu mà thiết bị gửi lên.

Report: Xem các kiểu báo cáo, các loại thống kê, có thể theo thời gian,

theo 1 tham số nào đấy, với nhiều lựa chọn. Ví dụ: Với thiết bị kiểm soát công suất, có thể xem đƣợc mức công suất theo thời gian.

Command Control: Thiết lập cấu hình các tập lệnh điều khiển cho thiết

4.3.2. Mô hình Package

Hình 4-4: Mô hình Package của phần mềm điều khiển

Trong đó:

Main Package: Là phần xử lý các giao diện chính, các liên kết tới các chức

năng khác của chƣơng trình.

Device Manager: Phần này chứa thêm các phần nhƣ: Device Command,

Device Content, Device Report. Có chức năng quản lý, thiết lập các thông số, tổ chức lƣu trữ dữ liệu, tạo báo cáo cho quá trình hoạt động của các thiết bị. Connection: Thiết lập kết nối giữa phần mềm trên Android và thiết bị, đƣợc

SMS Connection: Xây dựng chức năng gửi và nhận tin nhắn, chuyển

sang mode SMS.

IP Connection: Xây dựng chức năng thiết lập kết nối, gửi và nhận dữ

liệu, chuyển sang mode IP.

Service Manager: Service độc lập của chƣơng trình, đƣợc khởi động ngay khi

chƣơng trình khởi động, hay hệ điều hành khởi động, chịu trách nhiệm hứng tất cả cả sự kiện sms input của các thiết bị đƣợc kiểm soát và cung cấp dịch vụ gửi tin nhắn đi khi chƣơng trình có yêu cầu.

SMS Receiver: Module nhận sự kiện SMS từ hệ thống.

File System to store data: Hệ thống các file dữ liệu đƣợc lƣu trên thẻ nhớ của

điện thoại Android.

4.3.3. Mô hình Class cùng mô hình hoạt động chi tiết của từng Modul

4.3.3.1. Main Package

4.3.3.1.1. Biểu đồ class và GUI

Main Package +onCreate() +onResume() +onPause() +onDestroy() +onCreateOptionsMenu() +onOptionsItemSelected() +onCreateDialog() MainActivity Activity

Hình 4-5: Biểu đồ Main class và giao diện

MainActivity class đƣợc kế thừa từ Activity class, giao diện màn hình này tƣơng đối đơn giản, là nơi sẽ đi tới các chức năng chính của chƣơng trình.

Tại màn hình này cũng có thể thiết lập cấu hình phần mềm bằng cách lựa chọn Preferences từ Menu.

4.3.3.1.2. Biểu đồ hoạt động của các function chính.

Hình 4-6: Biểu đồ hoạt động hàm onCreate() trong Class MainActivity

Quá trình hoạt động này cần phải thực hiện các bƣớc quan trọng: thiết lập giao diện, thiết lập các sự kiện nhập liệu của ngƣời sử dụng, khởi động Service của chƣơng trình. 4.3.3.2. Service Manager 4.3.3.2.1. Biểu đồ class Service Manager Service -intentReceiver -deviceListFileName +onCreate() +onDestroy() -processMessage() -checkPhoneExist() -storeSMSContent() -getPhoneOrDescription() ServiceManager

Hình 4-7: Biểu đồ ServiceManager class

ServiceManager class đƣợc kế thừa từ Service class, service này sẽ chạy thƣờng trú cùng với hệ điều hành và cung cấp dịch vụ báo hiệu tin nhắn từ hệ thống cũng nhƣ hỗ trợ quá trình tính toán, xử lý dữ liệu.

4.3.3.2.2. Biểu đồ hoạt động của các function chính.

ServiceManager::onCreate

Register to receive SMS

Hình 4-8: Biểu đồ hoạt động hàm onCreate() trong ServcieManage class

Hàm này phải thực hiện duy nhất một mục đích: đăng ký nhận thông báo nhận tin nhắn SMS từ hệ thống. intenReceiver: ServiceManager::intentReceiver Get message Call processMessage() function Check SMS Yes No

Hình 4-9: Intent xử lý sự kiện nhận SMS trong ServiceManager class

Hàm onRecive() của intent này đƣợc gọi khi có thông báo nhận tin SMS từ SMSReceiver class. Hàm này sẽ nhận lấy nội dung SMS sau đó gọi hàm processMessage().

Hình 4-10: Biểu đồ hoạt động hàm processMessage() trong ServiceManage class

Hàm này thực hiện việc lƣu trữ nội dung tin nhắn theo cấu trúc đã đƣợc phân rã, sau đó thông báo quảng bá cho các module khác của chƣơng trình biết có tin nhắn mới đã sẵn sàng cho việc sử dụng.

checkPhoneExist() function:

Hàm này sẽ thực hiện tìm kiếm trong cấu file lƣu trữ để xác định xem đã có thiết bị (số phone number) đƣợc quản lý bằng chƣơng trình hay chƣa. Hàm này thƣờng xuyên đƣợc sử dụng trong quá trình thêm mới thiết bị, lấy thông tin và xử lý thông tin của một thiết bị.

storeSMSContent() function:

Hình 4-12: Biểu đồ hoạt động hàm storeSMSContent của ServiceManager class

Chƣơng trình phần mềm sử dụng lƣu trữ dạng file cho việc lƣu trữ dữ liệu cũng nhƣ cấu hình, hàm này thực hiện việc lƣu trữ tin nhắn của thiết bị vào file thông tin tin nhắn của chính thiết bị đó, có kiểm tra sự tồn tại của file trƣớc đó.

getPhoneOrDescription() function:

ServiceManager::getPhoneOrDescription

Validate String Input

Split string input

Return Command or Content

Hàm này sẽ trả về số điện thoại (hay còn gọi là DeviceID) hoặc mô tả về thiết bị (có thể gọi là tên thiết bị).

4.3.3.3. SMS Receiver 4.3.3.3.1. Biểu đồ class SMS Receiver BroadcastReceiver +onReceive() SMSReceiver

Hình 4-14: Biểu đồ SMSReceiver class

SMSReceiver class đƣợc kế thừa từ BroadcastReceiver class, thực hiện duy nhất một nhiệm vụ thực hiện xử lý khi có sự kiện nhận tin nhắn từ hệ thống để thông báo tới ServiceManager class.

4.3.3.3.2. Biểu đồ hoạt động của các function chính.

onReceive() function:

Hình 4-15: Biểu đồ hoạt động hàm oReceive() của SMSReceiver class

Đƣợc gọi khi có các thông tin quản bá từ hệ thống, và chỉ xử lý khi thông tin đó là thông báo có tin nhắn mới. Khi đó, hàm sẽ thực hiện việc xử lý thô thông tin của tin nhắn và thông báo tới ServiceManager class.

4.3.3.4. Device Manager

4.3.3.4.1. Biểu đồ class

Hình 4-16: Biểu đồ class của DeviceManager

Trong biểu đồ này, việc giám sát, quản lý và diều khiển sẽ đƣợc thực thi thông qua khối chức năng này. Chƣơng trình sẽ thực hiện việc quản lý thiết bị thông qua AddDeviceActivity class, việc giám sát và điều khiển đƣợc đƣa gọi từ DeviceTabActivity class.

AddDeviceActivity cũng đƣợc kế thừa từ Activity class. Đặc biệt có thêm một class PhoneInfo, nhăm mô tả các thông số và thuộc tính của thiết bị.

AddDeviceActivity còn chứa thêm 2 class hỗ trợ là IgnoreCaseComparetor dùng cho việc sắp xếp danh sách các thiết bị, PhoneItemAdpter dùng cho quá trình tạo danh sách các thiết bị trên màn hình hiển thị.

4.3.3.4.2. Các màn hình chính

Hình 4-17: Giao diện quản lý và thêm thiết bị

Hình 4-18: Màn hình ContextMenu và cập nhật mô tả thiết bị

4.3.3.4.3. Biểu đồ hoạt động của các function chính.

DeviceTabActivity::onCreate() function:

Hàm này thiết lập và khởi tạo ba Intent tƣơng ứng là: DeviceContent, DeviceCommand và DeviceReport, sau đó thực hiệt add ba Intent này vào TabHost.

DeviceTabActivity::onCreate

Declare DeviceContent intent Declare DeviceCommand intent

Declare DeviceReport intent

Init 3 intents

Add 3 intents to TabHost

Hình 4-19: Biểu đồ hoạt động hàm onCreate() của DeviceTabActivity class

AddDeviceActivity::onCreate() function: AddDeviceActivity::onCreate call setContentView() call loadPhoneInforList() function Sort listPhoneInfo

Regis event for Button, listView

Hình 4-20: Biểu đồ hoạt động hàm onCreate() của AddDeviceActivity class

Hàm này cần phải thiết lập giao diện cho phần quản lý thiết bị, danh sách các thiết bị sẽ đƣợc hiển thị cùng những chức năng có thể can thiệp trực tiếp tới.

Hàm này cũng cần thực hiện việc đăng ký các sự kiện cho các đối tƣợng trên màn hình.

AddDeviceActivity::onCreateDialog

Show About Dialog

call inputPhoneInfo() function

Show alert phone exist dialog

Show alert not Null validation

Hình 4-21: Biểu đồ hoạt động hàm onCreateDialog của AddDeviceActivity class

Tùy từng nơi gọi và điều kiện gọi hàm này mà thực hiện việc hiển thị một Dialog với nội dung tƣơng ứng.

AddDeviceActivity::loadPhoneInfoList() function: AddDeviceActivity::loadPhoneInfoList

read phoneListFileName file

Read nextLine

Add phone to phoneList

return phoneList

Yes No

Hình 4-22: Biểu đồ hoạt động hàm loadPhoneInfoList() của AddDevieActivity class

Hàm này trả về một danh sách số điện thoại (hay cũng tƣơng ứng với danh sách thiết bị). Thông tin này sẽ đƣợc lấy từ hệ thống file lƣu trữ.

AddDeviceActivity::addPhoneNumber

Open file which store phoneList

Write phoneInfo at the end of file

and phoneInfo to listPhoneInfo

refresh GUI

Hình 4-23: Biểu đồ hoạt động hàm addPhoneNumber() của AddDeviceActivity class

Hàm này thực hiện việc thêm một thiết bị vào chƣơng trình quản lý, cần làm những việc sau: lƣu vào file danh sách thiết bị trong hệ thống, thêm vào danh sách hiện tại và thực hiện việc làm mới giao diện.

AddDeviceActivity::removePhoneNumber() function: AddDeviceActivity::removePhoneNumber

Remove the phone from listPhoneInfo

Clear data of the phone

Replace phoneListFileName with content of listPhoneInfo

Update GUI Yes

No

Hàm thực hiện việc gỡ bỏ một thiết bị trong danh sách quản lý, thực hiện các việc: gỡ bỏ thiết bị trong danh sách thiết bị từ hệ thống file, cập nhật giao diện.

AddDeviceActivity::updatePhoneDescription() function AddDeviceActivity::updatePhoneDescription

Show the dialog to allow change description of the phone

Update to store file

Refresh GUI Yes

No

Hình 4-25: Biểu đồ hoạt động hàm updatePhoneDescription()

Khi có yêu cầu cần phải cập nhật mô tả thiết bị, hàm này đƣợc sử dụng, thực hiện việc cập nhật hệ thống file, cập nhật giao diện.

AddDeviceActivity::clearPhoneList() function:

AddDeviceActivity::clearPhoneList

Call clearePhoneData() function

Clear content of phoneListFileName file

Cleare listPhoneInfo

Refresh GUI

Hàm này hỗ trợ việc xóa hẳn danh sách thiết bị đang đƣợc quản lý một cách nhanh chóng, xóa bỏ hệ thống file lƣu trữ, cập nhật giao diện.

AddDeviceActivity::importPhoneList() function: AddDeviceActivity::importPhoneList

Import all contact list to listPhoneInfo

Hình 4-27: Biểu đồ hoạt động hàm importPhoneList() của AddDeviceActivity class

Hàm này đƣợc xây dựng nhằm hỗ trợ tính năng tạo ngay lập tức danh sách thiết bị cần quản lý từ contact list của điện thoại Android. Tên của số điện thoại sẽ là phần mô tả của thiết bị, thiết bị có ID là số điện thoại.

AddDeviceActivity::getPhoneOrDesc() function: AddDeviceActivity::getPhoneOrDescription

Validate input string

Split the string

Return Phone or Description

Hình 4-28: Biểu đồ hoạt động hàm getPhoneOrDescription

Khi thực hiện đọc thông tin về về thiết bị từ file lƣu danh sách thiết bị trong hệ thống file, cần thực hiện việc tách số điện thoại và phần mô tả từ một chuỗi ký tự, hàm này thực hiện chức năng đó.

AddDeviceActivity::clearPhoneData() function:

Hàm này hỗ trợ việc xóa bỏ toàn bộ dữ liệu của một thiết bị đã hoạt động từ trƣớc đó, thực hiện việc xóa tất nội dung message đã lƣu, xóa tất cả danh sách tập lệnh điều khiển và cập nhật lại giao diện.

AddDeviceActivity::clearPhoneData

Validate Input

Delete file store message of the phone

Delete file store command of the phone

Hình 4-29: Biểu đồ hoạt động hàm clearPhoneData() của AddDeviceActivity class

Hàm này hỗ trợ việc xóa bỏ toàn bộ dữ liệu của một thiết bị đã hoạt động từ trƣớc đó, thực hiện việc xóa tất nội dung message đã lƣu, xóa tất cả danh sách tập lệnh điều khiển và cập nhật lại giao diện.

AddDeviceActivity::isMyServiceRunning() function: AddDeviceActivity::isMyServiceRunning

Open ServiceManager of OS

Get nextService name

Return TRUE Return FALSE Yes Yes No No

Kiểm tra trạng thái Service của chƣơng trình, hàm này thực hiện việc kiểm tra sự tồn tại tên Service của chƣơng trình trong danh sách tên các Service của hệ điều hành đang chạy.

AddDeviceActivity::onCreateContextMenu() function: AddDeviceActivity::onCreateContextMenu

Set context menu

Hình 4-31: Hàm onCreateContextMenu() của AddDeviceActivity class

Đƣợc xây dựng nhằm hỗ trợ tính năng “long click” lên danh sách các thiết bị đƣợc quản lý. Nó thực hiện việc thiết lập nội dung cũng nhƣ quản lý các sự kiện ngƣời sử dụng. AddDeviceActivity::onContextItemSelected() function: AddDeviceActivity::onContextItemSelected Get PhoneNumber by ID call updatePhoneDescription() function call removePhoneNumber() function No Yes

Hình 4-32: Biểu đồ hoạt động hàm onContextItemSelected()

Hàm thi hành theo lựa chọn của ngƣời dùng, lấy ID của danh sách các lệnh và thực hiện theo yêu cầu.

AddDeviceActivity::onCreateOptionsMenu

Call Create option menu

Hình 4-33: Biểu đồ hoạt động hàm onCreateOptionMenu()

Thực hiện việc hỗ trợ Menu cho ngƣời dung.

AddDeviceActivity::onPrepareOptionMenu() function: AddDeviceActivity::onPrepareOptionsMenu

Get MenuItem of the handleService

Set icon to pause

Set icon to play Yes

No

Hình 4-34: Biểu đồ hoạt động hàm onPrepareOptionsMenu()

Trƣớc khi hiển thị Menu của giao diện màn hình, chƣơng trình cần phải kiểm tra trọng thái của Service đang hoạt động, để hiển thị và kiểm soát cho đúng chức năng.

AddDeviceActivity::onOptionsItemSelected() function: Thực hiện các chức năng mà ngƣời sử dụng lựa chọn.

AddDeviceActivity::onOptionsItemSelected Show About dialog call clearPhoneList() Call importPhones() Get ServiceManager Intent Stop Service Start Service Yes No

Hình 4-35: Biểu đồ hoạt động hàm onOptionsItemSelected()

AddDeviceActivity::isExistPhone() function: AddDeviceActivity::isExistPhone

Validate phone

Get nextPhone in listPhoneInfo

Return TRUE Return FALSE Yes Yes No

Mục đích dùng kiểm tra sự tồn tại của 1 thiết bị đƣợc quản lý trong chƣơng trình hay chƣa.

AddDeviceActivity::inputPhoneInfo() function: AddDeviceActivity::inputPhoneInfo

Show dialog for input a phone info

Handle event input

Validate input

Insert new PhoneInfo

Hình 4-37: Biểu đồ hoạt động hàm inputPhoneInfo() của AddDeviceActivity class

Thực hiện việc thêm một thiết bị vào danh sách quản lý, có thực hiện việc xác nhận thông tin đầu vào, xử lý các sự kiện thêm mới và cập nhật lại giao diện.

4.3.3.5. Device Command

4.3.3.5.1. Biểu đồ class

Biểu đồ class này cho thấy các mối quan hệ trong quá trình quản lý tập lệnh của thiết bị, nó cũng mô tả về danh sách các thuộc tính của DeviceCommandActivity class.

DeviceCommandActivity đƣợc kế thừa từ Activity class.

DeviceCommandActivity chứa class CommandInfo dùng để lƣu trữ và quản lý các thông tin cũng nhƣ thuộc tính của các lệnh điều khiển.

DeviceCommandActivity chứa class CommandItemAdapter dùng cho việc hỗ trợ hiển thị danh sách lệnh điều khiển trên màn hình.

Device Command Activity -strPhoneNumber -strDescription -intentFilter -listCommand -commamdAdapter -attribute #onCreate() -loadCommandInfoList() -addCommandName() -removeCommandName() -updateCommandContent() -clearCommandList() +onCreateContextMenu() +onContextItemSelected() -getCommandOrContent() +IExistCommand() +inputCommandInfo() #onCreateDialog() +sendCommandControl() -sendSMS() DeviceCommandActivity +CommandName +CommandContent +CommandInfo() CommandInfo -commandArray +CommandItemAdapter() #getView() CommandItemAdapter ArrayAdapter

Hình 4-38: Biểu đồ class của DeviceCommand

4.3.3.5.2. Các màn hình chính

Hình 4-40: Giao diện ContextMenu, cập nhật và xác nhận truyền một Command

4.3.3.5.3. Biểu đồ hoạt động của các function chính.

onCreate() function:

Hàm này đƣợc gọi khi giao diện quản lý Command bắt đầu đƣợc khởi tạo, nó thực hiện việc thiết lập layout cho màn hình, khởi tạo các tham số cho màn hình, đăng ký các sự kiện cho ngƣời dùng can thiệp tới các thành phần.

loadCommandInfoList() function:

Hình 4-42: Biểu đồ hoạt động hàmloadCommandInfoList()

Hàm thực hiện việc lấy danh sách tập lệnh của thiết bị đang đƣợc quản lý từ file tập lệnh trong hệ thống file, sau đó cập nhật lại giao diện.

addCommandName() function:

DeviceCommandActivity::addCommandName

Open Command file of the phone

Add a command with name and content to end of ile

Add this command to list

Hình 4-43: Biểu đồ hoạt động hàm addCommandName()

Thực hiện thêm mới một lệnh điều khiển vào file lƣu trữ tập command của thiết bị, đồng thời thêm vào listCommand và cập nhật lại giao diện.

DeviceCommandActivity::removeCommandName

Find the Command in Command List

Remove the Command in list

Remove command line in the command file Yes

No

Hình 4-44: Biểu đồ hoạt động hàm removeCommandName()

Ngƣợc lại với hàm addCommandName(), hàm này thực hiện việc loại bỏ một lệnh của thiết bị.

updateCommandContent() funtion:

DeviceCommandActivity::updateCommandContent

Find the command in command list

Get the position

Update command in the command list

Replace content in command file with command list No

Yes

Hình 4-45: Biểu đồ hoạt động hàm updateCommandContent

Hỗ trợ việc cập nhật lại nội dung của một lệnh điều khiển của thiết bị. clearCommandList() funtion:

DeviceCommandActivity::clearCommandList

Clear all content of the command file which has the phone

Clear Command List

Hình 4-46: Biểu đồ hoạt động hàm clearCommandList()

Xóa bỏ toàn bộ danh sách tập lệnh điều khiển của một thiết bị. onCreateContextMenu() function:

DeviceCommandActivity::onCreateContextMenu

Set context_menu_command to MenuInflater

Hình 4-47: Biểu đồ hoạt động hàm onCreateContextMenu()

Cũng giống nhƣ các hàm hỗ trợ việc thực hiện “long click” của ngƣời dùng trong các Activity khác, DeviceCommand cũng có tập lệnh tƣơng ứng.

onContextItemSelected() function:

Hàm này luôn đi kèm với hàm onCreateContextMenu() trong các Activity, thực

Một phần của tài liệu Quản lý, giám sát và điều khiển thiết bị bằng phần mềm trên Android thông qua mạng điện thoại di động (Trang 50)

Tải bản đầy đủ (PDF)

(94 trang)