android的launcher分析_第1頁
android的launcher分析_第2頁
android的launcher分析_第3頁
android的launcher分析_第4頁
android的launcher分析_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、今年做了 launcher 相關(guān)的工作,看了很長時間。很多人都在修改 launcher,但還沒有詳細的文檔,把自己積累的東西分享出來,大家一起積累。這份源碼是基于 2.1的 launched,以后版本雖有變化,但大概的原理一直還是保留了。、主要文件和類1 .Launcher.java:launcher 中主要的 activity。2 .DragLayer.java:launcherlayout 的 rootview0DragLayer 實際上也是一個抽象的界面,用來處理拖動和對事件進行初步處理然后按情況分發(fā)下去,角色是一個controllero它首先用 onlnterceptTouchEven

2、t(MotionEvent)來攔截所有的 touch事件,如果是長按 item 拖動的話不把事件傳下去,直接交由 onTouchEvent()處理,這樣就可以實現(xiàn) item 的移動了, 如果不是拖動 item 的話就把事件傳到目標(biāo) view,交有目標(biāo) view的事件處理函數(shù)做相應(yīng)處理。如過有要對事件的特殊需求的話可以修改onInterceptTouchEvent(MotionEvent)來實現(xiàn)所需要的功能。3 .DragController.java:為 Drag 定義的一個接口。包含一個接口,兩個方法和兩個靜態(tài)常量。接口為 DragListener(包含 onDragStart(),onDr

3、agEnd()兩個函數(shù)),onDragStart()是在剛開始拖動白時候被調(diào)用,onDragEnd()是在拖動完成時被調(diào)用。在 launcher 中典型的應(yīng)用是 DeleteZone,在長按拖動 item 時調(diào)用 onDragStart()顯示,在拖動結(jié)束的時候 onDragEnd()隱藏。兩個函數(shù)包括 startDrag()和setDragItemInfo().startDrag()用于在拖動是傳遞要拖動的 item 的信息以及拖動的方式,setDragItemInfo()用于傳遞 item 的參數(shù)信息(包括位置以及大小)。兩個常量為DRAG_ACTION_MOVE,DRAG_ACTION_

4、COPY 來標(biāo)識拖動的方式,DRAG_ACTION_MOVE 為移動,表示在拖動的時候需要刪除原來的 item,DRAG_ACTION_COPY 為復(fù)制型的拖動,表示保留被拖動的 item。4 .LauncherModel.java:輔助的文件。 里面有許多封裝的對數(shù)據(jù)庫的操作。 包含幾個線程,其中最主要的是 ApplicationsLoader 和 DesktopItemsLoader)ApplicationsLoader 在加載所有應(yīng)用程序時使用,DesktopItemsLoader 在力口載workspace 的時候使用。其他的函數(shù)就是對數(shù)據(jù)庫的封裝,比如在刪除,替換,添加程序的時候做更

5、新數(shù)據(jù)庫和 UI 的工作。5 .Workspace.java:抽象的桌面。由 N 個 celllaout 組成,從 cellLayout 更高一級的層面上對事件的處理。6 .LauncherProvider.java:launcher 的數(shù)據(jù)庫, 里面存儲了桌面的計 em 的信息。 在創(chuàng)建數(shù)據(jù)庫的時候會 loadFavohtes(db)方法,loadFavohtes(法解析 xml 目錄下的default_workspace.xml 文件, 把其中的內(nèi)容讀出來寫到數(shù)據(jù)庫中, 這樣就做到了桌面的預(yù)制。7 .CellLayout.java:組成 workspace 的 view,繼承自 viewg

6、roup,既是個 dragSource又是一個 dropTarget,可以將它里面的 item 拖出去,也可以容納拖動過來的 item0在workspace_screent 面定了些它的 view 參數(shù)。1.1 temInfo.java:對 item 的抽象, 所有類型 item 的父類, item 包含的屬性有 id (標(biāo)識 item的 id),cellX(在橫向位置上的位置,從 0 開始),cellY(在縱向位置上的位置,從 0 開始),spanX(在橫向位置上所占的單位格),spanY(在縱向位置上所占的單位格),screen(在 workspace 的第幾屏,從 0 開始),itemT

7、ype(item 的類型,有widget,searchhapplicationIF),container(item 所在的)。.UserFolder.java:用戶創(chuàng)建的文件夾??梢詫?item 拖進文件夾,單擊時打開文件夾,長按文件夾上面標(biāo)題處可以重命名文件夾。.LiveFolder.java:系統(tǒng)自帶的文件夾。從系統(tǒng)中創(chuàng)建出的如聯(lián)系人的文件夾等。.DeleteZone 刪除框。在平時是出于隱藏狀態(tài),在將 item 長按拖動的時候會顯示出來,如果將 item 拖動到刪除框位置時會刪除 item。DeleteZone 實現(xiàn)了 DropTarget 和DragListener 兩個接口。.Lau

8、ncherSettings.java 字符串的定義。數(shù)據(jù)庫項的字符串定義,另外在這里定義了container 的類型,還有讓 emType 的定義,除此還有一些特殊的 widget(如 search,clock的定義等)的類型定義。二、主要模塊1.界面模型:statusbar+J1*MaaaM,.口口口口1_邢。依邢。依( (由忖由忖cellLa/oirt組成組成workspacehDeletezon口Handvie1.*1Launcher 的界面的 rootview 是 DragLayer,它是個 FrameLayout,在它上面workspace(應(yīng)該說是 celllayout)占了絕大部

9、分的空間,celllayout 的參數(shù)文件是workspace_screen.xmlworkspace 既是一個 DropTarget 又是一個 DragSource,可以從AllAppGridView 中拖出應(yīng)用程序放在它上面,也可以把它里面的 item 拖走刪除或者拖到 bottomabr 里面去。2.Drop&Drag 模型:DragSource 可以拖動的對象來源的容器,在 launcher 中主要有AllAppGridView,workspace 等。voidonDropCompleted(Viewtarget,booleansuccess,intx,inty);DropTa

10、rget:可以放置被拖動的對象的容器。在 launcher 中有 folder,workspace,bottomba 邙,一個 View 既可以是 Dragsource 也可以是 DropTarget。主要包含以下幾個接口:booleanacceptDrop(DragSourcesource,intx,inty,intxOffset,intyOffset,ObjectdragInfo);acceptDrop 函數(shù)用來判斷 dropTarget 是否可以接受 item 放置在自己里面。voidonDragEnter(DragSourcesource,intx,inty,intxOffset,in

11、tyOffset,ObjectdragInfo);onDragEnter 是 item 被拖動進入到一個 dropTarget 的時候的回調(diào)。voidonDragOver(DragSourcesource,intx,inty,intxOffset,intyOffset,Objectdraginfo);onDragOver 是 item 在上一次位置和這一次位置所處的 dropTarget 相同的時候的回調(diào)。voidonDragExit(DragSourcesource,intx,inty,intxOffset,intyOffset,Objectdraginfo);onDragExit 是 it

12、em 被拖出 dropTarget 時的回調(diào)。booleanonDrop(DragSourcesource,intx,inty,intxOffset,intyOffset,Objectdraginfo);onDrop 是 item 被放置到 dropTarget 時的回調(diào)。函數(shù)的調(diào)用模式為:DropTargetdropTarget=findDropTarget(int)x,(int)y,coordinates);if(dropTarget!=null)/*當(dāng)這一次的 target 跟上一次相同時,根據(jù)坐標(biāo)來移動 item*/if(mLastDropTarget=dropTarget)dropT

13、arget.onDragOver(mDragSource,coordinates0,coordinates1,(nt)mTouchOffsetX,(int)mTouchOffsetY,mDraginfo);else*當(dāng)上一次的位置跟這一次不同而且上一次的位置不為空,說明 item*動出了,將上次的 View 根據(jù)上次的坐標(biāo)重新排列,并根據(jù)當(dāng)前坐標(biāo)重排*當(dāng)前的*/if(mLastDropTarget!=null)mLastDropTarget.onDragExit(mDragSource,coordinates0,coordinates1,(nt)mTouchOffsetX,(int)mTouc

14、hOffsetY,mDragInfo);dropTarget.onDragEnter(mDragSource,coordinates0,coordinates1,(nt)mTouchOffsetX,(int)mTouchOffsetY,mDragInfo);else/如果這一次為 null,上一次不為 null,那么把上一次坐標(biāo)位置的 cellif(mLastDropTarget!=null)mLastDropTarget.onDragExit(mDragSource,coordinates0,coordinates1,int)mTouchOffsetX,(int)mTouchOffsetY,

15、mDragInfo);/記錄上次的 droptargetmLastDropTarget=dropTarget;3.Touchevent 總結(jié):由于 launcher 的事件比較多比較復(fù)雜,所以在事件處理的時候一般采用rootview 先用 onInterceptTouchEvent(MotionEvent/截所有的 touch 事件,經(jīng)過判斷后分發(fā)給 childview0判斷的規(guī)則如下:a.down 事件首先會傳遞至 ijonInterceptTouchEvent(訪法b.如果該 ViewGroup 的 onInterceptTouchEvent(底接 U到 down 事件處理完成之后retu

16、rnfalse,那么后續(xù)的 move,up 等事件將繼續(xù)會先傳遞給該 ViewGroup,之后才和 down事件一樣傳遞給最終的目標(biāo) view 的 onTouchEvent(收 t 理。c 如果該 ViewGroup 的 onInterceptTouchEvent(底接 U到 down 事件處理完成之后returntrue,那么后續(xù)的 move,up 等事件將不再傳遞給 onInterceptTouchEvent(),而是和down 事件一樣傳遞給該 ViewGroup 的 onTouchEvent()處理,注意,目標(biāo) view 將接收不到任何事件。d.如果最終需要處理事件的 view 的 o

17、nTouchEvent(泅回了 false,那么該事件將被傳遞至其上一層次的 view 的 onTouchEvent()處理。e 如果最終需要處理事件的 view 的 onTouchEvent(泅回了 true,那么后續(xù)事件將可以繼續(xù)傳遞給該 view 的 onTouchEvent()處理。三、幾種問題的解決方式.將所有的應(yīng)用都排列在桌面上launcher:y=./放置 y 方向的位置(在行中的位置)將所有的應(yīng)用都排列在桌面是通過首先創(chuàng)建一個三維的 boolean 型全局數(shù)組來記錄計 em 的排列情況,第一維是屏數(shù),第二維是縱向上的排列情況,第三維是橫向的排列情況, 如果那個位置被 item

18、所占用就標(biāo)記為 1,否則標(biāo)記為 0.在啟動時把全局數(shù)組初始化為 0,然后在添加的時候把相應(yīng)的位置置 1.凡是涉及到 workspace 上 item 的變化,比如移動、添加、刪除操作時都需要維護數(shù)組,保持數(shù)組的正確性,因為在安裝新程序時依據(jù)數(shù)組的狀態(tài)去判斷把 item 加到什么位置。.動態(tài)增加屏幕動態(tài)增加屏幕是通過 worksapce.addchild(view)的方式實現(xiàn)?;舅悸肥牵菏紫阮A(yù)先規(guī)定所允許的最大的屏幕數(shù),然后在需要增加屏幕而且當(dāng)前屏幕數(shù)沒有超過最大屏幕數(shù)的時候通過(CellLayout)mInflater.inflate(R.layout.workspace_screen,nu

19、ll)倉1J建一個celllayout實例出來, 然后通過 addchild 把它加入進去。 在屏幕上的 item 被刪除時通過從最后一屏起判斷屏幕上是否有 item,如果有的話保留,沒有的話則刪除最后一屏,以此類推。.預(yù)制桌面a.添加普通的應(yīng)用程序快捷方式:在./res/xml 下的 default_workspace.xml 文件中加入默認要放置的普通的應(yīng)用程序。 加入的格式為:/在 y 方向上所占格數(shù)widgetlauncher:packageName=.launcher:className=.launcher:container=.launcher:screen=.launcher:x

20、-.launcher:y=.launcher:spanx=.例如,要在第 3 屏的第一行第二列放置開始放置一個 x 方向上占兩個單位格,y 方向上占兩個單位格的時鐘,可以加入以下代碼:.改變主界面的排列方式要修改桌面的排列方式,如下,先根據(jù)橫豎屏設(shè)置修改 workspace_screen.xml里 shortAxisCells 和 longAxisCells 的參數(shù),然后在 Launcher.java 中修改NUMBER_CELLS_X 和 NUMBER_CELLS_Y 的值, 在 2.3 版本中剛開始往數(shù)據(jù)庫中添加item 的時候會去判斷,如果不修改 NUMBER_CELLS_X 和 NUMBER_CELLS_Y 的話會導(dǎo)致一部分的 item 顯示不出來,導(dǎo)致預(yù)制 apk 的失敗。.增加 worksapce 上的屏數(shù)要增加屏數(shù),首先在根據(jù)橫豎屏在 launcher.xml 中的com.android.launcher.Workspac#刪除或增力口,然后在Launcher.java 中修改 SCREEN_COUNT 的值即可。四、x

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論