Android View使用startDragAndDrop 异常 Unable to initiate drag

Android View使用startDragAndDrop 异常 Unable to initiate drag

设备环境:Android13

源码来源:android-13.0.0_r3

View在使用startDragAndDrop出现如下异常
shell 复制代码
01-01 12:44:12.243 24031 24031 E View    : Unable to initiate drag
01-01 12:44:12.243 24031 24031 E View    : java.lang.IllegalStateException: Need to validate before calling identify is cleared
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Parcel.createExceptionOrNull(Parcel.java:3019)
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Parcel.createException(Parcel.java:2995)
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Parcel.readException(Parcel.java:2978)
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Parcel.readException(Parcel.java:2920)
01-01 12:44:12.243 24031 24031 E View    :      at android.view.IWindowSession$Stub$Proxy.performDrag(IWindowSession.java:1678)
01-01 12:44:12.243 24031 24031 E View    :      at android.view.View.startDragAndDrop(View.java:27325)
01-01 12:44:12.243 24031 24031 E View    :      at com.zhonghong.ac.view.style.adapter.AcStyleAdapter$1.onLongClick(AcStyleAdapter.java:91)
01-01 12:44:12.243 24031 24031 E View    :      at android.view.View.performLongClickInternal(View.java:7586)
01-01 12:44:12.243 24031 24031 E View    :      at android.view.View.performLongClick(View.java:7544)
01-01 12:44:12.243 24031 24031 E View    :      at android.view.View.performLongClick(View.java:7562)
01-01 12:44:12.243 24031 24031 E View    :      at android.view.View$CheckForLongPress.run(View.java:29297)
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Handler.handleCallback(Handler.java:942)
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Handler.dispatchMessage(Handler.java:99)
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Looper.loopOnce(Looper.java:201)
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Looper.loop(Looper.java:288)
01-01 12:44:12.243 24031 24031 E View    :      at android.app.ActivityThread.main(ActivityThread.java:7944)
01-01 12:44:12.243 24031 24031 E View    :      at java.lang.reflect.Method.invoke(Native Method)
01-01 12:44:12.243 24031 24031 E View    :      at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:548)
01-01 12:44:12.243 24031 24031 E View    :      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:942)
01-01 12:44:12.243 24031 24031 E View    : Caused by: android.os.RemoteException: Remote stack trace:
01-01 12:44:12.243 24031 24031 E View    :      at com.android.server.wm.Session.validateAndResolveDragMimeTypeExtras(Session.java:369)
01-01 12:44:12.243 24031 24031 E View    :      at com.android.server.wm.Session.performDrag(Session.java:324)
01-01 12:44:12.243 24031 24031 E View    :      at android.view.IWindowSession$Stub.onTransact(IWindowSession.java:876)
01-01 12:44:12.243 24031 24031 E View    :      at com.android.server.wm.Session.onTransact(Session.java:175)
01-01 12:44:12.243 24031 24031 E View    :      at android.os.Binder.execTransactInternal(Binder.java:1280)
01-01 12:44:12.243 24031 24031 E View    : 

使用Demo验证功能正常😀,然后集成到应用后就抛出异常无法使用😒,在百度、谷歌、Bing上来回找原因,并且反复核对代码,终于还是没有解决🤦‍♂️

不过还在定位到了原因,这个bug有人提出了issue issuetracker.google.com/issues/2456...

原因分析

根据上面的issue最终定位到了最终根源所在👇

java 复制代码
//services/core/java/com/android/server/wm/Session.java

@Override
public IBinder performDrag(IWindow window, int flags, SurfaceControl surface, int touchSource,
        float touchX, float touchY, float thumbCenterX, float thumbCenterY, ClipData data) {
    final int callingUid = Binder.getCallingUid();
    final int callingPid = Binder.getCallingPid();
    // Validate and resolve ClipDescription data before clearing the calling identity
    validateAndResolveDragMimeTypeExtras(data, callingUid, callingPid, mPackageName);
    validateDragFlags(flags, callingUid);
    final long ident = Binder.clearCallingIdentity();
    try {
        return mDragDropController.performDrag(mPid, mUid, window, flags, surface, touchSource,
                touchX, touchY, thumbCenterX, thumbCenterY, data);
    } finally {
        Binder.restoreCallingIdentity(ident);
    }
}

/**
 * Validates the given drag flags.
 */
@VisibleForTesting
void validateDragFlags(int flags, int callingUid) {
    if (callingUid == Process.SYSTEM_UID) {
        throw new IllegalStateException("Need to validate before calling identify is cleared");
    }

    if ((flags & View.DRAG_FLAG_REQUEST_SURFACE_FOR_RETURN_ANIMATION) != 0) {
        if (!mCanStartTasksFromRecents) {
            throw new SecurityException("Requires START_TASKS_FROM_RECENTS permission");
        }
    }
}

/**
 * Validates the given drag data.
 */
@VisibleForTesting
void validateAndResolveDragMimeTypeExtras(ClipData data, int callingUid, int callingPid,
        String callingPackage) {
    if (callingUid == Process.SYSTEM_UID) {
        throw new IllegalStateException("Need to validate before calling identify is cleared");
    }
    final ClipDescription desc = data != null ? data.getDescription() : null;
    if (desc == null) {
        return;
    }
    //省略其他...
}

我去无语了,系统进程应用这是直接不让用啊🤷‍♂️

java 复制代码
if (callingUid == Process.SYSTEM_UID) {
    throw new IllegalStateException("Need to validate before calling identify is cleared");
}

看下面有人反馈该问题已经修复了,随后我去看了一下Android14的源码,好家伙不拦截了🤢

Android14 Session

结尾

所以主要原因是我的应用是系统应用导致在当前版本上无法使用,初步来看是在Android13及以下都无法使用!

算了,不搞了,也不想打扰framework,我也不涉及多窗口之类的拖拽,还是使用RecyclerView吧🧨

相关推荐
再__努力1点1 分钟前
【68】颜色直方图详解与Python实现
开发语言·图像处理·人工智能·python·算法·计算机视觉
mingchen_peng8 分钟前
第一章 初识智能体
算法
木易 士心8 分钟前
MVC、MVP 与 MVVM:Android 架构演进之路
android·架构·mvc
百锦再10 分钟前
国产数据库的平替亮点——关系型数据库架构适配
android·java·前端·数据库·sql·算法·数据库架构
走在路上的菜鸟14 分钟前
Android学Dart学习笔记第十三节 注解
android·笔记·学习·flutter
晨曦夜月36 分钟前
笔试强训day5
数据结构·算法
H_z___38 分钟前
Hz的计数问题总结
数据结构·算法
她说彩礼65万39 分钟前
C# 反射
java·算法·c#
练习时长一年40 分钟前
LeetCode热题100(搜索插入位置)
数据结构·算法·leetcode