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