天天看點

Android實作的三種翻頁功能原理

本文給開發者集中展現了Android平台中的三種翻頁效果機器實作原理,希望能夠對開發者有實際的幫助價值!

  第一種翻頁效果如下:

  

  實作原理:

  目前手指觸摸點為a,則 a點坐标為(ax,ay), 由三角形acb與三角形cmb為對稱三角形并且直線cp為am垂直平分線,則 B點坐标為(ax/2,ay/2)。

  作gf垂直于om且cb垂直于am, 三角形cfg與gfm相似,則 cf:gf = gf:mf cf=(gf * gf) / mf gf長度為g點縱坐标 mf長度為g點橫坐标

  cf長度可求 c點坐标可求 由c點、g點可确定過兩點間的直線, 當該直線中x=0時求出與y足交點。

  第二種翻頁效果

  使用貝賽爾曲線。曲線有四個點:起始點、終止點(也稱錨點)以及兩個互相分離的中間點。滑動兩個中間點,貝塞爾曲線的形狀會發生變化。

  根據第一種翻頁效果原理可以确定a、e、h、f、g ,由eh平行于cj且af垂直于eh,則 af垂直于cj則三角形egf相似于三角形cnf 則有ef:cf = gf:nf 。

  設n為ag中點 則有cf=(3/2)*ef ,則c點坐标可求 由c點、k點坐标已知可知過兩點間的直線

  由該直線可計算與y軸相交點j 由a、e、c、j可計算兩條直線的相交點b 同理可求點k。

  在Android中的具體實作步驟:

  起始頁展示

  1.建立螢幕尺寸的bmp 2.将圖檔轉化為canvas 3.擷取起始頁面資料 3.在canvas中繪制起始頁資料 4.在目前視圖中複寫onDraw進行重繪出bmp對象

  翻頁處理

  1.初始化時建立兩個bmp(bmp1、bmp2)并将其轉換為canvas(canvas1、canvas2)

  2.擷取手勢首次觸摸的區域 (例:當首次點選螢幕的位置x<50&&y<50則為左上角)

  3.根據首次點選區域判斷需要展示的資料(例:首次點選處于左側區域【左上、左下】的則判斷操作為下一頁操作)

  4.擷取下一頁中資料并繪制出來在canvas2中

  5.根據1中擷取的區域位置調用起始動畫使視圖移動到手勢首次點選位置

  6.擷取手勢每次移動的坐标并根據移動坐标計算繪制的各個點的坐标

  7.每次移動重新整理視圖

本文轉自 wws5201985 51CTO部落格,原文連結:http://blog.51cto.com/wws5201985/778429,如需轉載請自行聯系原作者

繼續閱讀