不推荐使用的android方法替换getPath()

不推荐使用的android方法替换getPath(),android,deprecated,Android,Deprecated,我有这个getPath方法,它可以工作,但是我想去掉这个警告,因为它说managedQuery方法不推荐使用。如何在没有警告的情况下实现这个确切的getPath方法?多谢各位 public String getPath(Uri uri) { System.out.println("IM IN getPath"); String[] projection = { MediaStore.Images.Media.DATA }; Cursor curso

我有这个
getPath
方法,它可以工作,但是我想去掉这个警告,因为它说
managedQuery
方法不推荐使用。如何在没有警告的情况下实现这个确切的
getPath
方法?多谢各位

public String getPath(Uri uri) {
        System.out.println("IM IN getPath");
        String[] projection = { MediaStore.Images.Media.DATA };
        Cursor cursor = managedQuery(uri, projection, null, null, null);
        int column_index = cursor
                .getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
        cursor.moveToFirst();
        return cursor.getString(column_index);
    }
编辑:我现在收到这个logcat错误:

10-23 07:19:14.080: E/ActivityThread(594): Activity com.android.internal.app.ChooserActivity has leaked IntentReceiver com.android.internal.app.ResolverActivity$1@416c9560 that was originally registered here. Are you missing a call to unregisterReceiver()?
10-23 07:19:14.080: E/ActivityThread(594): android.app.IntentReceiverLeaked: Activity com.android.internal.app.ChooserActivity has leaked IntentReceiver com.android.internal.app.ResolverActivity$1@416c9560 that was originally registered here. Are you missing a call to unregisterReceiver()?
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.LoadedApk$ReceiverDispatcher.<init>(LoadedApk.java:763)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.LoadedApk.getReceiverDispatcher(LoadedApk.java:567)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.ContextImpl.registerReceiverInternal(ContextImpl.java:1043)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.ContextImpl.registerReceiver(ContextImpl.java:1030)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.ContextImpl.registerReceiver(ContextImpl.java:1024)
10-23 07:19:14.080: E/ActivityThread(594):  at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:341)
10-23 07:19:14.080: E/ActivityThread(594):  at com.android.internal.content.PackageMonitor.register(PackageMonitor.java:65)
10-23 07:19:14.080: E/ActivityThread(594):  at com.android.internal.app.ResolverActivity.onCreate(ResolverActivity.java:99)
10-23 07:19:14.080: E/ActivityThread(594):  at com.android.internal.app.ChooserActivity.onCreate(ChooserActivity.java:53)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.Activity.performCreate(Activity.java:4465)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.ActivityThread.access$600(ActivityThread.java:123)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
10-23 07:19:14.080: E/ActivityThread(594):  at android.os.Handler.dispatchMessage(Handler.java:99)
10-23 07:19:14.080: E/ActivityThread(594):  at android.os.Looper.loop(Looper.java:137)
10-23 07:19:14.080: E/ActivityThread(594):  at android.app.ActivityThread.main(ActivityThread.java:4424)
10-23 07:19:14.080: E/ActivityThread(594):  at java.lang.reflect.Method.invokeNative(Native Method)
10-23 07:19:14.080: E/ActivityThread(594):  at java.lang.reflect.Method.invoke(Method.java:511)
10-23 07:19:14.080: E/ActivityThread(594):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
10-23 07:19:14.080: E/ActivityThread(594):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
10-23 07:19:14.080: E/ActivityThread(594):  at dalvik.system.NativeStart.main(Native Method)
10-23 07:19:14.080:E/ActivityThread(594):Activity com.android.internal.app.choose活动已泄漏IntentReceiver com.android.internal.app.ResolveActivity$1@416c9560原来是在这里注册的。是否缺少对unregisterReceiver()的调用?
10-23 07:19:14.080:E/ActivityThread(594):android.app.IntentReceiver泄漏:Activity com.android.internal.app.choose活动已泄漏IntentReceiver com.android.internal.app.ResolverActivity$1@416c9560原来是在这里注册的。是否缺少对unregisterReceiver()的调用?
10-23 07:19:14.080:E/ActivityThread(594):在android.app.LoadedApk$ReceiverDispatcher(LoadedApk.java:763)
10-23 07:19:14.080:E/ActivityThread(594):位于android.app.LoadedApk.getReceiveDispatcher(LoadedApk.java:567)
10-23 07:19:14.080:E/ActivityThread(594):位于android.app.ContextImpl.registerReceiverInternal(ContextImpl.java:1043)
10-23 07:19:14.080:E/ActivityThread(594):位于android.app.ContextImpl.registerReceiver(ContextImpl.java:1030)
10-23 07:19:14.080:E/ActivityThread(594):位于android.app.ContextImpl.registerReceiver(ContextImpl.java:1024)
10-23 07:19:14.080:E/ActivityThread(594):位于android.content.ContextWrapper.registerReceiver(ContextWrapper.java:341)
10-23 07:19:14.080:E/ActivityThread(594):位于com.android.internal.content.PackageMonitor.register(PackageMonitor.java:65)
10-23 07:19:14.080:E/ActivityThread(594):位于com.android.internal.app.resolverectivity.onCreate(resolverectivity.java:99)
10-23 07:19:14.080:E/ActivityThread(594):位于com.android.internal.app.ChooserActivity.onCreate(ChooserActivity.java:53)
10-23 07:19:14.080:E/ActivityThread(594):在android.app.Activity.performCreate(Activity.java:4465)上
10-23 07:19:14.080:E/ActivityThread(594):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
10-23 07:19:14.080:E/ActivityThread(594):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
10-23 07:19:14.080:E/ActivityThread(594):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
10-23 07:19:14.080:E/ActivityThread(594):位于android.app.ActivityThread.access$600(ActivityThread.java:123)
10-23 07:19:14.080:E/ActivityThread(594):位于android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
10-23 07:19:14.080:E/ActivityThread(594):位于android.os.Handler.dispatchMessage(Handler.java:99)
10-23 07:19:14.080:E/ActivityThread(594):位于android.os.Looper.loop(Looper.java:137)
10-23 07:19:14.080:E/ActivityThread(594):位于android.app.ActivityThread.main(ActivityThread.java:4424)
10-23 07:19:14.080:E/ActivityThread(594):位于java.lang.reflect.Method.Invokenactive(本机方法)
10-23 07:19:14.080:E/ActivityThread(594):位于java.lang.reflect.Method.invoke(Method.java:511)
10-23 07:19:14.080:E/ActivityThread(594):位于com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
10-23 07:19:14.080:E/ActivityThread(594):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
10-23 07:19:14.080:E/ActivityThread(594):在dalvik.system.NativeStart.main(本机方法)

您可以将其替换为
getContentResolver.query()

所以看起来是这样的

public String getPath(Uri uri) {
        System.out.println("IM IN getPath");
        String[] projection = { MediaStore.Images.Media.DATA };
        Cursor cursor = getContentResolver().query(uri, projection, null, null, null);
        int column_index = cursor
                .getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
        cursor.moveToFirst();
        return cursor.getString(column_index);
    }
试试这个,它很管用

fun getPath(context:context?,uri:uri?):字符串?{
打印(uri)
if(uri==null)
返回空
val projection=arrayOf(MediaStore.Video.Media.DATA)
val cursor:cursor?=context?.contentResolver?.query(uri、投影、null、null、null)
val path=if(光标!=null){
val columnIndex:Int=cursor.getColumnIndexOrThrow(MediaStore.Video.Media.DATA)
cursor.moveToFirst()
cursor.getString(columnIndex)
}否则无效
光标?.close()
返回路径
}
新问题“'DATA:String'已弃用。在Java Q中弃用”

MediaStore.Video.Media.DATA

使用文档中的游标加载工具感谢您的帮助,但我现在收到一个logcat错误(请参见编辑)。这并没有影响我的计划,但我仍然认为它应该得到重视。也许吧。我认为这个错误与上面的代码无关。查看此链接或