file_paths.xml:resディレクトリでのようなXMLのxmlファイル名を追加し内部のフォルダを作成します
<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<root-path
name="root"
path="." />
<files-path
name="files"
path="." />
<cache-path
name="cache"
path="/"/>
<external-path
name="external"
path="." />
<external-cache-path
name="external_cache"
path="." />
<external-files-path
name="external_file"
path="." />
</paths>
要素は、1つまたはサブ複数の要素を含んでいなければなりません。これらのサブ要素は、あなたがこれらの要素のいずれかである必要があり、共有ファイルへのディレクトリパスを指定するために使用されます。
<ファイルパス>:Context.getFilesDirと同等のプライベートディレクトリの下に内部ストレージアプリケーションのファイル/ディレクトリ、()取得したディレクトリパス。
<キャッシュパス>:内部ストレージアプリケーションのキャッシュ/プライベートディレクトリのディレクトリの下Context.getCacheDir(取得したディレクトリ・パス)に相当します。
<外部パス>:Environment.getExternalStorageDirectoryに相当する外部ストレージルート、()取得したディレクトリパス。
<外部-ファイルパス>:プライベートディレクトリの下に、外部ストレージアプリケーションファイル/ディレクトリ、ディレクトリ・パスは、取得したContext.getExternalFilesDir(ヌル)と同等です。
<外部キャッシュパス>:Context.getExternalCacheDir()と同等の外部ストレージキャッシュ/ディレクトリの下のプライベートディレクトリの応用;
アプリケーションに追加
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.fileprovider"
android:exported="false"
android:grantUriPermissions="true"
tools:replace="android:authorities">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths" />
</provider>
アンドロイドは取得して表示画像アルバム7.0+
方法
public static Uri getImageContentUri(Context context, String path) {
Cursor cursor = context.getContentResolver().query(MediaStore.Images.Media.EXTERNAL_CONTENT_URI,
new String[]{MediaStore.Images.Media._ID}, MediaStore.Images.Media.DATA + "=? ",
new String[]{path}, null);
if (cursor != null && cursor.moveToFirst()) {
int id = cursor.getInt(cursor.getColumnIndex(MediaStore.MediaColumns._ID));
Uri baseUri = Uri.parse("content://media/external/images/media");
return Uri.withAppendedPath(baseUri, "" + id);
} else {
// 如果图片不在手机的共享图片数据库,就先把它插入。
if (new File(path).exists()) {
ContentValues values = new ContentValues();
values.put(MediaStore.Images.Media.DATA, path);
return context.getContentResolver().insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, values);
} else {
return null;
}
}
}
var urll = UtilImags.getImageContentUri(this, picturePath)
// Glide使用uri加载图片
// Glide.with(this).load(urll).into(iv_logo)
val bitmap = BitmapFactory.decodeStream(contentResolver.openInputStream(urll))
iv_logo.setImageBitmap(bitmap)
APKインストール
/***
* 安装apk
*/
fun showInstallApp(fileSavePath: String) {
var intent = Intent(Intent.ACTION_VIEW)
var apkFile = File(fileSavePath)
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
var uri = FileProvider.getUriForFile(videoNewsFragment.context!!, videoNewsFragment.context!!.getPackageName() + ".fileprovider", apkFile)
intent.setDataAndType(uri, "application/vnd.android.package-archive")
} else {
intent.setDataAndType(Uri.fromFile(apkFile), "application/vnd.android.package-archive")
}
videoNewsFragment.startActivity(intent)
}