我正在 android studio 4.0 中尝试一些 codelabs 代码,并在应用程序中使用了以下代码:
String uri = uritext.getText().toString();//uritext is an editText view
Uri webpage = Uri.parse(uri);
Intent intent = new Intent(Intent.ACTION_VIEW, webpage);
if(intent.resolveActivity(getApplicationContext().getPackageManager())!=null){
startActivity(intent);
}
else {
Log.d("implicitintent:","cant handle this implicit intent!");
Toast toast = Toast.makeText(MainActivity.this,"cant open website:" + uri,Toast.LENGTH_SHORT);
toast.show();
}
我在两个不同的 AVD 中尝试了上面的代码,当我尝试在按钮单击事件中执行上面的代码时,它们都显示了 toast 消息。这意味着 resolveActivity() 返回一个空值。我找不到任何可能的原因,因为我发现两个 AVD 上都安装了 google chrome。Logcat 显示以下行:
2020-07-14 17:39:05.829 392-392/? E/netmgr: Failed to open QEMU pipe 'qemud:network': Invalid argument
2020-07-14 17:39:08.229 395-395/? E/wifi_forwarder: RemoteConnection failed to initialize: RemoteConnection failed to open pipe
2020-07-14 17:39:28.490 1889-2010/system_process E/ClipboardService: Denying clipboard access to com.android.chrome, application is not in focus neither is a system service for user 0
2020-07-14 17:39:31.234 1889-3470/system_process W/system_server: JNI critical lock held for 18.962ms on Thread[120,tid=3470,Runnable,Thread*=0xadd6a010,peer=0x13dc0a38,"Binder:1889_13"]
从 Logcat 看来,可能是 android studio 内部出了问题。我在 google 上做了一些研究,但找不到任何合适的答案。任何人都请帮助我解决这个问题,因为我被困在这里。任何帮助都是非常可观的。提前致谢。