编辑:
system_process
当我单击固定的快捷方式时,我正在登录以下:
2019-10-26 20:00:16.086 2047-3533/system_process I/ActivityTaskManager: START u0 {act=android.intent.action.VIEW dat=file:///storage/emulated/0/Download/AAD.pdf typ=application/pdf flg=0x10000000 cmp=com.google.android.apps.docs/com.google.android.apps.viewer.PdfViewerActivity bnds=[439,84][641,337]} from uid 10147
2019-10-26 20:00:16.100 2047-2047/system_process W/ActivityManager: Unable to start service Intent { act=android.service.appprediction.AppPredictionService cmp=com.google.android.as/com.google.android.apps.miphone.aiai.app.AiAiPredictionService } U=0: not found
2019-10-26 20:00:16.100 2047-2047/system_process W/RemoteAppPredictionService: could not bind to Intent { act=android.service.appprediction.AppPredictionService cmp=com.google.android.as/com.google.android.apps.miphone.aiai.app.AiAiPredictionService } using flags 67108865
简而言之,固定快捷方式不会在 Android 10 中打开,但可以在旧版本中使用。在 Android 10 中,当我单击快捷方式时,Drive PDF Viewer 会打开,但实际文件显示为黑色空间,并在一秒钟内关闭应用程序。
老的:
我的 Android 应用程序以 API 级别 28 为目标。它将 PDF 文件的快捷方式固定到主屏幕,然后单击图标会明显打开文件。直到 Android Pie,它工作得非常好。但是当我在 API 29 上对其进行测试时,单击该图标会打开 PDF 查看器并强制关闭且没有错误。这是相关的代码。
private fun addShortcutInOreo(path1: String, pdfName: String) {
val file = File(path1)
try {
Log.d("Data", file.path)
val pdfIntent = Intent(Intent.ACTION_VIEW)
val uri = Uri.fromFile(file)
pdfIntent.setDataAndType(uri, "application/pdf")
pdfIntent.flags = Intent.FLAG_GRANT_READ_URI_PERMISSION
pdfIntent.flags = Intent.FLAG_GRANT_WRITE_URI_PERMISSION
Log.d("DataPath", uri.path)
Log.d("DataPath", pdfName)
if (Build.VERSION.SDK_INT > 25) {
val shortcutManager = getSystemService(ShortcutManager::class.java)
// Check which icon is to be pinned
image = if (blueIcon.isChecked)
R.drawable.pdf
else
R.drawable.pdf2
// Create a shortcut
val shortcut = ShortcutInfo.Builder(this, pdfName)
.setShortLabel(pdfName)
.setLongLabel(pdfName)
.setIcon(Icon.createWithResource(this, image))
.setIntent(pdfIntent)
.build()
shortcutManager.requestPinShortcut(shortcut, null)
}
} catch (e: Exception) {
errorMessage(e)
}
}
记录的数据在这里。第一行显示文件路径。第二行显示 Uri。第三行简单地给出了提取的文件名。我这样做只是为了检查我的代码是否一切正常。
2019-08-02 13:43:14.160 3306-3306/com.parassidhu.pdfpin D/Data: /storage/emulated/0/Download/Nakal.pdf
2019-08-02 13:43:14.160 3306-3306/com.parassidhu.pdfpin D/DataPath: file:///storage/emulated/0/Download/Nakal.pdf
2019-08-02 13:43:14.160 3306-3306/com.parassidhu.pdfpin D/DataPath: Nakal
API 28 的日志相同:
2019-08-02 13:55:07.853 5341-5341/com.parassidhu.pdfpin D/Data: /storage/emulated/0/Download/Nakal.pdf
2019-08-02 13:55:07.853 5341-5341/com.parassidhu.pdfpin D/DataPath: file:///storage/emulated/0/Download/Nakal.pdf
2019-08-02 13:55:07.853 5341-5341/com.parassidhu.pdfpin D/DataPath: Nakal
由于没有错误,我正在挠头,因为可能出了什么问题。我已经阅读了有关 Android Q 中的 Scoped Storage 的信息,但这不适用于这里,因为我不是针对 Q 的。我已经阅读了有关 Android Q 中其他行为更改的信息,但就我所阅读的而言,没有一个适用。
可能是什么问题?谢谢阅读!