我有一個GridView。 GridView中的每個項目都是水平(或垂直)佈局(取決於方向)。該佈局內部是一個ImageView和一個TextView。在onLongPress之後,gridview中的第一個視圖在startDrag中獲取NullPointerException
當我在任何ImageView上執行「Long Touch」時,除GridView中的第一個外,所有內容都按計劃運行。在onLongPress()處理程序中,我調用ImageView上的startDrag,並且一切按計劃進行。如果我在GridView的第一個ImageView上執行「Long Touch」,我會在Android View的startDrag()方法中得到一個NullPointer異常。
08-16 10:11:04.425: E/View(2456): Unable to initiate drag
08-16 10:11:04.425: E/View(2456): java.lang.NullPointerException
08-16 10:11:04.425: E/View(2456): at android.view.View.startDrag(View.java:16281)
08-16 10:11:04.425: E/View(2456): at org.xyzzy.test.GridLauncher$ShortCutTouchListener$ShortcutGestureListener.onLongPress(RemoteLauncher.java:650)
08-16 10:11:04.425: E/View(2456): at android.view.GestureDetector.dispatchLongPress(GestureDetector.java:675)
我可以確認所有的傳遞給的startDrag參數是非空 - 一個ClipData,一個DragShadowBuilder,並作爲LocalState我ImageView的。這裏是代碼片段:
ClipData data = ClipData.newPlainText("", "");
DragShadowBuilder shadowBuilder = new View.DragShadowBuilder(mView);
boolean doingDrag = mView.startDrag(data, shadowBuilder, mView, 0);
startDrag返回false,並且logcat包含無法啓動拖動消息和異常跟蹤。
這隻發生在gridview中的第一個ImageView上。所有其他人工作得很好。
我繞過Android View源尋找線索 - 發現我的設備的構建/標記是試驗和錯誤,但我發現其中少數線路16281在startDrag中的一個是標記jb-mr1-release(我的Nexus 10是4.2.1,所以它可能是正確的)。在16281的代碼是:
Point shadowSize = new Point();
Point shadowTouchPoint = new Point();
shadowBuilder.onProvideShadowMetrics(shadowSize, shadowTouchPoint);
if ((shadowSize.x < 0) || (shadowSize.y < 0) ||
(shadowTouchPoint.x < 0) || (shadowTouchPoint.y < 0)) {
throw new IllegalStateException("Drag shadow dimensions must not be negative");
}
if (ViewDebug.DEBUG_DRAG) {
Log.d(VIEW_LOG_TAG, "drag shadow: width=" + shadowSize.x + " height=" + shadowSize.y
+ " shadowX=" + shadowTouchPoint.x + " shadowY=" + shadowTouchPoint.y);
}
Surface surface = new Surface();
try {
IBinder token = mAttachInfo.mSession.prepareDrag(mAttachInfo.mWindow,
flags, shadowSize.x, shadowSize.y, surface);
if (ViewDebug.DEBUG_DRAG) Log.d(VIEW_LOG_TAG, "prepareDrag returned token=" + token
+ " surface=" + surface);
行16281是在嘗試的第一條語句:令牌的IBinder = mAttachInfo.mSession ...
如果我的偵探是正確的(我有權利JB /視圖。 java源代碼),那麼問題出現在mAttachInfo或其中一個字段爲空。 shadowSize已經過審查,表面剛創建。是否有一些原因,爲什麼第一個視圖不會有「mAttachInfo」值(假設它意味着它沒有連接到窗口)?或者它可能是try塊內的其他行(異常被捕獲)。
錯誤可能是在RemoteLauncher.java:650。那條線上具體是什麼? – Nizam
這將是上面代碼中對startDrag的調用: DragShadowBuilder shadowBuilder = new View。DragShadowBuilder(MVIEW); – BJV
那麼'mView'在那裏是空的。 – Nizam