Android华容道之一步一步实现-6-还原状态检测
再次說(shuō)明一下,我們的華容道的最終版本是圖像華容道,不是純數(shù)字的華容道,難度當(dāng)然要比純數(shù)字版的華容道大多了,因?yàn)樵谕娴臅r(shí)候要記住整福圖像以及被切分后,每一張小圖片應(yīng)該在什么位置,如果是一幅您不熟悉的圖片的話,是很考察觀察力和記憶力的。
但是無(wú)論是圖片版也好,數(shù)字版也好,我們實(shí)現(xiàn)的本質(zhì)都是一樣的。
我們先說(shuō)數(shù)字版的華容道怎么判斷已經(jīng)還原。
還原狀態(tài)也就是初始狀態(tài),1234,5678,9 10 11 12,13 14 15
只要判斷對(duì)應(yīng)的數(shù)字是不是在對(duì)應(yīng)的位置就知道了,即判斷數(shù)字1是不是在1號(hào)位,2是不是在2號(hào)位,以此類推,所以要最多判斷15次可以判斷出是否還原。
我們的圖像版華容道也一樣,仍然是判斷每個(gè)小圖像是否在自己的正確位置,可以回憶一下我們的代碼,我們代碼中是用一個(gè)puzzles數(shù)組來(lái)存放這些圖像塊的,而每一個(gè)數(shù)組中的元素是一個(gè)img_puzzle對(duì)象,該對(duì)象除了存儲(chǔ)bitmap對(duì)象之外,還有一個(gè)原始的位置pos,這個(gè)pos從0到15,第15是一個(gè)空白圖像。
當(dāng)經(jīng)過(guò)一陣手指移動(dòng)后,圖像塊的原始位置就發(fā)生了變化,即puzzles數(shù)組中的元素進(jìn)行了交換,參考上一篇博文。雖然發(fā)生了交換,但是元素對(duì)象本身的bitmap和pos都不會(huì)發(fā)生變化,也就是說(shuō),只是他們?cè)趐uzzles數(shù)組中的位置發(fā)生了變化,從而顯示出來(lái)的整個(gè)圖片也就是亂序的了。
所以檢測(cè)我們的圖像華容道是否還原就很簡(jiǎn)單了,遍歷puzzles數(shù)組,判斷每個(gè)數(shù)組中的元素是否處于初始的位置。代碼如下:
for(int i=0;i<bit_num;i++){
if(puzzles[i[].pos !=i)
? ? ? ? return false;
}
return true;
所以,在成功還原的情況下,需要比較15次。
?
總結(jié)
以上是生活随笔為你收集整理的Android华容道之一步一步实现-6-还原状态检测的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Android华容道之一步一步实现-5-
- 下一篇: Android华容道之一步一步实现-7-