專利名稱:一種拖動移向判斷的方法和系統(tǒng)的制作方法
技術(shù)領(lǐng)域:
本發(fā)明涉及拖動移向領(lǐng)域,尤其涉及一種拖動移向判斷的方法和系統(tǒng)。
背景技術(shù):
當(dāng)終端平臺用戶在一個畫面上從某點拖動到另一個點來查看這個點區(qū)域的具體 畫面時,通常需要判斷拖動移動方向,根據(jù)移動方向和偏移量大小來獲取和改變畫面。 現(xiàn)有技術(shù)中,一般實現(xiàn)4個方向(上、下、左、右)的移動,即坐標(biāo)軸方向,如圖1所 示,現(xiàn)將坐標(biāo)軸形成的4個夾角做2等分,即直線AB、CD,用虛線表示。用戶從O點 拖動移向到另一點落在直線AB和CD所形成的夾角里面。在直線AB與CD所形成的夾 角AOC中,判定拖動移動方向為向上(即射線OE),依次類推,在夾角BOD里判定拖 動移動方向向下(即射線OF),在夾角COB里判定移動方向向左(即射線OG),在夾角 AOD里判定移動方向向右(即射線OH)。這是普遍的做法,顯然這種判定方法不夠準(zhǔn) 確,比較粗略,例如,當(dāng)用戶通過原點O (坐標(biāo)為(xl,yl))移動到P點(坐標(biāo)為(x2, y2)),藍(lán)色射線OP所示,該方法把移動方向歸為向上移動了,其實該方向更傾向于斜向 右上方向OA(夾角45度)。這種方案在技術(shù)上實現(xiàn),一般采用三角函數(shù)來具體判定另一 個落點P所在的區(qū)域,通常采用正切函數(shù),通過斜率來判斷,可行的一種算法為先大 概判斷向X、Y軸移動方向,再比較X和Y坐標(biāo)的偏移量,比如方向向上的判斷條件為 y2 >yl&&|y2_yl| > |x2-xl|,其中y2>yl,限定了移動方向是X軸以上方向,包括夾 角GOC (代表方向向左)、夾角AOC (代表方向向上)、右夾角AOH(代表方向向右), 之后再通過條件|y2-yl| > |x2-xl|判定P點落在夾角AOC中,因為射線OP斜率的絕對值 大于1(臨界條件就是P點落在射線OA或OC上,此時斜率絕對值為1,與X軸夾角為 45度或135度)。通過類似方法可以類推其他三個方向的條件?,F(xiàn)有技術(shù)方案的缺點可用于判斷拖動移向的方向數(shù)量少,而通常應(yīng)用中需要判斷更多方向,而且方 向越小,移動效果越差,拖動移向誤差明顯;現(xiàn)有技術(shù)的算法的擴(kuò)展性不強(qiáng),不具備伸 縮性,在某些終端平臺,如JavaME中CLDC 1.0配置下,浮點數(shù)運算在特定的配置環(huán)境 下不支持,通用性不強(qiáng)。
發(fā)明內(nèi)容
本發(fā)明實施例的目的在于提出一種拖動移向判斷的方法和系統(tǒng),旨在解決現(xiàn)有 技術(shù)中判斷拖動移向的方向的數(shù)量少、誤差大、刷新慢、不易擴(kuò)展的問題。本發(fā)明實施例是這樣實現(xiàn)的,一種拖動移向判斷的方法,包括以下步驟自定義正切表賦值;觸發(fā)拖動移向請求,確定起始點和終點;對所述的每個η等分夾角再進(jìn)行二等分,形成第二個的η等分夾角;判斷拖動移向是否為4個坐標(biāo)軸方向重合;
如果是,拖動移向的方向為其中的一個坐標(biāo)軸方向;如果否,確定拖動移向所在象限;根據(jù)終點坐標(biāo)相對于原點坐標(biāo)偏移量的正切值與自定義正切表中的數(shù)值確定拖 動移向的方向。本發(fā)明實施例的另一目的在于提出一種判斷拖動移向的系統(tǒng),所述的系統(tǒng)包 括正切表初始模塊、坐標(biāo)處理模塊、象限判斷模塊、移向判斷模塊;正切表初始模塊,與坐標(biāo)處理模塊和移向判斷模塊相連,用于根據(jù)所要判斷拖 動移向的方向的數(shù)量對正切表賦值,接收移向判斷模塊獲取正切值的請求,并發(fā)送符合 條件的正切值到移向判斷模塊;坐標(biāo)處理模塊,與正切表初始模塊和象限判斷模塊相連,用于觸發(fā)拖動移向請 求,確定拖動移向起始點和終點坐標(biāo);象限判斷模塊,與坐標(biāo)處理模塊和移向判斷模塊相連,用于判斷坐標(biāo)處理模塊 觸發(fā)的拖動移向的所在象限,并請求移向判斷模塊根據(jù)拖動移向所在象限進(jìn)行拖動移向 的判斷;移向判斷模塊,與象限判斷模塊和正切表初始模塊相連,用于接收象限判斷模 塊發(fā)來的拖動移向的所在具體象限的結(jié)果,k倍放大終點坐標(biāo)相對于原點坐標(biāo)的偏移量的 正切值,與正切表初始模塊的各正切值逐個對比確定拖動移向的方向。本發(fā)明的有益效果本發(fā)明實施例中通過η個方向來判斷拖動移向,其中共分為2η個夾角,拖動移 向判斷誤差在360° /2η夾角內(nèi)(η可以無限大擴(kuò)展,η越大,誤差越小,),計算終點坐 標(biāo)偏移量的正切值,再與正切表里取值進(jìn)行比較,從而確定移動的方向;在不支持浮點 數(shù)運算的系統(tǒng)或設(shè)備中,把正切值無限放大;本發(fā)明支持所有系統(tǒng)和設(shè)備,擴(kuò)展性好, 判斷移動方向精確、誤差小,準(zhǔn)確率較高,刷新快。
圖1是現(xiàn)有技術(shù)判斷拖動移向的方法示意圖;圖2是本發(fā)明實施例一種判斷拖動移向的方法流程圖;圖3是本發(fā)明實施例8個方向判斷拖動移向的方法示意圖;圖4是本發(fā)明實施例一種判斷拖動移向的系統(tǒng)結(jié)構(gòu)圖。
具體實施例方式為了使本發(fā)明的目的、技術(shù)方案及優(yōu)點更加清楚明白,以下結(jié)合附圖和實施 例,對本發(fā)明進(jìn)行進(jìn)一步詳細(xì)說明,為了便于說明,僅示出了與本發(fā)明實施例相關(guān)的部 分。應(yīng)當(dāng)理解,此處所描寫的具體實施例,僅僅用于解釋本發(fā)明,并不用以限制本發(fā) 明。本發(fā)明通過確定用來判斷拖動移向的方向的數(shù)量,對自定義正切表進(jìn)行賦值, 當(dāng)觸發(fā)拖動移向請求時,確定起始點和終點,以起始點為原點,確定水平X軸和垂直Y 軸,以原點和水平X軸為一條邊開始繞原點均分為η個夾角,共形成η條邊,每條邊為一 個移向,再對每個夾角進(jìn)行二等分,形成第二個η等分夾角,根據(jù)終點相對起點的偏移量的正切函數(shù)和自定義正切表中的數(shù)值確定拖動移向的方向。實施例一圖2是本發(fā)明實施例一種判斷拖動移向的方法流程圖。所述的方法包括以下步 驟S201,自定義正切表賦值;根據(jù)判斷拖動移向的方向的數(shù)量η (n ^ 2),來確定正切表的賦值,此處為了方便 理解,以8個方向為例說明,如圖4所示,tanTable = {k*tan22.5°,k*tan67.5°丨,其中 tanTable為正切表,22.5°為360°分為16等分夾角的度數(shù),67.5°為一個16等分夾角與 一個8等分夾角的和;其中k為正整數(shù),當(dāng)系統(tǒng)不支持浮點數(shù)運算時,k無限大,且每個 正切值的賦值是經(jīng)調(diào)用外部工具生成;同樣可以采用余切、正弦、余弦、正割、余割三角函數(shù)方法實現(xiàn)余切表、正弦 表、余弦表、正割表、余割表的賦值,具體算法類似,這里不做一一敘述;S202,觸發(fā)拖動移向請求,確定起始點和終點;以8個方向為例說明,如圖3所示,從O向P拖動,形成直線OP,O為起始 點,P為終點,其中OP可以為任何一個方向,此處以圖4的OP位置為例,OP所在位置 為第一象限;S203,以起始點為原點,確定水平X軸和垂直Y軸;S204,以水平X軸為一條邊開始圍繞原點分為η等分夾角,共形成的η條邊作為 移動的η個方向;以8個方向為例說明,如圖4所示,共形成8等分夾角為ΒΟΑ、Α0Η、 HOG、GOF> FOE、EOD> DOC、COB,其中 8 條邊 OA、OH、OG、OF、OE、OD、
OC> OB為拖動移向的方向;S205,對所述的每個η等分夾角再進(jìn)行二等分,形成第二個的η等分夾角;以8個方向為例說明,如圖4所示,共形成第二個8等分夾角為IOJ、J0K、 KOL> LOM、MON、NOQ> QOR、ROI,其中,OP落入第二個8等分夾角后的拖動移 向的方向分別是 0J、01、OR、OQ > ON、OM、OL > OK;S206,判斷拖動移向是否為4個坐標(biāo)軸方向重合;根據(jù)Δ X、Δ Y的取值進(jìn)行判斷OP在坐標(biāo)軸上的拖動移向,其中ΔΧ、ΔΥ為 P點相對于起點O的坐標(biāo)偏移量;S207,如果是,則拖動移向為其中的一個坐標(biāo)軸方向;以8個方向為例說明,如圖4所示,判斷方法為如果Δ X = O且Δ Y > 0,則OP的拖動移向為OH ;如果Δ X = O且Δ Y < 0,則OP的拖動移向為OD ;如果Δ X > O且Δ Y = O 則OP的拖動移向為OB ;如果Δ X < O且Δ Y = 0,則OP的拖動移向為OF ;S208,如果否,確定拖動移向所在象限;S209,根據(jù)終點坐標(biāo)偏移量的正切值與自定義正切表中的數(shù)值確定拖動移向的 方向;以8個方向為例說明,如圖4所示
如果ΔΧ>0且ΔΥ>0,則OP在第一象限,這時判斷條件k* Δ Y/Δ X
<tanTable
是否成立,條件成立則確定OP拖動移向為OB ;否則,判斷條件tanTable
Sk* Δ Y/Δ X&&k* Δ Y/ Δ X<tanTable[l]是否成立,
條件成立則確定OP拖動移向為OA ;否則,OP的拖動移向為OH;所述的k為正整數(shù),當(dāng)系統(tǒng)不支持浮點數(shù)運算時,k無限大;如果ΔΧ>0且ΔΥ<0,則OP在第四象限,這時判斷條件k* Δ Y/Δ X
>-tanTable
是否成立,條件成立則確定OP拖動移向為OB ;否貝丨J,判斷條件-tanTable
> k* Δ Y/ Δ X&&k* Δ Y/ Δ X > _tanTable[l]是否成
立,條件成立則確定OP拖動移向為OC ;否則,OP的拖動移向為OD;所述的k為正整數(shù),當(dāng)系統(tǒng)不支持浮點數(shù)運算時,k無限大;如果ΔΧ<0且ΔΥ>0,則OP在第二象限,這時判斷條件k* Δ Y/Δ X
>-tanTable
是否成立,條件成立則確定OP拖動移向為OF ;否貝丨J,判斷條件_tanTable
> k* Δ Y/ Δ X&&k* Δ Y/ Δ X > _tanTable[l]是否成
立,條件成立則確定OP拖動移向為OG ;否則,OP的拖動移向為OH;所述的k為正整數(shù),當(dāng)系統(tǒng)不支持浮點數(shù)運算時,k無限大;如果ΔΧ<0且ΔΥ<0,則OP在第三象限,這時判斷條件k* Δ Y/Δ X
<tanTable
是否成立,條件成立則確定OP拖動移向為OF ;否則,判斷條件tanTable
Sk* Δ Y/Δ X&&k* Δ Y/ Δ X<tanTable[l]是否成立, 條件成立則確定OP拖動移向為OE ;否則,OP的拖動移向為OD;所述的k為正整數(shù),當(dāng)系統(tǒng)不支持浮點數(shù)運算時,k無限大。本發(fā)明實施例中通過n(n^2)個方向來判斷拖動移向,其中共分為2η個夾角, 拖動移向判斷誤差在360° /2η夾角內(nèi),誤差更小,準(zhǔn)確率較高,刷新更快,同時,η可 以無限大擴(kuò)展,η越大,誤差越小,拖動移向更精確,此方法還可以采用余切、正弦、余 弦、正割、余割三角函數(shù)方法實現(xiàn)。實施例二圖4是本發(fā)明實施例一種判斷拖動移向的系統(tǒng)結(jié)構(gòu)圖。所述的系統(tǒng)包括正切表初始模塊、坐標(biāo)處理模塊、象限判斷模塊、移向判斷 模塊;正切表初始模塊,與坐標(biāo)處理模塊和移向判斷模塊相連,用于根據(jù)所要判斷拖 動移向的方向的數(shù)量對正切表賦值,接收移向判斷模塊獲取正切值的請求,并發(fā)送符合 條件的正切值到移向判斷模塊;此處為了方便理解,以8個方向為例說明,如圖4所示,所述根據(jù)判斷拖動移向 的方向的數(shù)量為 8,tanTable = {k*tan22.5°,k*tan67.5° },其中 tanTable 為正切表,
22.5°為360°分為16等分夾角的度數(shù),67.5°為一個16等分夾角與一個8等分夾角的 和;其中k為正整數(shù),當(dāng)系統(tǒng)不支持浮點數(shù)運算時,k無限大,且每個正切值的賦值是經(jīng)調(diào)用外部工具生成;坐標(biāo)處理模塊,與正切表初始模塊和象限判斷模塊相連,用于觸發(fā)拖動移向請 求,確定拖動移向起始點和終點坐標(biāo);象限判斷模塊,與坐標(biāo)處理模塊和移向判斷模塊相連,用于判斷坐標(biāo)處理模塊 觸發(fā)的拖動移向的所在象限,并請求移向判斷模塊根據(jù)拖動移向所在象限進(jìn)行拖動移向 的判斷;所述的象限判斷是根據(jù)拖動移向的終點坐標(biāo)相對于原點坐標(biāo)的偏移量的取值來 確定;移向判斷模塊,與象限判斷模塊和正切表初始模塊相連,用于接收象限判斷模 塊發(fā)來的拖動移向的所在具體象限的結(jié)果,k倍放大終點坐標(biāo)相對于原點坐標(biāo)的偏移量的 正切值,與正切表初始模塊的各正切值逐個對比確定拖動移向的方向;所述拖動移向的方向是以拖動移向的起始坐標(biāo)為原點以水平X軸為一條邊圍繞 原點進(jìn)行判斷拖動移向的方向數(shù)量的等分形成的夾角的其中一條邊的方向;以8個方向為例說明,如圖4所示,共形成8等分夾角為BOA、AOH、 HOG、GOF> FOE、EOD> DOC、COB,其中 8 條邊 OA、OH、OG、OF、OE、OD、 OC> OB為拖動移向的方向;所述具體象限的結(jié)果是指拖動移向所在的是第幾象限。所述的正切表同樣可以采用余切、正弦、余弦、正割、余割三角函數(shù)方法實現(xiàn) 余切表、正弦表、余弦表、正割表、余割表的賦值,具體算法類似,這里不做一一敘 述。所述的判斷拖動移向的系統(tǒng)工作過程如下正切表初始模塊根據(jù)所要進(jìn)行判斷拖動移向的方向的數(shù)量來確定正切表的賦 值;坐標(biāo)處理模塊觸發(fā)拖動移向請求,確定起始點和終點的坐標(biāo);象限處理模塊判斷拖 動移向的方向所在的象限,并發(fā)送請求到移向判斷模塊進(jìn)行拖動移向的方向判斷;移向 判斷模塊接收到象限處理模塊確定的拖動移向具體象限的結(jié)果,與正切表初始模塊的各 正切值逐個比較確定拖動移向的方向;本發(fā)明實施例中正切表的賦值可自定義賦值也可調(diào)用外部系統(tǒng)賦值,同時正切 表初始模塊可以靈活擴(kuò)展到余切、正弦、余弦、正割、余割賦值并作為判斷條件;賦值 的數(shù)量根據(jù)判斷拖動移向的方向數(shù)量來確定,賦值可以無限大倍數(shù)擴(kuò)大,適用不支持浮 點數(shù)運算的系統(tǒng),判斷拖動移向的方向數(shù)量越多,誤差越小,刷新越快。
權(quán)利要求
1.一種拖動移向判斷的方法,其特征在于,所述方法包括以下步驟 自定義正切表賦值;觸發(fā)拖動移向請求,確定起始點和終點; 以起始點為原點,確定水平X軸和垂直Y軸; 以水平X軸為一條邊開始圍繞原點起始點分為η等分夾角; 對所述的每個η等分夾角再進(jìn)行二等分,形成第二個的η等分夾角; 根據(jù)終點坐標(biāo)偏移量的正切值與自定義正切表中的數(shù)值的關(guān)系確定起始點和終點的 連線的拖動移向。
2.如權(quán)利要求1所述的拖動移向判斷方法,其特征在于,所述正切表賦值為 tanTable = {k*tan22.5°,k*tan67.5° };其中tanTable為正切表,22.5°為360°分為16等分夾角的度數(shù),67.5°為一個16等 分夾角與一個8等分夾角的和;其中k為正整數(shù),當(dāng)系統(tǒng)不支持浮點數(shù)運算時,k無限 大,且每個正切值的賦值是經(jīng)調(diào)用外部工具生成。
3.如權(quán)利要求1所述的拖動移向判斷方法,其特征在于所述“自定義正切表賦值”步驟可替換為“自定義余切/正弦/余弦/正割/余割 表賦值”;所述“根據(jù)坐標(biāo)偏移量的正切值與自定義正切表中的數(shù)值的關(guān)系確定起始點和終點 的連線的拖動移向”可替換為“根據(jù)坐標(biāo)偏移量的余切/正弦/余弦/正割/余割值與 自定義余切/正弦/余弦/正割/余割表中的數(shù)值的關(guān)系確定起始點和終點的連線的拖動 移向”。
4.如權(quán)利要求1所述的拖動移向判斷方法,其特征在于,步驟“根據(jù)所述終點坐標(biāo)偏 移量的正切值與自定義正切表中的數(shù)值的關(guān)系確定起始點和終點的連線的拖動移向”之 前還包括步驟判斷起始點和終點的連線是否與4個坐標(biāo)軸方向重合;如果是,則根據(jù)終點橫坐標(biāo)和縱坐標(biāo)的偏移量來確定起始點和終點的連線方向; 如果否,判斷起始點和終點的連線所在象限;進(jìn)入步驟“根據(jù)終點坐標(biāo)偏移量的正切值與自定義正切表中的數(shù)值的關(guān)系確定起始 點和終點的連線的拖動移向”。
5.如權(quán)利要求4所述的拖動移向判斷方法,其特征在于,步驟“判斷起始點和終點的 連線是否與4個坐標(biāo)軸方向重合”具體為如果ΔΧ = 0且Δ Y > 0,則起始點和終點的連線的拖動移向為Y軸的正方向; 如果ΔΧ = 0且Δ Y < 0,則起始點和終點的連線的拖動移向為Y軸的負(fù)方向; 如果ΔΧ>0且ΔΥ = 0:則起始點和終點的連線的拖動移向為X軸的正方向; 如果ΔΧ < 0且Δ Y = 0,則起始點和終點的連線的拖動移向為X軸的負(fù)方向; 其中Δ X為終點在X軸上的偏移量,Δ Y是終點在Y軸上的偏移量。
6.如權(quán)利要求1所述的拖動移向判斷方法,其特征在于,所述“根據(jù)終點坐標(biāo)偏移量 的正切值與自定義正切表中的數(shù)值的關(guān)系確定起始點和終點的連線的拖動移向”具體包 括如果ΔΧ>0且ΔΥ>0,則起始點和終點的連線在第一象限,這時判斷條件k*AY/ΔΧ < tanTable
是否成立,條件成立則確定起始點和終點的連線拖動移向為X軸正方 向;成立則確定起始點和終點的連線拖動移向為第一象限對角線方向; 否則,起始點和終點的連線的拖動移向為Y軸正方向;如果ΔΧ>0且ΔΥ<0,則起始點和終點的連線在第四象限,這時判斷條件k*AY/ Δ X > -tanTable
是否成立,條件成立則確定起始點和終點的連線拖動移向為X軸正方 向;件成立則確定起始點和終點的連線拖動移向為第四象限對角線; 否則,起始點和終點的連線的拖動移向為Y軸負(fù)方向;如果ΔΧ<0且ΔΥ>0,則起始點和終點的連線在第二象限,這時判斷條件k*AY/ Δ X > -tanTable
是否成立,條件成立則確定起始點和終點的連線拖動移向為X軸負(fù)方 向;件成立則確定起始點和終點的連線拖動移向為第二象限對角線方向; 否則,起始點和終點的連線的拖動移向為Y軸正方向;如果ΔΧ<0且ΔΥ<0,則起始點和終點的連線在第三象限,這時判斷條件k*AY/ ΔΧ < tanTable
是否成立,條件成立則確定起始點和終點的連線拖動移向為X軸負(fù)方 向;成立則確定起始點和終點的連線拖動移向為第三象限對角線方向; 否則,起始點和終點的連線的拖動移向為Y軸負(fù)方向;其中ΔΧ、ΔΥ為終點相對于起始點在X軸、Y軸上的偏移量;tanTable
、 tanTable[l]表示各夾角的正切值的K倍;&&表示前后兩個條件必須都滿足;k為正整 數(shù),當(dāng)系統(tǒng)不支持浮點數(shù)運算時,k無限大,且每個正切值的賦值是經(jīng)調(diào)用外部工具生 成。
7.—種拖動移向判斷的系統(tǒng),其特征在于,所述系統(tǒng)包括 正切表初始模塊、坐標(biāo)處理模塊、象限判斷模塊、移向判斷模塊; 正切表初始模塊,與坐標(biāo)處理模塊和移向判斷模塊相連,用于根據(jù)所要判斷移向的 方向數(shù)的數(shù)量對正切表賦值,接收移向判斷模塊獲取正切值的請求,并發(fā)送符合條件的 正切值到移向判斷模塊;坐標(biāo)處理模塊,與正切表初始模塊和象限判斷模塊相連,用于觸發(fā)拖動移向請求, 確定拖動移向起始點和終點坐標(biāo);象限判斷模塊,與坐標(biāo)處理模塊和移向判斷模塊相連,用于判斷坐標(biāo)處理模塊觸發(fā) 的拖動移向的所在象限,并請求移向判斷模塊根據(jù)拖動移向所在象限進(jìn)行拖動移向的判 斷;移向判斷模塊,與象限判斷模塊和正切表初始模塊相連,用于接收象限判斷模塊發(fā) 來的拖動移向的所在具體象限的結(jié)果,k倍放大終點坐標(biāo)相對于原點坐標(biāo)的偏移量的正切值,與正切表初始模塊的各正切值逐個對比確定拖動移向的方向。
8.如權(quán)利要求7所述的拖動移向判斷系統(tǒng),其特征在于所述正切表 tanTable = {k*tan22.5°,k*tan67.5° },22.5° 為 360° 分為 16 等分夾 角的度數(shù),67.5°為一個16等分夾角與一個8等分夾角的和;其中k為正整數(shù),當(dāng)系統(tǒng) 不支持浮點數(shù)運算時,k無限大,且每個正切值的賦值是經(jīng)調(diào)用外部工具生成。
9.如權(quán)利要求7所述的拖動移向判斷系統(tǒng),其特征在于所述“正切表初始模塊”可替換為“余切/正弦/余弦/正割/余割表初始模塊”; 所述“正切值”替換為“余切/正弦/余弦/正割/余割值”。
全文摘要
本發(fā)明公開一種拖動移向判斷的方法和系統(tǒng),本發(fā)明通過n個方向來判斷拖動移向,其中共分為2n個夾角,拖動移向判斷誤差在360°/2n夾角內(nèi),n可以無限大擴(kuò)展,n越大,誤差越小,拖動移向更精確;計算坐標(biāo)偏移量的正切值,再與正切表里取值進(jìn)行比較,從而確定拖動移動的方向;本發(fā)明方法具有良好擴(kuò)展性和通用性,可準(zhǔn)確判斷拖動移向的方向。
文檔編號G06F3/048GK102012782SQ20101028548
公開日2011年4月13日 申請日期2010年9月17日 優(yōu)先權(quán)日2010年9月17日
發(fā)明者宋葉祥 申請人:深圳市融創(chuàng)天下科技發(fā)展有限公司