車載導航畢業(yè)設計論文_第1頁
車載導航畢業(yè)設計論文_第2頁
車載導航畢業(yè)設計論文_第3頁
車載導航畢業(yè)設計論文_第4頁
車載導航畢業(yè)設計論文_第5頁
已閱讀5頁,還剩51頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

Denso 車載導航系統(tǒng) -道路限制和收費站 導航 子系統(tǒng)的設計與實 現(xiàn) Denso Navigation System -Design and Implementation of Road Restrictions and Toll Station Navigation Subsystems 畢業(yè)設計(論文)任務書 畢業(yè)設計(論文)題目: Denso 車載導航系統(tǒng) 道路限制和收費站子系統(tǒng)的設計與實現(xiàn) 基本內容: 本課題將要完成的內容是在 Denso車載導航系統(tǒng)已有的導航機制基礎上,完成道路限制和收費站導航子系統(tǒng)的設計與實現(xiàn),需要完成的功能是對某些時間段禁止通行的道路和行駛道路上的收費站進行提示(包括文字、圖示和聲音)。 為此,需要學習 Denso 車載導航系統(tǒng)實現(xiàn)的基本原理和總體框架。在此基礎上學習取得地圖數(shù)據(jù)(包括讀取和解析),對道路屬性信息進行處理和判斷等內容。在完成本課題期間還需要掌握 ITRON系統(tǒng)在 windows系統(tǒng)下模擬實現(xiàn), cygwin編譯環(huán)境和 .net 編譯器等工具的使用。 畢業(yè)設計(論文)專題部分: 題目: 基本內容: 學生接受畢業(yè)設計(論文)題目日期 第 1 周 指導教師簽字: 2011 年 2 月 28 日 摘要 -I- Denso 車載導航 道路限制和收費站導航子系統(tǒng)的設計與實現(xiàn) 摘 要 隨著社會的發(fā)展, 車輛不斷增多,道路狀況日漸復雜,擁有一個好的車載導航系統(tǒng)對于駕駛員來說變得十分重要。同時,導航系統(tǒng) 與車內的空調、視聽娛樂、電話等功能的結合也將給駕駛員帶來極大方便與享受。 這就對 車載 導航技術產生了巨大的市場需求。因此車載導航軟件的開發(fā)是非常具有現(xiàn)實意義的工作。 本文主要論述了 Denso 車載導航系統(tǒng)導航功能中的兩個功能,對具有時間限制的道路和收費站進行導航。所謂的時間限制就是在特定的一段時間內某條道路不允許車輛通行。完成本系統(tǒng)首先需要 研究 Denso 車載 導航系統(tǒng)的整體框架,了解系統(tǒng)的運行環(huán)境,通信機制以及掌握開發(fā)過程中需要用到的技術。在此 基礎上深入研究導航模塊的實現(xiàn),然后實現(xiàn)上述的兩個功能。通過對已有導航系統(tǒng)的研究,確定了需要在系統(tǒng) Task 中進行修改以實現(xiàn)的兩個模塊的功能。全文按照軟件的開發(fā)流程進行描述,首先對本導航系統(tǒng)所用的 ITRON系統(tǒng)和 KIWI 地圖數(shù)據(jù)格式兩項關鍵技術進行簡要介 紹,然后針對導航模塊進行系統(tǒng)分析,接下來是深入到所需實現(xiàn)的功能模塊中進行系統(tǒng) Task 級的設計。 依據(jù)系統(tǒng)分析和系統(tǒng)設計完成系統(tǒng)實現(xiàn)。最后在模擬導航 機 PCNavi 上進行了系統(tǒng)測試工作,確保正確性。 經(jīng)過系統(tǒng)測試,完成了道路限制和收費站導航子系統(tǒng)設計與實現(xiàn)的工作,正確的實現(xiàn)了導航功能,即汽車行駛時,當前方道路上路上存在收費站或者時間限制的道路時,對用戶進行文字、圖片和語音提示以達到導航目的。 關鍵詞 : 車載導航系統(tǒng), ITRON,時間限制, Task Abstract -II- Denso Navigation System -Design and Implentation of Road Restrictions and Toll Station Navigation Subsystems Abstract With the development of society, increasing traffic and road conditions more and more complex, to have a good car navigation system become very important to drivers. Meanwhile, car navigation systems combine with air-conditioning, entertainment, telephone and other functions will also bring great convenience and enjoyment to the driver.This has created an enormous market demand for navigation technology. Therefore, to develop car navigation software is of great significance. This paper mainly discusses two functions of Denso car navigation system, they are toll station navigation and time restricted road navigation. Time restricted means vehicles are not allowed on this road within a specific period of time. Research on the framework of Denso navigation system, system environment, communication mechanism and other technology, which is the basis of the paper, are necessary. The two modules should be implemeted by means of modifing system task.The paper is base on software development process.It begins with introduction of ITRON system and KIWI map data. Then, the paper will give system analysis of navigatioin module.The system design, which concentrates on system task, comes after. System implementation is based on system analysis and system design. Finally, system testing is excuted on the simulated navigation system PCNavi to ensure the accuracy. Design and implementation of time restricted navigation and toll station navigation subsystems are completed after system testing, the navigation is correct.When the car meet with time restricted road or toll station on its way, the text, pictures and voice prompts should be provided in order to achieve the purpose of navigation. Key Words: car navigation, ITRON, time restricted, Task 目錄 -III- 目 錄 摘 要 . I Abstract . II 第 1 章 緒 論 . 1 1.1. 車載導航發(fā)展簡介 . 1 1.2. 國內外發(fā)展現(xiàn)狀 . 1 1.3. 車載導航的發(fā)展趨勢 . 2 第 2 章 關鍵技術介紹 . 3 2.1. ITRON 系統(tǒng) . 3 2.1.1. 系統(tǒng)綜述 . 3 2.1.2. 任務及通信 . 3 2.2. KIWI 格式地圖數(shù)據(jù) . 5 第 3 章 系統(tǒng)分析 . 7 3.1. 系統(tǒng)功能 . 7 3.1.1. 道路限制導航模塊 . 7 3.1.2. 收費站導航模塊 . 8 3.1. 系統(tǒng)結 構 . 9 3.1.1. 系統(tǒng)功能框架 . 9 3.1.2. DG 模塊概要 . 10 3.2. 信息流程 . 錯誤 !未定義書簽。 3.2.1. 信息輸入 . 11 3.2.2. 信 息處理及輸出 . 11 3.3. 開發(fā)環(huán)境 . 12 第 4 章 系統(tǒng)設計 . 13 4.1. 架構概述 . 13 4.2. 系統(tǒng) Task 級設計 . 14 4.3. 道路限制導航模塊 . 15 4.3.1. 功能點及對應 Task 分析設計 . 15 4.3.2. 重要函數(shù)設計 . 20 4.4. 收費 站導航模塊 . 21 4.4.1. 功能點及對應 Task 分析設計 . 21 4.4.2. 重要函數(shù)設計 . 25 目錄 -IV- 第 5 章 系統(tǒng)實現(xiàn) . 27 5.1. 系統(tǒng) Task 級實現(xiàn) . 27 5.2. 道路限制導航模塊 . 28 5.2.1. 系統(tǒng)實現(xiàn)概要 . 28 5.2.2. 重要函數(shù)實現(xiàn) . 29 5.3. 收費站導航模塊 . 33 5.3.1. 系統(tǒng)實現(xiàn)概要 . 33 5.3.2. 重要函數(shù)實現(xiàn) . 33 第 6 章 系統(tǒng)測試 . 41 6.1. 道路限制導航模塊 . 41 6.1.1. 測試方案 . 41 6.1.2. 測試結果 . 42 6.2. 收費站導航模塊 . 44 6.2.1. 測試方案 . 44 6.2.2. 測試結果 . 45 第 7 章 結 論 . 47 參考文獻 . 48 致 謝 . 49 第 1 章 緒論 -1- 第 1章 緒 論 近年來,隨著我國的汽車銷售總量和私人購車數(shù)量逐年上升、人們出行頻率的增加,以及人們對生活質量和信息服務質量要求的不斷提高,車載導航系統(tǒng)正逐漸顯示出其強大的生命力、廣闊的應用前景和巨大市場潛力 1。因此研究探索車載導航技術,使之更好的為人們服務是一項長遠、具有重要意義,而且很有前景的工作。本文是在已有導航機制的基礎上進行部分功能的更新,旨在于了解熟悉車載導航 系統(tǒng)的相關知識,并希望對車載導航功能的發(fā)展有所作用。 1.1. 車載導航發(fā)展簡介 最初的汽車導航系統(tǒng)是在單畫面 CRT(陰極射線管)的前面貼上印刷了地圖的透明封條,在 CRT 畫面上顯示自車位置的系統(tǒng)。 1989 年汽車導航第一次采用了地圖匹配技術。就是把通過推測導航法計算出來的車輛的行駛軌跡和存放在 CD-ROM 里的道路形狀相比較,找出自車的行駛道路,確定自車位置。到 1990 年第一次采用了 GPS 定位技術。 1994年出現(xiàn)了具有真正意義上導航能力的導航系統(tǒng) 2。到了 1996 年, VICS 設備被引入到導航系統(tǒng),有了有交通信息支持的數(shù) 據(jù)庫實現(xiàn)了動態(tài)導航 3。 至此,汽車導航系統(tǒng)的導航功能已基本成熟。現(xiàn)今的導航系統(tǒng)除了具有動態(tài)導航的功能外,還有檢索功能、網(wǎng)絡功能、電話功能、檢索周邊環(huán)境、目的地經(jīng)由地信息、計算最優(yōu)路徑、自動檢索硬件環(huán)境等功能 4。 1.2. 國內外發(fā)展現(xiàn)狀 在發(fā)達國家,車載 GPS 導航系統(tǒng)技術已經(jīng)非常成熟,從全球來看,日本和美國 GPS導航產品是領先的。日本的車載 GPS 導航系統(tǒng)技術和使用覆蓋率均處于全球霸主地位,日本導航軟件和地圖數(shù)據(jù)還在不斷發(fā)展和更新版本 5。近幾年日本的車載導航軟件很多是基于 ITRON 系統(tǒng)的 6,本文第二章會 具體介紹此系統(tǒng)。現(xiàn)在主流的導航電子地圖數(shù)據(jù)也是由日本 KIWI 協(xié)會 (KIWI-W Consortium)制定的標準 KIWI 地圖數(shù)據(jù)格式。 它是專門針對汽車導航的電子數(shù)據(jù)格式,旨在提供一種通用的電子地圖數(shù)據(jù)的存儲格式,以滿足嵌入式應用快速精確和高效的要求。該格式是公開的,任何人都可使用 7。 我國 GPS 車載市場還處在發(fā)展初期 ,從系統(tǒng)的技術水平與產品的質量和成熟程度來說,都是比較落后的。實時交通信息發(fā)布和完善的導航電子地圖的提供與更新機制, 第 1 章 緒論 -2- 均缺乏實際的解決方案和途徑 8。國內從事導航軟件開發(fā)的公司也比較少,大部 分也是在做外包的工作。 1.3. 車載導航的發(fā)展趨勢 導航技術發(fā)展的動態(tài)和趨勢主要體現(xiàn)在以下幾個方面 9: ( 1) 硬件平臺多樣化 目前的導航產品已經(jīng)形成了包括 CAR-PC、車載 CD-ROM/DVD、掌上電腦和其他多種多樣的平臺。 ( 2) 導航電子地圖的標準化 日本的導航電子地圖標準 KIWI、歐盟等國家和地區(qū)的 GDF 地理數(shù)據(jù)文件等都制定了相應的導航用電子地圖的規(guī)范與標準,為導航系統(tǒng)及智能交通系統(tǒng)的建設提供了基礎。 ( 3) 無線通信技術的加入 通過無線通訊可以實現(xiàn)行進中的信息查詢及導航電子地圖下載,使得導航系統(tǒng)向 LBS服務(基于位置的服 務)方向轉化。 ( 4) 導航語音識別與合成技術 如果采用語音接口,對計算機的訪問時間就可以縮短,而像觸摸按鈕和鍵盤等都可以取消了,這很大程度上提高了導航的效率。 ( 5) 地圖表現(xiàn)形式多樣化 傳統(tǒng)的二維平面式地圖正在被新的更具表現(xiàn)力的三維地圖所取代。 第 2 章 關鍵技術介紹 -3- 第 2章 關鍵技術介紹 本導航系統(tǒng)采用的是 ITRON 嵌入式系統(tǒng),所用的地圖數(shù)據(jù)是 KIWI 格式的 10。因此有必要對這兩項技術作簡要介紹。 2.1. ITRON 系統(tǒng) 2.1.1. 系統(tǒng)綜述 ITRON( Industrial the Real-Time Operation System Nucleus)工 業(yè)實時操作系統(tǒng)中心 提出的實時多任務系統(tǒng)規(guī)范。它具有標準的實時內核,適用于任何小規(guī)模的嵌入式系統(tǒng)。 ITRON 系統(tǒng)具有以下特點 11: ( 1) 多任務支持 ( 2) 事件驅動基于優(yōu)先級的調度 ( 3) 任務間的通信與同步 ( 4) 實時時鐘控制 ( 5) 完全可搶占內核硬實時響應 ITRON 規(guī)范中定義了一系列 C 語言接口庫,應用系統(tǒng)可以利用這些接口庫實現(xiàn)應用與操作系統(tǒng)的相連。 2.1.2. 任務及通信 ( 1) Task 任務是一個具有獨立功能的無限循環(huán)的程序段的一次運行活動。任務具有動態(tài)性、并行性、異步獨立性的特點。 動態(tài)性任務的狀態(tài)是不斷變化的,一般分為休眠態(tài) (dormant), 就緒態(tài) (ready),運行態(tài)(running),掛起態(tài) (suspended) ,睡眠態(tài) (sleep)等 12。 并行性是指系統(tǒng)中同時存在多個任務,它們宏觀上是同時運行的。 異步獨立性任務是系統(tǒng)中獨立運行的基本單元也是內核分配和調度的基本單元每個任務各自按相互獨立的不可預知的速度運行,走走停停。 第 2 章 關鍵技術介紹 -4- 每個任務都要安排一個決定其重要性的優(yōu)先級,都有一個無限循環(huán)的程序段規(guī)定其功能,并相應有一個數(shù)據(jù)段、堆棧段及一個任務控制塊 (保存 CPU 的現(xiàn)場、狀態(tài)等 )。 ( 2) Event Flag 在多任務處理系統(tǒng)中,需要等到一個任 務終了后,其他任務再開始啟動的等候功能,這個時候,需要擁有對其他任務是否終了進行判斷的能力, ITRON 系統(tǒng)中提供了 Event Flag來實現(xiàn)這個機能。 ITRON 系統(tǒng)中,一個 Event Flag 是 ITRON 工作區(qū)中的一個 32 位的變量。 32 位中的每一位都是表示一個事件標志,事件標志有兩種狀態(tài),設置( 1)和清除( 0)。當一個標志處于設置狀態(tài)時,表示相關的事件已經(jīng)發(fā)生了,任務可以使用事件標志來向其他任務發(fā)送信號,表示事件已發(fā)生 13。 一般來說, Event Flag 為任務之間的等待操作提供了場所,下面是其操作 方法。 圖 2.1 表示了兩個 Task 通過 32Bit Event Flag 傳遞信息的。 3 2 B i t E v e n t F l a gT a s k W a i t QT a s k A T a s k Bs e t _ f l a gw a i t _ f l a gS t a t e m i g r a t i o n 圖 2.1 32Bit Event Flag 使用方法示意圖 任務間的等候需要能夠傳達 Event 的任務和等待 Event 發(fā)生的任務,傳達 Event 任務通過發(fā)行 set_flag 調用來傳遞信息,另一方面等待 Event 任務對事件發(fā)行等待調用,并且參照等候模式。 因為 Event Flag 是一個 32Bit 的位群,所以在進行 Event Flag 的設定的時候可以按照條件的邏輯進行設定 ,主要的邏輯有 And 和 Or 兩種,需要根據(jù)實際情況進行有選擇的使用。 And:多個條件同時存在的時候,才滿足任務的運行條件。 Or:當設定的多個條件有一個滿足的時候,運行條件成立。 ( 3) MailBox 第 2 章 關鍵技術介紹 -5- 為了實現(xiàn)任務之間的通信功能, ITRON 提供了郵箱。郵箱包含有多任務應用的等待隊列和郵箱專用的信息等待隊列,除了任務之間的通信功能使用,也作為任務之間的協(xié)作功能使用。 當一個任務執(zhí)行發(fā)送原語時,有兩種可能性,一種可能是接收者已經(jīng)處于等待狀態(tài);另外一種可能是消息發(fā)送時,接收者沒有處于等待收信狀態(tài)。 消息等待方式的實現(xiàn)方 法是為 Message 提供等待隊列作為緩沖,并且對于從隊列中取得信息的方式提供了兩種方式作為支持:基于 FIFS 的等待機制和基于優(yōu)先級的等待機制。 ITRON 系統(tǒng)提供的方法是為任務提供等待隊列,并且系統(tǒng)分配消息的方式是基于 FIFS方法的,不區(qū)分任務的優(yōu)先級別。 圖 2.2 表明了 Task 之間通過 MailBox 傳遞信息的使用示例。 T a s k W a i t QT a s k A T a s k Bs n d _ m s gr c v _ m s gM e s s a g e QT a s k Br c v _ m s gT a s k Br c v _ m s gF C F Sm s g _ m a keFIFO 圖 2.2 Task 利用 MailBox 進行通信示意圖 在任務之間的信息通信里,需要給郵箱分配送信的任務(發(fā)報任務)和接受這個信息的任務(接受任務)。這時如果郵箱里已經(jīng)有任務被排列在隊列里,信息就會被傳遞給等待隊列里的任務中。任務專用隊列的先頭任務將會從 Wait 狀態(tài)遷移到 Ready 狀態(tài)。但是如果郵箱中還沒有任務被排列在隊列中,信息就會被排列到信息專用的隊列中。發(fā)行 snd_msg調用的任務不進行狀態(tài)遷移 13。 2.2. KIWI 格式地圖數(shù)據(jù) 本文描述的導航系統(tǒng)是用 KIWI 數(shù)據(jù)格式來存儲地圖信息的, KIWI 數(shù)據(jù)的分類主要由 第 2 章 關鍵技術介紹 -6- 以下幾部分構成 14: Parcel 數(shù)據(jù):主要用于描畫,也被稱作描畫數(shù)據(jù),數(shù)據(jù)的存儲主要的一些坐標的記錄,和相關的屬性。根 據(jù)所存的點、線、面的信息,進行顯示其中包括背景、道路、文字。這些數(shù)據(jù)是構成地圖的基本元素。 Region 數(shù)據(jù):主要用于徑路探索,這些數(shù)據(jù)的組織形式也是為了方便最優(yōu)路徑的探索。region 數(shù)據(jù)中主要強調了道路的接續(xù),交通限制,通行方向等屬性,因此能夠應用于徑路探索中。 導航數(shù)據(jù):主要用于道路提示導航,就是在車行駛過程中提供一些信息,比如交叉點名稱,道路名稱,前方交叉的道路的目的地,等等。 畫像數(shù)據(jù):提供高速道路上主要交叉點的一些情況,表示各個方向上的目的地。 聲音數(shù)據(jù):保存在道路導航過程中所能提供的所有的聲音 信息。 檢索數(shù)據(jù):保存了地圖數(shù)據(jù)中主要的點的信息,能夠提供這個點上具有的地圖要素的詳細信息。 描畫參數(shù)數(shù)據(jù):保存地圖描畫時各種要素描畫的參數(shù)信息,比如某某道路需要描畫多寬,某個背景需要使用什么顏色來描畫,某種文字需要描畫成什么顏色等等。 在 KIWI 數(shù)據(jù)的存儲方面,地圖采用了分層和分塊處理。為了滿足對于不同比例尺條件下數(shù)據(jù)處理或檢索的需要,把地圖分層( Level)存儲。一般在最底層存儲最詳細的數(shù)據(jù),而上層逐漸進行數(shù)據(jù)的抽取,在進行數(shù)據(jù)處理或檢索時,按從上向下的順序處理,以最快的速度對數(shù)據(jù)進行處理。在分層數(shù)據(jù)的 基礎上對數(shù)據(jù)進行分塊存儲,便于數(shù)據(jù)的取得和管理,從而達到了快速讀取數(shù)據(jù)的目的 15。 第 3 章 系統(tǒng)分析 -7- 第 3章 系統(tǒng)分析 3.1. 系統(tǒng)功能 車載導航系統(tǒng)的功能有很多,包括定位,地圖顯示,導航,查詢和娛樂等功能。本文只是針對導航部分的功能。 本文將在汽車導航系統(tǒng)的導航模塊中添加兩個擴展功能,功能名稱分別是“收費站導航”和“道路時間限制導航”:在駕駛者行駛過程中,當自車前面有收費站或有時間限制的道路等情況時,給以文字、圖示和聲音的提示,起到預警的作用。 3.1.1. 道路限制導航模塊 在道路時間限制功能的需求文檔中規(guī)定的新增功能為: 當自車處于 on route 狀態(tài), 進入時間限制區(qū)間時,進行導航。 ( 1) 概要導航提示: 如果行車路線含有時間限制的道路,在概要導航提示的時候提示:在導航屏幕上彈出文字(以下簡稱為 ONS, on screen 的縮寫)“ Time restricted roads on this route.”。 ( 2) 時間限制 Mark 表示: 時間限制道路進入點的導航點 Mark 表示為 。 ( 3) 時間限制 ONS 警告: 當汽車進入時間限制的道路時,進行警告。彈出 ONS:“ You will reach time restricted roads. Please respect the local traffic regulations.”;并且進行語音提示:“ Traffic restrictions may apply. Please respect the local traffic regulations.”。 ( 4) 時間限制擴大圖 Mark 表示: 車輛進入具有時間限制的道路上時正常為其導航,但是在導航屏幕左側的擴大圖中岔路點的 Mark 更改為 。 ( 5) TurnList 表示: 行車線路含有時間限制道路,在導航屏幕左側提示岔路場合如何轉向的列表(以下稱為 TurnList)中將含有時間限制道路的岔路場合 Mark 顯示 為 灰色 的 箭頭 。 第 3 章 系統(tǒng)分析 -8- 3.1.2. 收費站導航模塊 根據(jù)項目需求說明書,收費站導航的新增功能為: ( 1) Turnlist 中收費站導航提示 : 把行車路線上存在的收費站作為 TurnlistPoint 進行 List 化。即 在 Turnlist 中添加收費站信息,進行導航提示。 導航提示內容: 收 費站名稱 ,當該收費站沒有名稱時,顯示文本 TOLL BOOTH 車輛到收費站的距離 /收費站到 TurnlistPoint 的 距離 收費站圖標 ( 2) 收費站擴大圖提示 : 行車線路上存在的收費站以擴大圖的形式進行提示。 導航提示內容:收費站設計圖片如圖 3.1 所示。 圖 3.1 收費站 mark 圖片 ( 3) 輔助導航中收費站提示 : 在輔助導航中添加收費站的導航提示 。 文本 TOLL BOOTH 車輛到收費站的距離 收費站圖標 ( 4) 收費站聲音提示 當車輛到收費站的距離為 L時,發(fā)聲。 L 滿足聲音提示條件如表 3.1 所示。 第 3 章 系統(tǒng)分析 -9- 表 3.1 聲音輸出時間 進入道路種別 輸出時機 一般道 Residential L=400m Non-residential L=400m 高速進出道 (SA.PA 道 ) L=800m 都市間高速 L=2000m 其中 SA 代表 Service Area; PA 代表 Parking Area。 3.1. 系統(tǒng)結構 3.1.1. 系統(tǒng)功能框架 導航系統(tǒng)功能結構如圖 3.2 所示。本文所論述的內容在其中的 DG 模塊。 導 航 系 統(tǒng)V PM A PD GR PN O T EV I C S V I 圖 3.2 系統(tǒng)功能結構圖 ( 1) HMI (Human & Machine Interface) HMI 實現(xiàn)的是用戶的操作界面,是用戶與導航系統(tǒng)交互的紐帶。用戶通過 HMI 告訴導航系統(tǒng)想要進行的操作, 導航系統(tǒng)再通過 HMI 顯示出來。達到人機交互的目的。 ( 2) DG (Driver Guidance) DG 在司機需要的時候,提示正確的行進方向,能夠準確到達目的地的動態(tài)和靜態(tài)信息等。其主要功能是:交叉點擴大圖和聲音提示。 第 3 章 系統(tǒng)分析 -10- ( 3) MAP MAP 即地圖描畫,導航系統(tǒng)中的地圖描畫是指、根據(jù)應顯示的地點位置從地圖 Data base 讀入地點信息,并根據(jù)描畫算法進行描畫及顯示。 ( 4) NOTE NOTE 組件為用戶提供信息的檢索和管理功能。包括導航信息和用戶自定義信息兩部分。導航信息是導航系統(tǒng)提供的數(shù)據(jù),例如 Disc 數(shù)據(jù)、 Vics 數(shù)據(jù)等,而 用戶自定義信息是用戶自己設定的信息,例如 Mark 等。 用戶檢索時可以檢索所有兩種信息,提供信息列表,詳細情報等功能。而管理只是針對用戶自定義信息,主要是提供了登錄,刪除,修改等功能 ( 5) RP (Route Production/Route Planning) RP 就是在給定自車位置和目的地的情況下,按照用戶設定的不同條件,計算出一條或多條從自車位置到目的地的花費 (根據(jù)用戶的設定,可能是指時間,費用等 )最少的最優(yōu)路以供用戶使用。 ( 6) VP (Vehicle Position) VP 即車輛定位,即:車行過程中,實時計算 出車輛位置。車輛定位方法有自行定位法、 GPS 全球衛(wèi)星定位法、復式定位法、地圖匹配法等。 3.1.2. DG 模塊概要 DG(Driver Guidance)即對駕駛員的引導。對用戶來說,是整個導航系統(tǒng)中最重要,最基本的功能。本文研究論述的內容就是這個模塊中的一部分,在此進一步的分析導航模塊和其它模塊的聯(lián)系,如圖 3.3 所示。 H M I ( 畫 面 表 示 )A P I導 航徑 路 描 畫檢 索 D S 聲 音現(xiàn) 在 地 圖 3.3 導航模塊與其它模塊的關系圖 第 3 章 系統(tǒng)分析 -11- 導航模塊主要是從徑路、現(xiàn)在地、檢索、 DS 四個模塊中取得信息,做成相應功能所需要的數(shù)據(jù),然后發(fā)送給描畫,聲 音,和 API 模塊。最終直接體現(xiàn)給用戶信息的是 HMI和聲音這兩個模塊。 3.2. 信息流程 現(xiàn)在的導航系統(tǒng)主要是通過處理接收到的位置、道路、自身信息等,計算并表示出用戶要求的道路,從而起到引導用戶的作用。并能夠根據(jù)用戶的選擇來完成一些其他的動作。下面將分以下幾部分來介紹導航系統(tǒng)的數(shù)據(jù)。 3.2.1. 信息輸入 信息的輸入主要有以下幾部分來組成: GPS 信息、 KIWI 數(shù)據(jù)、 VICS 情報、用戶操作要求。 ( 1) GPS 信息 GPS 衛(wèi)星定期地發(fā)送時刻情報和衛(wèi)星軌道情報。導航系統(tǒng)實時接收 GPS 的信息,來確定自車位置、速度等信息,通過這些信息的進一步處 理,做成為下一步的計算提供的有效數(shù)據(jù)。 ( 2) KIWI 數(shù)據(jù) 包括導航數(shù)據(jù)、畫像數(shù)據(jù)、聲音數(shù)據(jù)、檢索數(shù)據(jù)。 ( 3) VICS 情報 VICS 是 Vehicle Information and Communication System 的簡稱。在 VICS Center 收集并編輯交通信息,將阻塞和交通限制等的道路交通信息實時發(fā)送出去,由車載導航系統(tǒng)以文字和圖形表示。 VICS 信息 24 小時 365 日提供。它的目的很明確:保證行車的快速,安全。 ( 4) 用戶操作要求 用戶對導航系統(tǒng)的設置,功能使用等信息。在 HMI 中通過 API 和導航系統(tǒng)交互,將信息發(fā) 送過去。 3.2.2. 信 息處理及輸出 通過導航系統(tǒng)的處理,會得到駕駛者要求的功能。輸出是處理的結果表示,這里把處理和輸出合在一起來闡述。 汽車導航系統(tǒng)功能龐大,本文選取幾個相關的功能點來闡述。 1) 車輛定位 第 3 章 系統(tǒng)分析 -12- 獲得自車位置情報,包括 On Road / Off Road 情報、經(jīng)緯度、方向、行進 /停止、速度、道路上的位置、 GPS 等。如果由于種種原因產生汽車偏離的現(xiàn)象,導航儀還會進行補正,包括距離補正、感度補正、安裝角度補正。同時還會進行修正,主要有位置修正、方位修正。最終取得車輛位置的結果。 2) 徑路計算 為了提高速度,向用戶提供良 好的交互界面,探索徑路分別從自車位置和目的地位置雙方向進行道路的擴展。一直到兩側的擴展道路有一定數(shù)量的重合后,方可確定一條最優(yōu)的道路。 3) 導航計算及顯示功能 導航提供了交差點、目的地、經(jīng)由地、收費站、交通限制等具體地點的導航。比如當前方有交叉點時,會顯示交叉點擴大圖、 Real 3D 交叉點擴大圖、車線情報、方面看板等信息,同時也會有聲音提示,從而完成導航功能。 3.3. 開發(fā)環(huán)境 汽車導航系統(tǒng)是基于 Itron 系統(tǒng)開發(fā)的,本系統(tǒng)同樣是基于 Itron 系統(tǒng),但要求在windows 系統(tǒng)下模擬實現(xiàn),到的編譯器主要有兩個: cygwin 編譯環(huán)境和 .net 編譯器。由于整個工程的文件很多,利用 .net 編譯器的 make 命令能很方便的編譯多個工程文件。本設計利用 cygwin 編譯環(huán)境來產生庫文件,用 .net 來整合編譯整個工程。另外需要在 PCNavi 上進行測試。 第 4 章 系統(tǒng)設計 -13- 第 4章 系統(tǒng)設計 4.1. 架構概述 從系統(tǒng)層次的角度看,本系統(tǒng)分為四層,從下到上依次為 PF(Platform)、 Server、Application 和 UI。 HMI 層負責顯示, Application 層為功能層,本文論述的內容處于Application 層中的 DG 模塊。系統(tǒng)的框架圖如圖 4.1 所示。 H M IP e r i S e r v e rL i b r a r yV P M A P D G R PN O T EV I C SV S SV o i c eG P S C I SO S D D F S G U IC l o c kI n sUIApplicationServerPlatformN a v i S e r v e rF r a m e 圖 4.1 系統(tǒng)框架圖 本導航系統(tǒng)是基于 Itron 操作系統(tǒng)開發(fā)的,和一般的嵌入式操作系統(tǒng)類似, Itron 操作系統(tǒng)是支持多任務、事件驅動、基于優(yōu)先級調度、完全可搶占內核硬實時響應的操作系統(tǒng)。基于 Itron 的機制,整個導航系統(tǒng)劃分為多個 Task,形成多進程的系統(tǒng),所以我們才可以在系統(tǒng)完成導航的同時可以聽音樂、看電影。從系統(tǒng)的具體實現(xiàn)方式看,導航系統(tǒng)中的每一個大功能,例如導航,徑路,檢索等都是有許多 Task 協(xié)作實現(xiàn)的。整個導航系統(tǒng)中不同的 Task 之間的通信采取的是 message 和 Event 等機制進行通信的。由于本文是在已有導航系統(tǒng)基礎上進行部分功能模塊的更改,因此以下將著重于系統(tǒng) Task 級的設計。 第 4 章 系統(tǒng)設計 -14- 4.2. 系統(tǒng) Task 級設計 本文論述的主要內容位于系統(tǒng)的導航模塊,該模塊在導航系統(tǒng)框架中的位置在圖 3.2中有過介紹。下面具體介紹本文對該模塊的 Task 級設計內容。圖 4.2 是導航模塊系統(tǒng)的 Task級設 計圖。 H M IA P IR P V P數(shù) 據(jù) 整 合 導 航 控 制數(shù) 據(jù) 提 取描 畫 V I11123 456 789107 圖 4.2 系統(tǒng) Task 級設計 其中 RP、 VP、 VI、 API 和 HMI 是已有導航系統(tǒng)系統(tǒng)已經(jīng)實現(xiàn)了的,不需要改變。本文 涉及到的需要改變的地方為矩形線框內的部分。比較重要的數(shù)據(jù)整合,導航控制,數(shù)據(jù)提取這三個任務。數(shù)字代表 Task 之間發(fā)送的信息。具體說明參照表 4.1。 表 4.1 Message 說明表 序號 Message 說明 序號 Message 說明 1 徑路計算結果通知 6 Turnlist 送信通知 2 現(xiàn)在地信息 7 導航輸出信息通知 3 導航信息取得要求 8 聲音再生要求 4 導航信息取得應答 9 event 通知 5 導航 Point 通知 10 API 函數(shù)調用 徑路計算結果通知是徑路模塊 ( RP) 發(fā)送給數(shù)據(jù) 整合任務的信息,這個信息是在用戶 第 4 章 系統(tǒng)設計 -15- 設定了目的地后,徑路模塊接收 GPS、 VICS、 KIWI 等信息,然后通過相應的算法計算出來的從現(xiàn)在車輛所在位置到目的地的一條最佳路線。經(jīng)過 3、 4 過程數(shù)據(jù)提取任務會把從數(shù)據(jù)整合任務接收到的信息經(jīng)過處理再進行返回。 6、 7、 8 則關系到導航屏幕上的輸出和聲音上的輸出。 4.3. 道路限制導航模塊 本文論述的道路限制導航模塊遵循的上述設計方式。在具體細節(jié)方面有一些不同。在道路限制導航模塊中,導航控制任務需要向 API 層發(fā)送 ONS 警告的表示通知,另外在描畫任務中,還需要有一個地圖數(shù)據(jù)取得的過程。其余部 分都與 4.1 中論述的一樣。 完成此模塊的關鍵點是在取得地圖數(shù)據(jù)整合必要的導航數(shù)據(jù)的處理中,要添加對取得的數(shù)據(jù)中的道路屬性信息進行判斷和處理。在導航控制中,增加相應的對時間限制導航的控制,以達到對新增內容的要求。 4.3.1. 功能點及對應 Task 分析設計 在對 Task 間的關系設計完成后 ,需要設計出道路限制模塊實現(xiàn)的功能點與系統(tǒng) Task 的對應關系。具體如表 4.2 所示 。 表 4.2 道路限制模塊功能點與系統(tǒng) Task 對應關系 功能點 序號 功能任務 對應 Task 時間限制道路 mark的表示 1 區(qū)分時間限制道路和普通道路 數(shù) 據(jù)整合 2 根據(jù) 導航 交叉點 mark 的表示 種別來分別表示普通道路 mark 和 時間限制道路 mark 描畫 時間限制道路聲音提示 3 區(qū)分時間限制道路和普通道路 數(shù)據(jù)整合 4 在 進 入 時間限 制道路 時 , 發(fā)出提示聲音 。 導航控制 5 根據(jù)導航控制發(fā)送過來的聲音 ID 列,進行發(fā)聲 VI 時間限制制道路擴大圖的表示 6 區(qū)分時間限制道路和普通道路 數(shù)據(jù)整合 7 在進入時間限制道路時和進入后,擴大圖表示 導航控制 8 進行擴大圖表示和擴大圖上限制 mark 的表示變更 地圖描畫 第 4 章 系統(tǒng)設計 -16- 續(xù)表 4.2 道路限制模塊 功能點與系統(tǒng) Task 對應關系 功能點 序號 功能任務 對應 Task 開始導航時限制道路 警告 ons表示 9 向 HMI 提供函數(shù)接口,用來判斷當前徑路上是否有時間限制道路 API 10 根據(jù) API 返回的信息,表示警告 ons HMI 初期 導航時限制道路警告 ons表示 11 區(qū)分時間限制道路和普通道路 數(shù)據(jù)整合 12 進入時間限制道路時,向 API 發(fā)送 限制警告ons 的表示通知 導航控制 13 向 HMI 提供函數(shù)接口,用來判斷當前徑路上是否有時間限制道路 API 14 根據(jù) API 返回的信息,表示時間 限制道路警告 ons HMI 限制道路turnlist 表示 15 區(qū)分時間限制道路和普通道路 數(shù)據(jù)整合 16 根據(jù) 導航類型 設定 turnlist 的 node 種別,向API 發(fā)送 turnlist 信息通知 數(shù)據(jù)整合 17 將時間限制道路 turnlist 的分歧箭頭置灰 HMI 由上表可見數(shù)據(jù)整合 Task 的任務就是區(qū)分時間限制道路和普通道路,這也是該模塊的核心任務所在,導航控制 Task 的任務是向 HMI、 VI、 API 和描畫任務發(fā)送通知讓他們進行語音或文字的提示。 HMI 和 VI 的任務就是最終體現(xiàn)給用戶文字或聲音 提示。具體實現(xiàn)時, VI 模塊需要根據(jù)導航控制發(fā)送過來的聲音 ID 到存儲模塊中提取聲音進行發(fā)聲,描畫模塊在進行擴大圖標是的時候需要從地圖 Database中提取更細化的地圖數(shù)據(jù)進行局部地圖的放大表示。 Turnlist 表示與本模塊的關系不是很大,此項功能的完成是改變 TURN_INF全局變量, HMI 會具體做處理。 根據(jù)功能點的對應任務,在 Task 之間的 Msg 時序中進行設計。 ( 1) 時間限制道路 Mark 表示,如圖 4.3 所示。 第 4 章 系統(tǒng)設計 -17- 現(xiàn) 在 地 導 航 控 制1 . 現(xiàn) 在 地 信 息 7 . 導 航 輸 出 信 息 通 知 6 . 描 畫 時 機 判 定數(shù) 據(jù) 整 合2 . n o d e 信 息 取 得 要 求 3 . n o d e 信 息 取 得 應 答 4 . 導 航 數(shù) 據(jù) 整 合5 . 導 航 p o i n t 通 知 數(shù) 據(jù) 提 取8 . 描 畫 處 理導 航 數(shù) 據(jù) 整 合 時需 區(qū) 分 時 間 限 制道 路 和 普 通 道 路地 圖 描 畫 圖 4.3 時間限制道路 Mark 表示時 序圖 需要注意的是導航控制需要對描畫時機進行判定,決定何時輸出導航信息。最后交由描畫任務進行處理。時間限制道路 Mark 表示就是嚴格按照上述的時序實現(xiàn)的。 ( 2) 時間限制道路聲音提示,如圖 4.4 所示。 導 航 控 制2 . 聲 音 發(fā) 生 要 求 1 .聲 音 p h r a s e 做 成 和 時 機 判 定3 .發(fā) 聲 處 理 處 理聲 音 控 制4 .聲 音 發(fā) 生 應 答 圖 4.4 時間限制道路聲音提示時序圖 第 4 章 系統(tǒng)設計 -18- 時間道路限制聲音提示在數(shù)據(jù)提取、數(shù)據(jù)整合兩個任務的實現(xiàn)方式上和 Mark 表示是一樣的。只是在導航控制和提示方式上有一些區(qū)別。導航控制任務接收到數(shù)據(jù)整合發(fā)送來的信息,需要進行聲音 phrase 做成和進行時機判定在正確的時候將聲 音發(fā)聲要求發(fā)送給聲音控制處理。 ( 3) 時間限制道路 turnlist 表示 時序圖如圖 4.5 所示。 現(xiàn) 在 地 數(shù) 據(jù) 整 合1 . 現(xiàn) 在 地 信 息 5 . T u r n l i s t 送 信 通 知 2 . n o d e 信 息 取 得 要 求 3 . n o d e 信 息 取 得 應 答 4 . 導 航 數(shù) 據(jù) 整 合A P I數(shù) 據(jù) 提 取在 T U R N L _ I N F 的 n d _ k i n d 中 增 加時 間 限 制 道 路 的 n o d e k i n d 。對 于 相 應 的 n d _ k i n d , 在 h m i 側會 分 別 做 相 應 的 處 理 。數(shù) 據(jù) 整 合 時需 區(qū) 分 時 間 限 制道 路 和 普 通 道 路 圖 4.5 時間限制道路 turnlist 表示時序圖 時間限制道路 turnlist 表示 同樣需要數(shù)據(jù)整合和數(shù)據(jù)提取任務協(xié)作得出必要的導航數(shù)據(jù),不同的是,數(shù)據(jù)提取任務向 API 發(fā)送 Turnlist 送信通知,在 TURNL_INF 的 nd_kind中增加時間限制道路的 nodekind。對于相應的 nd_kind,在 hmi 層會分別做相應的處理。 ( 4) 時間限制道路擴大圖表示。 擴大圖表 示功能點在數(shù)據(jù)整合和數(shù)據(jù)處理任務上的設計與 Turnlist 表示相同,因此下面不再贅述,圖 4.6表示的內容是擴大圖表示在時序圖設計上與 Turnlist表示上的不同之處。主要體現(xiàn)在導航控制、地圖描畫和 API 三個部分。導航控制模塊需要先將導航輸出信息通知發(fā)送給 API,由 API 將導航圖的表示要求發(fā)送給地圖描畫模塊。 第 4 章 系統(tǒng)設計 -19- 導 航 控 制地 圖 描 畫1 .導 航 圖 準 備 要 求2 .導 航 圖 準 備 應 答3 . 導 航 圖 時 機 判 定A P I4 . 導 航 輸 出 信 息 通 知5 . 導 航 圖 表 示 要 求6 . 擴 大 圖 表 示時 間 限 制 道 路在 初 期 導 航 時表 示 擴 大 圖 圖 4.6 時間限制道路擴大圖表示時序圖 ( 5) 時間限制道路 初期 導航警告 ons 表示 ,如圖 4.7 所示。 導 航 控 制6 . 聲 音 發(fā) 聲 要 求 7 . 聲 音 發(fā) 聲 應 答 7 . 導 航 輸 出 信 息 通 知 現(xiàn) 在 地 數(shù) 據(jù) 整 合1 . 現(xiàn) 在 地 信 息 2 . n o d e 信 息 取 得 要 求 3 . n o d e 信 息 取 得 應 答 4 . 導 航 數(shù) 據(jù) 整 合5 . 導 航 p o i n t 通 知 數(shù) 據(jù) 處 理聲 音 控 制 A P I7 . 發(fā) 聲 處 理8 . O N S 處 理6 . 導 航 控 制 圖 4.7 時間限制道路 初期 導航警告 ons 表 示時序圖 第 4 章 系統(tǒng)設計 -20- ONS 警告比較復雜,如上圖所示。 ONS 的文字顯示需要導航控制給 API 發(fā)送導航輸出信息通知。由 API 進行 ONS 處理。 ONS 的聲音提示需要導航控制給聲音控制發(fā)送發(fā)聲要求,聲音控制進行發(fā)聲處理。在道路限制導航模塊前期的工作都是有數(shù)據(jù)整合和數(shù)據(jù)提取這兩個任務完成的,導航控制起到了一個橋梁作用,同樣也是一個時機決策的關鍵任務。然后根據(jù)具體功能由 API、描畫、 HMI 和聲音控制實現(xiàn)。 4.3.2. 重要函數(shù)設計 接口函數(shù)分為模塊間接口函數(shù)和模塊內接口函數(shù)。模塊間接口函數(shù) 主要來完成不同模塊之間的信息接收和發(fā)送的功能,而模塊內接口函數(shù)是實現(xiàn)同一模塊中的不同 Task 的信息接收和發(fā)送的功能。本設計主要在原有函數(shù)中保證原有功能不變的情況下,為了不改變此模塊和其他模塊通信接口,在原有函數(shù)基礎上來添加新增的功能點。從而達到正確接收和發(fā)送所要求信息的功能。 ( 1) lmk_ginf_regu_pp() 在本函數(shù)設計中,通過影響 acs_kpinf , gdlst -regu_cont 等全局變量的標志位或者值,觸發(fā)模塊的函數(shù)判定條件,對全局變量的內容進行更改。表 4.3 為函數(shù)設計表。 表 4.3 lmk_ginf_regu_pp 函數(shù)說明 ( 2) dsp_gdcrs_inf_kind_gc() 表 4.4 為 dsp_gdcrs_inf_kind_gc 的函數(shù)設計表 函數(shù)名 lmk_ginf_regu_pp 文件名 Lmk_guide_set.c 功能概要 道路導航內容設定處理 記述形式 I4 lmk_ginf_regu_pp (ACS_KPNT_INF_PP *acs_kpinf, U1 *gdlst ) 參數(shù) 類型 變量名 I/O 說明 ACS_KPNT_INF_PP *acs_kpinf I 導航點數(shù)據(jù)首地址信息 U1 *gdlst I 導航 list地址 返回值 類型 I4 說明 值 PP_OK 正常結束 PP_NG 異常結束 詳細說明 對全局的導航數(shù)據(jù)的內容進行設置,追加了對時間限制導航的數(shù)據(jù)的更新部分。對時間限制道路的信息,及時保存到變量中。 第 4 章 系統(tǒng)設計 -21- 表 4.4 dsp_gdcrs_inf_kind_gc 函數(shù)說明 在本函數(shù)中 ,根據(jù)徑路導航內容的取得結果,對導航 Pattern 進行判斷,對不表示為交差點 mark 的導航對象不做處理。需要表示的將標志位置 1。從而返回導航交差點專用信息( u4kind)給上級函數(shù)使用。 4.4. 收費站導航模塊 本文中的收費站導航模塊遵循 4.1 中論述系統(tǒng)設計方式。具體細節(jié)有所不同。在此模塊中,導航控制和描畫之間需要發(fā)送導航圖準備要求和導航圖準備應答的信息。描畫內部需要有一個 Image 請求的過程。另外 API 層需要向描畫任務發(fā)送導航圖表示要求。 完成此模塊的關鍵點是對收費站的判斷和處理的增加,需要在全局結構體中添加新的標志位,以便在導航數(shù)據(jù)整合的時候,能夠識別并正確作成收費站的相應數(shù)據(jù)。另外,在對 Package 外部的交互中,也要對 Package 之間的 Message 增加相應的附加信息。只有這樣才能正確實現(xiàn)收費導航。 4.4.1. 功能點及對應 Task 分析設計 在對 Task 間的關系設計完成后,需要設計出收費站導航模塊實現(xiàn)的功能點與系統(tǒng) Task的對應關系,具體如表 4.5 所示。 函數(shù)名 dsp_gdcrs_inf_kind_gc 文件名 Dsp_gdcrs.c 功能概要 導航交差點專用信息設定 記述形式 U2 dsp_gdcrs_inf_kind_gc ( T_GUD_PT_GC *_gui_pnt, GPT_KRDT *_p_krdt) 參數(shù) 類型 變量名 I/O 說明 T_GUD_PT_GC *_gui_pnt I 導航交差點的基本數(shù)據(jù)的address GPT_KRDT *_p_krdt I 徑路數(shù)據(jù)的 address 返回值 類型 U4 說明 值 u4kind 導航交差點專用信息 詳細說明 對局部變量 u4kind進行設定, return給上級函數(shù)使用。對時間限制部分的處理在 switch中的 PATT_ID_DD處。 第 4 章 系統(tǒng)設計 -22- 表 4.5 收費導航功能點與系統(tǒng) Task 對應關系 功能點 序號 功能任務 相關 Task Turnlist中收費站mark的表示 1 增加收費站標志位判斷,處理收費站 數(shù)據(jù) 數(shù)據(jù)整合 2 根據(jù)設定 turnlist 的 node 種別,向 API 發(fā)送turnlist 信息通知 。 數(shù)據(jù)整合 3 在 turnlist 中顯示收費站 mark HMI 收費站擴大圖的表示 4 增加收費站標志位判斷,處理收費站數(shù)據(jù) 數(shù)據(jù)整合 5 在交差點導航中,對收費站的 Pattern 進行判斷和導航控制 導航控制 6 進行擴大圖表示 地圖描畫 輔助 導航上的收費站顯示 7 增加收費站標志位判斷,處理收費站數(shù)據(jù) 數(shù)據(jù)整合 8 根據(jù)收費站的導航類型和該對應的導航時機設定 Message 中的信息, 發(fā)送 Message 導航控制 9 在 輔助 導航區(qū)域顯示收費站信息 HMI 收費站聲音導航 10 增加收費站標志位判斷,處理收費站數(shù)據(jù) 數(shù)據(jù)整合 11 根據(jù)收費站的導航類型和該對應的導航時機設定 Message 中的信息,發(fā)送 Message 導航控制 12 根據(jù)導航控制發(fā)送過來的音聲 ID 列,進行發(fā)聲 VI 上表中很重要的一點是數(shù)據(jù)整合 Task 中增加收費站標志位判斷,處理收費站數(shù)據(jù)。這一點是其它 Task 工作的基礎和依據(jù)。另外比較特殊的一點是 HMI 中的次導航區(qū)域顯示收費站信息。其它的與道路限制導航的設 計都一樣遵循 4.1 中所論述的。 根據(jù)功能點及其相對應的系統(tǒng) Task,在 Task 之間的 Msg 時序中進行設計 。 ( 1) Turnlist 中收費站 mark 的時序 表示 如圖 4.8 所示。 需要注意的是在導航數(shù)據(jù)整合時增加對收費站 Pattern 的判斷,作成收費站導航數(shù)據(jù)。本文主要設計的是導航數(shù)據(jù)做成的部分,前期的數(shù)據(jù)處理仍然是由數(shù)據(jù)整合和數(shù)據(jù)提取任務完成的。由于此功能是在一開始的 Turnlist 顯示的,所以不需要有導航控制任務進行時機判定。 第 4 章 系統(tǒng)設計 -23- 現(xiàn) 在 地 數(shù) 據(jù) 整 合1 . 現(xiàn) 在 地 信 息 5 . T u r n l i s t 送 信 通 知 2 . n o d e 信 息 取 得 要 求 3 . n o d e 信 息 取 得 應 答 4 . 導 航 數(shù) 據(jù) 整 合A P I數(shù) 據(jù) 提 取在 T U R N L _ I N F 的 n d _ k i n d 中 增 加時 間 限 制 道 路 的 n o d e k i n d 。對 于 相 應 的 n d _ k i n d , 在 h m i 側會 分 別 做 相 應 的 處 理 。增 加 對 收 費 站P a t t e r n 的 判 斷 ,整 合 收 費 站 導 航 數(shù) 據(jù) 圖 4.8 Turnlist 中 收費站 mark 的表示時序變更圖 ( 2) 輔助導航上的收費站顯示時序設計如圖 4.9 所示。 導 航 控 制3 . 導 航 輸 出 信 息 通 知A P I2 . 導 航 時 機 判 定增 加 對 收 費 站 的輔 助 導 航 的 提 示 時機 判 定1 . 導 航 P o i n t T a b l e作 成 圖 4.9 輔助導航上的收費站顯示時序圖 第 4 章 系統(tǒng)設計 -24- 次導航上的收費站顯示和 Turnlist 提示的區(qū)別在于需要進行時機判定,因為 Turnlist提示是在開始導航時就提示的,而次導航上的收費站提示是在車輛行駛的過程中提示的。如上圖,導航控制 Task 需要進行導航時機判定。 ( 3) 收費站聲音導航 Task 時序設計。 此部分設計和時間道路限制聲音導航的 Task 時序設計只在數(shù)據(jù)整合任務和導航控制任務的 小細節(jié)上中有所不同,因此不再詳細論述。本功能的數(shù)據(jù)做成任務是對收費站 Pattern的判斷,并且在導航控制中對發(fā)生時機的判斷需要依據(jù)表 3.1 中的內容。 ( 4) 收費站擴大圖的表示如圖 4.10。 現(xiàn) 在 地 數(shù) 據(jù) 整 合1 . 現(xiàn) 在 地 信 息 5 . 導 航 P o i n t 通 知 2 . n o d e 信 息 取 得 要 求 3 . n o d e 信 息 取 得 應 答 4 . 導 航 數(shù) 據(jù) 整 合數(shù) 據(jù) 提 取增 加 對 收 費 站P a t t e r n 的 判 斷 ,整 合 收 費 站 導 航 數(shù) 據(jù)導 航 控 制 地 圖 描 畫6 . 導 航 圖 準 備 要 求7 . 導 航 圖 準 備 應 答A P I8 . 導 航 圖 時 機 判 定9 . 導 航 輸 出 信 息 通 知1 0 . 導 航 圖 表 示 要 求1 1 . 擴 大 圖 表 示增 加 對 收 費 站P a t t e r n 的 判 斷圖 4.10 收費站擴大圖的表示時序圖 針對收費站擴大圖表示這一個功能點,主要的工作是在導航數(shù)據(jù)整合,導航圖時機判定以及擴大圖表示部分。整體設計思路與道路限制導航的擴大圖標是功能有所相似。 第 4 章 系統(tǒng)設計 -25- 4.4.2. 重要函數(shù)設計 ( 1) set_gptn_common_pp( ) 在本函數(shù)設計中,根據(jù)交 差點 node 進行識別和條件判斷對導航 Pattern 進行設定。取得導航 Pattern 后,進行判斷。條件符合時,則取得全局變量 node 附加信息數(shù)據(jù)。表 4.6為該函數(shù)設計表。 表 4.6 set_gptn_common_pp 函數(shù)說明表 根據(jù)現(xiàn)在地信息中的交差點 mode 的類型進行判斷,取得導航 Pattern 的值。然后根據(jù)*gui_ptn 的值進行判斷和處理。取得 acs_kpinf 中的 node_info,根據(jù) node_info 設定 gui_ptn。達到更新 gui_ptn 的內容,以提供給上級的調用函數(shù)使用。 ( 2) set_toll_dsp_dist_gc( ) 表 4.7 set_toll_dsp_dist_gc 函數(shù)說明 函數(shù)名 set_gptn_common_pp 功能概要 收費站開始表示的距離的設定處理 記述形式 I4 set_gptn_common_pp(LMK_LOCAL_EXT_PP *p_lext, ACS_KPNT_INF_PP *acs_kpinf,U2 *gui_ptn ) 參數(shù) 類型 變量名 I/O 說明 LMK_LOCAL_EXT_PP *p_lext I 現(xiàn)在地附屬信息 ACS_KPNT_INF_PP *acs_kpinf I 導航 Point 數(shù)據(jù)地址 U2 *gui_ptn I 導航 Pattern 返回值 類型 I4 說明 值 PP_OK 正常結束 PP_NG 異常結束 函數(shù)名 set_toll_dsp_dist_gc 功能概要 收費站開始表示的距離的設定處理 記述形式 U4 set_toll_dsp_dist_gc( TOLL_ANNAI_DATA_GC *toll_inf ) 參數(shù) 類型 變量名 I/O 說明 TOLL_ANNAI_DATA_GC *toll_inf I 收費導航數(shù)據(jù) address 返回值 類型 U4 說明 值 dsp_dist 開始表示的距離 0xffffffff 無效距離(初始化用) 第 4 章 系統(tǒng)設計 -26- 表 4.7 為該函數(shù)的設計表。具體就是根據(jù)全局的導航數(shù)據(jù)的內容進行判斷,追加對收費站導航的判斷和處理。如果導航點類型為收費站,作成收費站的導航時機距離數(shù)據(jù)。對于一個收費站,最多有 3 個提前導航的時機距離。 第 5 章 系統(tǒng)實現(xiàn) -27- 第 5章 系統(tǒng)實現(xiàn) 5.1. 系統(tǒng) Task 級實現(xiàn) 本文主要論述的兩個功能均屬于導航模塊中的內容,現(xiàn)對導航模塊的具體實現(xiàn)作簡要論述。圖 5.1 為導航模塊的 Task 實現(xiàn)圖。 D r a wA n n a iL O CR IG CN SP PA P IG MH M IG D現(xiàn) 在 地 信 息徑 路 計 算 結 果 通 知N O D E 信 息 取 得 應 答導 航 輸 出 信 息 通 知N O D E 信 息 取 得 要 求導 航 點 通 知【 e v e n t 】導 航 圖 表 示 要 求導 航 圖 描 畫 要 求導 航 圖 描 畫 應 答D S導 航 信 息 要 求 導 航 信 息 應 答圖 5.1 導航模塊 Task 實現(xiàn)圖 上圖表示的是導航模塊內 Task 之間的協(xié)同工作機制,其中比較重要的是 NS、 PP、 GC這三個 Task。 NS Task 的任務是 Node 信息提取,主要職能是與 DS 交互,取得地圖數(shù)據(jù)和與 PP 交互,提供給 PP 某個 Node Link 對的詳細信息; PP Task 為導航模塊中最重要的控制Task,主要職能是 ON/OFF ROUTE 判定、各種通過判定,到達判定、獲得導航數(shù)據(jù)以及導航點的數(shù)據(jù)做成; GC Task 為導航控制任務,職能是 做成 詳細的表示導航數(shù)據(jù)和聲音數(shù)據(jù) 控制導航提示的時機,通知上位模塊進行導航。 Task 間的通信是通過底層的 PF(Platform)實現(xiàn)的。 PF 是 Application 與 Itron 系統(tǒng)之間的接口,同樣可以視作 Task 通信的橋梁。兩個 Task 之間的通信如圖 5.2 所示。 T a s k A T a s k BP F1 .請 求 2 .請 求3 .應 答4 .應 答 圖 5.2 Task 間通信示意圖 第 5 章 系統(tǒng)實現(xiàn) -28- TaskA 如果要想和 TaskB 通信 ,TaskA 必須先將請求信息發(fā)送給 PF,由 PF 發(fā)送信息請求給 TaskB,然后 TaskB 再將應答經(jīng)由 PF 返回給 TaskA。 另 外,簡單的來說道路是由 NODE 和 NODE 之間的 LINK 組成的,比如 NODE A 和NODE B 之間的道路是時間限制道路,那么 NDOE A 和 NODE B 的信息中就會有一個變量標志出來。理解這一點是論述下面內容的基礎。 5.2. 道路限制導航模塊 5.2.1. 系統(tǒng)實現(xiàn)概要 圖 5.3 為該模塊 Task 實現(xiàn)示意圖。 G CP PH M I導 航 點 通 知M s g 接 受處 理導 航 點數(shù) 據(jù) 解 析時 間 限 制道 路 導 航數(shù) 據(jù) 更 新V O I C E G發(fā) 聲 要 求導 航 輸 出 信 息 通 知導 航 輸 出 信 息 狀 態(tài) 通 知時 間 限 制導 航 表 示描 畫 要 求描 畫圖 5.3 道路限制導航模塊 Task 實現(xiàn)示意圖。 GC Task 是關鍵任務,包括 Msg 接受處理,導航點數(shù)據(jù)解析,時間限制導航數(shù)據(jù)更新和時間限制導航表示四個功能塊。 Msg 接 受處理主要是將來自 PP 的導航點信息更新到總的全局的導航點總信息中。導航點數(shù)據(jù)解析將 Msg 接受處理任務發(fā)送來的信息進行判定和提取再發(fā)送給時間限制道路導航信息更新和時間限制導航表示。 時間限制導航表示主要是決定了導航提示時機的判定。 第 5 章 系統(tǒng)實現(xiàn) -29- 5.2.2. 重要函數(shù)實現(xiàn) 在此功能模塊中有兩個關鍵函數(shù),在系統(tǒng)設計中有過論述,下面具體介紹函數(shù)的實現(xiàn)由于是在 base 代碼上進行修改,首先需要對相應結構體及其它變量進行增加或者修改。 ( 1) 結構體修改 NODE_INFO: 此新增結構體變量來存儲導航 Point 的數(shù)據(jù)。具體新增成員已用加粗字體顯示。新增的 標志位表示了時間限制道路有無的信息等。 各條件判斷位采用位運算的方式,按照預先約定好的順序表示當前狀態(tài)。這樣的設計最大程度上節(jié)約了內存使用量和運算時 間。表 5.1 顯示了 NODE_INFO 的部分信息。 表 5.1 NODE_INFO 結構體(部分) 數(shù)據(jù)類型 成員名 成員功能 U2: 1 no_guide 是否導航 0:導航 /1:不導航 U2: 1 time_kisei Node 時間限制信息 0:無 /1:有 U2: 1 sapa_enter SAPA 入口 U2: 1 etc 其他 U2: 1 kakudai_flg 擴大圖信息 0:無 /1:有 U2: 1 u_turn_flg U Turn 判定結果信息 0:無 /1:有 GUIDT_PNT_INF:此結構體存儲 Node 的共通信息,其中的 pnt_add 成員是標志判斷用, bit4 用來判斷有無時間規(guī)則道路。表 5.2 顯示了 GUIDT_PNT_INF 的部分信息。 表 5.2 GUIDT_PNT_INF 結構體(部分) 數(shù)據(jù)類型 成員名 成員功能 GUIDT_LNK_ND node Node 信息 U2 pnt_add 點附加信息: BIT0:行駛車線 0=左側行駛、 1=右側行駛 BIT4:時間限制道路行駛 0:無 /1:有 BIT5:常時限制道路行駛 0:無 /1:有 第 5 章 系統(tǒng)實現(xiàn) -30- ( 2) 函數(shù)流程圖 lmk_ginf_regu_pp:圖 5.4 為 lmk_ginf_regu_pp 的函數(shù)流程圖。 開 始初 始 化 處 理 導 航 列 表 的 地 址判 斷 導 航 數(shù) 據(jù)是 否 有 效判 斷 a c s _ k p i n f 中 的 信息 是 否 有 效相 應 數(shù) 據(jù) 處 理是 否 為入 口 場 合設 定 全 局 變 量r e g u _ c o n t - k i n d 為R E G _ K I N D _ I NYYY是 否 為出 口 場 合N設 定 全 局 變 量r e g u _ c o n t - k i n d 為R E G _ K I N D _ I NY是 否 為P o i n t 場 合N設 定 全 局 變 量r e g u _ c o n t - k i n d 為R E G _ K I N D _ P O I N TYR e t u r n P P _ N G R e t u r n P P _ O KNNN結 束 圖 5.4 lmk_ginf_regu_pp 流程圖 第 5 章 系統(tǒng)實現(xiàn) -31- 本函數(shù)主要是通過影響 acs_kpinf , (*gdlst).regu_cont 等全局變量的標志位或者值,觸發(fā)模塊的函數(shù)判定條件,對 全局變量的內容進行更改和對全局的導航數(shù)據(jù)的內容進行設置,首先判斷導航點數(shù)據(jù)首地址 acs_kpinf 是否有效,若無效返回 PP_NG(異常結束 )。如果是有效的則再進行相應數(shù)據(jù)處理之后繼續(xù)判斷是否為入口場合、出口場合或者 Point 場合。根據(jù)以上判斷確定 regu_cont 的值。最后返回 PP_OK(正常結束)。 dsp_gdcrs_inf_kind_gc:圖 5.5 為 dsp_gdcrs_inf_kind_gc 的函數(shù)流程圖。 開 始初 始 化 處 理u 4 k i n d = 0c h k _ r e s i _ m o d e _ g c徑 路 導 航 內 容 容 取 得 成 功 ?YS w i t c h ( 導 航P a t t e r n )R e t u r n ( U 2 ) u 4 k i n dNP A T T _ I D _ B BP A T T _ I D _ W A Y P N TP A T T _ I D _ D D其 它 P t t e r nd e f a u l t導 航 對 象 點 m a r k 表 示 為 交差 點 的 場 合 ?u 4 k i n d | = B I T 0 ;YN相 應 數(shù) 據(jù) 處 理 圖 5.5 dsp_gdcrs_inf_kind_gc 流程圖 第 5 章 系統(tǒng)實現(xiàn) -32- 本函數(shù)主要是對局部變量 u4kind 進行設定,返回給上級函數(shù)使用。對時間限制部分的處理在 switch 中的 PATT_ID_DD 處。在本函數(shù)中,根據(jù)徑路導航內容的取得結果,對導航Pattern進行判斷,對不表示為交差點 mark的導航對象不做處理。需要表示的將標志位置 1 。從而返回導航交差點專用信息( u4kind)給上級函數(shù)使用。 ( 3) 代碼編寫 lmk_ginf_regu_pp() I4 lmk_ginf_regu_pp (ACS_KPNT_INF_PP *acs_kpinf, U1 *gdlst ) /*- variables -*/ GDLIST_PP *prgd; /* 導航 list結構體地址 */ GPT_KDRT_REG *regu_cont; /* 規(guī)制 道路 導航 內容 */ NODE_INFO *node_info; /* node附加信息 data */ /* 初始化處理 */ prgd = (GDLIST_PP*)gdlst; /* 取得全局變量地址 */ if ( (prgd-valid & BIT_VALID_REGU_CONT) = 0 ) /* 導航數(shù)據(jù)有效 */ return ( PP_OK ); /* 處 理対象判定 */ /* 入口 場 合 */ if ( (lattr_sl.time_kisei = FLAG_OFF)& (lattr_tl.time_kisei = FLAG_ON ) ) regu_cont-kind = REG_KIND_IN; /* 出口 場 合 */ else if ( (lattr_sl.time_kisei = FLAG_ON ) & (lattr_tl.time_kisei = FLAG_OFF) ) regu_cont-kind = REG_KIND_OUT; /* 時間限制 Point 場 合 */ else if ( ( lattr_sl.time_kisei = FLAG_OFF) & ( lattr_tl.time_kisei = FLAG_OFF) & (node_info-time_kisei = FLAG_ON) regu_cont-kind = REG_KIND_POINT; return ( PP_OK ); /* 結束處理 */ dsp_gdcrs_inf_kind_gc()的代碼編寫相對比較簡單,主要就是對導航 Pattern 的判定,在此不貼出代碼。 第 5 章 系統(tǒng)實現(xiàn) -33- 5.3. 收費站導航模塊 5.3.1. 系統(tǒng)實現(xiàn)概要 本模塊的重點同樣是在 GC Task,具體示意圖與道路導航限制模塊大致相似,此處不再給出。收費站導航數(shù)據(jù)更新的任務是 根據(jù)導航中對應徑路導航信息中的收費站導航使用的區(qū)間距離信息進行設定,檢索到第一 個收費站導航有效徑路數(shù)據(jù)時,將對應的信息設定到全局導航點所對應的收費站導航 data 中; 收費站導航表示完成了收費站導航表示內容的作成,表示時機的取得。還有設定導航輸出信息通知對應的 Event。 5.3.2. 重要函數(shù)實現(xiàn) 此模塊同樣有兩個重要函數(shù),以下論述具體實現(xiàn),首先對相關結構體變量進行修改。 ( 1) 結構體修改 此部分涉及到三個已有結構體的修改和一個新增結構體,結構體 MNG_GUID_PNT_PP用來保存綜合的 Point 信息, MNG_GUID_PNT_PP 中的變量 MNG_KEIRO_PNT_PP 是徑路導航 Point 管理 Table, MNG_KEIRO_PNT_PP 中的變量 GPT_KRDT 結構體用來保存具體導航點信息,在 GPT_KRDT 中新增 GPT_KRD_TLL 結構體來 存儲收 費站相關信息表 5.3為 GPT_KRD_TLL 結構體的部分構成。 表 5.3 GPT_KDRT_TLL 結構體(部分) 數(shù)據(jù)類型 成員名 成員功能 U1: 1 kind 數(shù)據(jù)有無 0:無 /1:有 U2: 1 unit 貨幣單位 U4: 1 fee 收費金額 U2: 1 car_kind 車種 U1: 1 ttxt_add_flg 收費站名稱信息有無 0:無 /1:有 ( 2) 函數(shù)流程圖 set_gptn_common_pp:圖 5.6 為該函數(shù)的流程圖。根據(jù)現(xiàn)在地信息中的交差點 mode的類型進行判斷,取得導航 Pattern 的值。然后根據(jù) *gui_ptn 的值進行判斷和處理。取得acs_kpinf 中的 node_info,根據(jù) node_info 設定 gui_ptn。達到更新 gui_ptn 的內容,以提供給上級的調用函數(shù)使用。 第 5 章 系統(tǒng)實現(xiàn) -34- 開 始初 始 化 函 數(shù) 局 部 變 量取 得 p _ l e x t 中 的 交 差 點 m o d eL o o p ( c n t )循 環(huán) F O R _ L O O P _ C N T 1 次c n t F O R _ L O O P _ C N T 1( 未 完 成 循 環(huán) 次 數(shù) )交 差 點 m o d e 為 目 的 地 ?Y* g u i _ p t n = P A T T _ I D _ D E S T I N ;交 差 點 m o d e 為 通 過點 ?NY* g u i _ p t n = P A T T _ I D _ M I T I N AR I ; ( 各 交 差 點 m o d e 判 斷 和 處 理 )NL o o pN其 他 非 共 通 的 m o d e 設 定對 g u i _ p t n 進 行 判 斷是 否 需 要 誘 導Y取 得 n o d e 附 加 信 息 數(shù) 據(jù)R e t u r n P P _ O KN結 束Y 圖 5.6 set_gptn_common_pp 函數(shù)流程圖 set_toll_dsp_dist_gc:該函數(shù)流程比較復雜。其中圖 5.7 為 set_toll_dsp_dist_gc 的函數(shù)主流程圖。圖 5.8、圖 5.9、和圖 5.10 分別表示了函數(shù)主流程圖中的三個重要組成部分,單獨畫出流程圖。 第 5 章 系統(tǒng)實現(xiàn) -35- 開 始局 部 變 量 聲 明 初 始 化 處 理收 費 站 導 航數(shù) 據(jù) 是 否 有 效取 得 導 航 點 索 引 的 A d d r e s sA以 上 兩 個 P o i n t 信 息取 得 成 功B導 航 點 D a t a 設 定CR e t u r n d s p _ d i s t結 束導 航 點 T a b l e 數(shù) 據(jù) 置 0YYN 圖 5.7 set_toll_dsp_dist_gc 主流程圖 首先對局部變量進行初始化處理,然后取得導航點索引地址,經(jīng)過下面三個過程達到設定導航距離的目的。具體就是根據(jù)全局的導航數(shù)據(jù)的內容進行判斷,追加對收費站導航的判斷和處理。如果導航點類型為收費站,作成收費 站的導航時機距離數(shù)據(jù)。對于一個收費站,最多有 3 個提前導航的時機距離。 圖 5.8 為 A 過程,具體是從徑路數(shù)據(jù)取得徑路 Point 索引中第一個與收費站導航 Point的下一個交叉點信息一致的導航 Point,同時保存收費站導航 Point將相應值賦給 gui_pnt1,gui_pnt0。 第 5 章 系統(tǒng)實現(xiàn) -36- AL o o p( l o o p = 0 ; l o o p ( I 4 ) n u m I d x ; l o o p + + )l o o p = 0 ; C n t - -c n t = 0Yw k _ p n t = g e t _ G u i P u t _ g c ( )取 得 導 航 點 的基 本 數(shù) 據(jù) 地 址 有 效 ?Yg u i _ p n t k r _ p n t n o = w k _ p n t ;保 存 到 導 航 點 T a b le 中( k r _ p n t n o + 1 ) T O L L _ B F R _ P N T _ M AXYL o o pNNd s t _ g e t _ d o u b l e _ g c ( )連 續(xù) 導 航 距 離 的 取 得到 前 一 個 導 航 點 的 距 離 = 連 續(xù) 導 航 距 離k r _ p n t n o = 1 ;結 束k r _ p n t n o = 0 ;NY 圖 5.9 set_toll_dsp_dist_gc B 流程圖 需要注意的是最后一個判斷條件,如果連續(xù)的導航距離較短,需要在一次導航中完成提示。例如兩個需要轉向的地方相距 50 米,那么就需要在一次導航提示中顯示出來,如果分兩次導航提示,司機可能在第一個導航點過去之后來不及按照第二次的導航提示行 第 5 章 系統(tǒng)實現(xiàn) -38- 駛,導致行駛錯誤。 C 過程是對收費站表示區(qū)間距離的設定,簡單的 說就是在收費站前多少米處進行提示。具體過程如圖 5.10 所示。 Ck r _ p n t n o = = 0Yd s t _ g e t _ a u t o _ d s t _ g c ( )d s p _ d i s t 設 定取 得 自 動 發(fā) 聲 距 離N自 動 發(fā) 聲 距 離 有 效Y設 定 收 費 站 導 航 距 離要 加 上 發(fā) 聲 距 離收 費 站 導 航 距 離 為 全 局 變 量 中的 收 費 站 導 航 數(shù) 據(jù) 中 的 距 離N結 束Y 圖 5.10 set_toll_dsp_dist_gc C 流程圖 在導航系統(tǒng)進行聲音提示時車輛仍然在行駛,這段時間車輛行駛的距離需要計算在內,另外全局變量中收費站導航數(shù)據(jù)中的距離在表 3.1 中有介紹。 ( 3) 代

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論