日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

Android华容道之一步一步实现-6-还原状态检测

發布時間:2025/3/21 60 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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-还原状态检测的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。