摘 要: 目前國內(nèi)水表抄表行業(yè)存在找表難、外出抄表員難管理,、水表漏抄和抄表界面不友好等問題,,給企業(yè)造成較大的經(jīng)濟(jì)損失。為避免上述現(xiàn)象的出現(xiàn),,設(shè)計(jì)了一款基于Android平臺的抄表機(jī)抄表軟件,。該軟件具有二維碼掃描,、GPS定位/地圖導(dǎo)航、拍照以及GPRS/WiFi通信等功能,。
關(guān)鍵詞: Android,;二維碼;GPS,;地圖導(dǎo)航,;GPRS/WiFi通信
目前水表抄表方式主要有IC智能卡水表、無線發(fā)射式,、抄表機(jī)抄表以及分線制集中抄表等[1],。IC智能卡水表是一種先充值后使用的智能水表,用戶往往由于無法很好地掌握充值時間造成突然停水的現(xiàn)象,;無線發(fā)射式和分線制集中抄表方式因其昂貴的前期投入和后期維護(hù)費(fèi)用,,暫無法廣泛推廣。抄表機(jī)抄表是目前國內(nèi)市場上采用最多使用最廣的方式,。
現(xiàn)有的抄表機(jī)抄表存在以下4個問題:(1)抄表機(jī)不能夠精確定位每一只水表,,導(dǎo)致找表困難;(2)供水企業(yè)難以掌握外出抄表員工的工作情況,,常出現(xiàn)有意估抄的情況,;(3)水表分布廣泛、不規(guī)律,,常常漏抄大量水表,;(4)現(xiàn)有抄表機(jī)界面不友好,不便于使用,。
鑒于此,,設(shè)計(jì)一款基于Android OS水表抄表機(jī)軟件。本軟件利用現(xiàn)有GPS定位技術(shù)實(shí)時記錄外出抄表員工的抄表路徑,,方便供水企業(yè)管理外出抄表員工,;本系統(tǒng)還具有地圖導(dǎo)航功能,可以方便抄表員在地圖上查詢水表地理位置以及行走路線,;同時,,利用現(xiàn)有成熟的GPRS/WiFi通信技術(shù)與服務(wù)器即時通信。此外,,為了提高抄表效率,,本系統(tǒng)采用二維碼掃描技術(shù)快速得到水表信息,省去抄表員在抄表機(jī)中查找的過程,;最后,,本系統(tǒng)增加對水表讀數(shù)拍照的功能,以便日后公司對抄表情況的抽查和復(fù)查。
1 抄表機(jī)軟件總體設(shè)計(jì)
抄表機(jī)軟件堆棧結(jié)構(gòu)如圖1所示,。主要包含以下模塊:
?。?)本地?cái)?shù)據(jù)庫設(shè)計(jì)。本地?cái)?shù)據(jù)庫用于存儲抄表相關(guān)數(shù)據(jù),,數(shù)據(jù)讀寫方便,,減少抄表機(jī)與服務(wù)器的通信。
?。?)二維碼掃描,。抄表機(jī)直接從印制在表體上的二維碼識別出該水表的相關(guān)信息,無需手動查找,。
?。?)抄表功能。通過手動或者二維碼掃描的方式找到對應(yīng)的水表,,輸入水表讀數(shù),。
(4)GPS實(shí)時定位,。對外出抄表員外出抄表路徑實(shí)時定位并記錄,,方便對其管理。
?。?)地圖導(dǎo)航,。地圖上顯示每一個水表的地理位置,并提供路線導(dǎo)航,。
?。?)網(wǎng)絡(luò)通信。利用GPRS/WiFi通信技術(shù)實(shí)現(xiàn)終端與后臺服務(wù)器的無縫連接,。
?。?)拍照功能。將水表表碼以水表圖片的形式存入數(shù)據(jù)庫中,,方便供水企業(yè)日后對抄表工作的抽查和復(fù)查,。
2 主要模塊介紹
2.1 抄表機(jī)數(shù)據(jù)庫
本地?cái)?shù)據(jù)庫用于存儲來自服務(wù)器的抄表任務(wù)單以便于抄表員抄表,。本地?cái)?shù)據(jù)庫主要由6張表組成,,分別為水表信息表(PDA_ShuiBiaoXX)、客戶信息表(PDA_KeHuXX),、用戶欠費(fèi)信息表(PDA_QianFeiXX),、抄表信息表(PDA_ChaoBiaoList)、冊本信息表(PDA_CeBenXX)和圖片信息表(PDA_MediaFile),。
抄表信息表中每個水表的ID(S_id)是唯一的,,與水表信息表中水表ID(S_id)構(gòu)成一對一的關(guān)系;一個抄表冊包含多個水表,通過冊本ID(C_id)與水表信息表構(gòu)成一對多的關(guān)系,;一個水表可以有多種欠費(fèi)信息,,通過水表ID(S_id)與欠費(fèi)信息表構(gòu)成一對多的關(guān)系;一個水表可以有多張圖片,,同樣通過水表ID(S_id)與圖片信息表形成一對多的關(guān)系,;一個客戶可以擁有多個水表,客戶信息表與水表信息表通過客戶ID(K_id)構(gòu)成一對多的關(guān)系,。根據(jù)以上所述,,可以構(gòu)建如圖2所示的關(guān)系圖,。
2.2 抄表功能
抄表功能是該軟件的基本功能,,其主要任務(wù)是將水表讀數(shù)寫入本地?cái)?shù)據(jù)庫以及記錄抄表過程中的異常情況。具體步驟如下:
?。?)輸入本次水表讀數(shù),;
?。?)計(jì)算本次用水量。從數(shù)據(jù)庫中讀出上次讀數(shù),,本次讀數(shù)減去上次讀數(shù)得到本次用水量,;
(3)將用水量及相關(guān)數(shù)據(jù)寫入數(shù)據(jù)庫,。當(dāng)確認(rèn)所抄表碼無誤后,,調(diào)用database的update方法[2]將數(shù)據(jù)寫入數(shù)據(jù)庫中。
2.3 二維碼識別
二維碼(dimensional barcode)是用某種特定的幾何圖形按一定規(guī)律在平面(二維方向上)分布的黑白相間的圖形記錄數(shù)據(jù)符號信息[3],。二維碼有很多種,,本系統(tǒng)采用在行業(yè)中應(yīng)用最成功的QR碼(Quick Response code),它以矩陣排列的形式存儲數(shù)據(jù),。
為實(shí)現(xiàn)QR碼的快速識別,,本軟件采用開源類庫Zxing實(shí)現(xiàn)。首先將識別出的信息以固定的格式輸出,,最后對輸出的信息進(jìn)行后續(xù)操作,。二維碼識別主要流程如下:
(1)完成初始化,,打開攝像頭,。初始化主要由Android項(xiàng)目的Activity來完成,包含view的初始化,,攝像頭硬件和驅(qū)動初始化以及Zxing類庫的初始化,。
setContentView(R.layout.qrcodescan);
CameraManager.init(getApplication()),;
CameraManager.openDriver(),;
?。?)攝像頭自動對焦。在CaptureActivityHandler中實(shí)現(xiàn)自動對焦,,并獲取一幀圖像,。
CameraManager.get().requestAutoFocus(this,R.id.auto_focus),;
?。?)條碼解碼。在CaptureActivityHandler中新建一個條碼解碼線程DecodeThread進(jìn)行解碼,,將圖像灰度化,、二值化、條碼區(qū)域定位,。如果解碼成功,,調(diào)用系統(tǒng)函數(shù)getSystemService(VIBRATOR_SERVICE)新建vibrator類,執(zhí)行方法vibrate(VIBRATE_DURATION)進(jìn)行震動及聲音提示,,并將條碼值返回給CaptureActivityHandler,;如果解碼失敗則獲取下一幀圖像繼續(xù)嘗試解碼。
?。?)后續(xù)處理,。最終解碼成功后,CaptureActivityHandler調(diào)用主程序中的回調(diào)函數(shù)將解碼出的信息作進(jìn)一步的處理,。
抄表機(jī)軟件QR碼解碼應(yīng)用流程如圖3所示,。
2.4 網(wǎng)絡(luò)通信
抄表機(jī)軟件采用WiFi和GPRS兩種網(wǎng)絡(luò)保證通信的可靠,實(shí)現(xiàn)有線網(wǎng)絡(luò)和無線網(wǎng)絡(luò)的無縫連接,,利用socket[4]通信構(gòu)建通信鏈路,,完成數(shù)據(jù)協(xié)議轉(zhuǎn)換等功能。
為提高抄表機(jī)軟件與服務(wù)器之間的通信效率,,本文初步設(shè)計(jì)一套通信協(xié)議,,采用指令加數(shù)據(jù)的形式,具體格式如表1所示,。
2.5 地圖導(dǎo)航
軟件結(jié)合百度地圖API和GPS的使用,,實(shí)現(xiàn)以下功能:定位并在地圖上標(biāo)注當(dāng)前所處位置;地圖顯示當(dāng)前位置到目的位置的最優(yōu)公交,、駕車以及步行路線,;地圖上標(biāo)識每一個水表的地理位置,抄表員可以直觀地查看水表分布,。以下是調(diào)用百度地圖API[5]實(shí)現(xiàn)路線導(dǎo)航的基本步驟(以駕車路線為例):
?。?)初始化,。完成授權(quán)驗(yàn)證,、BMapManager類初始化、百度地圖Activity初始化以及MapView的初始化。
?。?)設(shè)置地圖顯示模式,。主要是對是否使用內(nèi)置縮放控件以及縮放過程中是否顯示圖層的設(shè)置。
mMapView.setBuiltInZoomControls(true),;
//設(shè)置是否使用內(nèi)置縮放控件
mMapView.setDrawOverlayWhenZooming(true),;
(3)新建路線搜索模塊,。百度地圖API中有一個MKSearch類專門用于路線搜索,,它包含公交、駕車和步行等路線搜索,,并可以根據(jù)需要設(shè)置搜索策略,,如時間最短、距離最短,、換乘最少,、步行距離最短等。
mMKSearch=new MKSearch(),;
//新建一個MKSearch,,初始化搜索模塊
mMKSearch.setDrivingPolicy(MKSearch.ECAR_DIS_FIRST);
//設(shè)置策略
?。?)初始化搜索模塊,,建立搜索監(jiān)聽事件。百度地圖API中MKSearchListener()用于接收并處理MKSearch()返回的搜索結(jié)果,。
?。?)開始搜索。得到起點(diǎn)位置和終點(diǎn)位置后,,將起始點(diǎn)傳給搜索方法,,開始搜索,搜索完畢將結(jié)果返回,。
mMKSearch.drivingSearch(“杭州”,,startNode,“杭州”,,endNode),;
3 測試結(jié)果分析
該軟件各模塊的測試是在HTC G11手機(jī)上進(jìn)行的,該測試平臺各參數(shù)如下,。主屏尺寸:4英寸800×480像素,;操作系統(tǒng):Android OS 2.3.4;CPU型號:高通驍龍Snapdrago,;CPU頻率:1 024 MHz,;電池容量:1 450 mAh可拆卸式,。
3.1 抄表功能測試結(jié)果
圖4顯示的是抄表功能測試結(jié)果。圖4(a)是ID號為P12537水表對應(yīng)的抄表界面,。圖4(b)是通過SQLiteSpy數(shù)據(jù)庫軟件查看執(zhí)行抄表功能以后的數(shù)據(jù)庫相關(guān)信息,。圖中可以看到PDA_ChaoBiaoSJ表中水表編號P12537對應(yīng)的BenCiCM(本次抄碼)和I_ChaoJianSL(用水量)兩項(xiàng)的值與圖4(a)中填入的數(shù)據(jù)一致,因此數(shù)據(jù)寫入數(shù)據(jù)庫成功,。
3.2 二維碼識別測試結(jié)果
圖5是QR碼識別測試結(jié)果圖,。圖5(a)是QR碼掃描過程界面;圖5(b)是識別結(jié)果顯示界面,;圖5(c)是選擇“確定”后的相應(yīng)抄表界面,。本次實(shí)驗(yàn)結(jié)果表明,該QR碼識別方法識別速度快,、準(zhǔn)確率高,、糾錯能力強(qiáng),能夠滿足本系統(tǒng)的要求,。
3.3 網(wǎng)絡(luò)通信測試結(jié)果
利用WiFi/GPRS主要是用于發(fā)送單個抄表數(shù)據(jù)(含圖片)和抄表數(shù)據(jù)庫,。考慮到網(wǎng)絡(luò)不穩(wěn)定而導(dǎo)致傳輸中斷的情況,,軟件設(shè)計(jì)時采用大文件斷點(diǎn)上傳技術(shù),。實(shí)驗(yàn)結(jié)果表明,軟件可實(shí)現(xiàn)網(wǎng)絡(luò)重連后續(xù)傳文件,,提高效率,。
3.4 地圖導(dǎo)航測試結(jié)果
圖6是GPS定位及地圖導(dǎo)航測試結(jié)果界面,圖6(a)中地圖中心點(diǎn)是抄表員當(dāng)前位置在地圖上的顯示,,圖6(b)中線顯示的是當(dāng)前位置到目的地的駕車路線(點(diǎn)擊每一個帶箭頭的節(jié)點(diǎn)將會提示行走方向及距離),。
針對現(xiàn)有抄表機(jī)軟件不能滿足水表抄表行業(yè)需求的現(xiàn)狀,本文設(shè)計(jì)了一款基于Android OS的抄表機(jī)軟件,。重點(diǎn)介紹了軟件中數(shù)據(jù)庫設(shè)計(jì),、二維碼識別應(yīng)用、網(wǎng)絡(luò)通信及地圖導(dǎo)航等模塊,。本軟件基于Android操作系統(tǒng),,增加現(xiàn)有抄表機(jī)沒有的二維碼掃描、地圖導(dǎo)航等功能,,彌補(bǔ)了現(xiàn)有抄表機(jī)存在的一些不足,。
參考文獻(xiàn)
[1] 石巖峰,蔡洪光,,尹佳輝.水表抄表系統(tǒng)的發(fā)展與趨勢分析[M].科技風(fēng),,2009(8):204.
[2] 吳亞峰,索伊娜.Android核心技術(shù)與實(shí)例詳解[M].北京:電子工業(yè)出版社,,2012.
[3] RUSS A. Two dimensional bar codes[J]. Adams Cemmuniea-fions,, 2002,,27(4):15-18.
[4] 劉邦桂,李正凡.用Java實(shí)現(xiàn)流式Socket通信[J].華東交通大學(xué)學(xué)報(bào),,2007,,24(5):110-112.
[5] 文斌,,李代偉.基于Android的移動公交輔助導(dǎo)航系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)[J].成都信息工程學(xué)院學(xué)報(bào),,2012(5):437-442.