Native.js调用原生文件系统

PickFile(callback, acceptType) {
				var CODE_REQUEST = 1000;
				var main = plus.android.runtimeMainActivity();
				if (plus.os.name == 'Android' && typeof callback == 'function') {
					var Intent = plus.android.importClass('android.content.Intent');
					var intent = new Intent(Intent.ACTION_GET_CONTENT);
					intent.addCategory(Intent.CATEGORY_OPENABLE);
					if (acceptType) {
						intent.setType(acceptType);
					} else {
						intent.setType("*/*");
					}
					main.onActivityResult = function(requestCode, resultCode, data) {
						if (requestCode == CODE_REQUEST) {
							var uri = data.getData();
							plus.android.importClass(uri);
							var Build = plus.android.importClass('android.os.Build');
							var isKitKat = Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT;

							var DocumentsContract = plus.android.importClass('android.provider.DocumentsContract');
							// DocumentProvider
							if (isKitKat && DocumentsContract.isDocumentUri(main, uri)) {
								console.log("版本大于 4.4 ",uri.getAuthority());
								// ExternalStorageProvider
								if ("com.android.externalstorage.documents" == uri.getAuthority()) {
									var docId = DocumentsContract.getDocumentId(uri);
									var split = docId.split(":");
									var type = split[0];

									if ("primary" == type) {
										var Environment = plus.android.importClass('android.os.Environment');
										callback(Environment.getExternalStorageDirectory() + "/" + split[1]);
									} else {
										var System = plus.android.importClass('java.lang.System');
										var sdPath = System.getenv("SECONDARY_STORAGE");
										if (sdPath) {
											callback(sdPath + "/" + split[1]);
										}
									}
								}
								// DownloadsProvider
								else if ("com.android.providers.downloads.documents" == uri.getAuthority()) {
									var id = DocumentsContract.getDocumentId(uri);
									var ContentUris = plus.android.importClass('android.content.ContentUris');
									var contentUri = ContentUris.withAppendedId(
										// Uri.parse("content://downloads/public_downloads"), Long.valueOf(id));
										Uri.parse("content://downloads/public_downloads"), id);
									callback(getDataColumn(main, contentUri, null, null));
								}
								// MediaProvider
								else if ("com.android.providers.media.documents" == uri.getAuthority()) {
									console.log(uri)
									var docId = DocumentsContract.getDocumentId(uri);
									var split = docId.split(":");
									var type = split[0];
                                    console.log(type)
									var MediaStore = plus.android.importClass('android.provider.MediaStore');
									let contentUri = ""
									if ("image" == type) {
										contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
									} else if ("video" == type) {
										contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI;
									} else if ("audio" == type) {
										contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
									}else{
										contentUri = MediaStore.Files.getContentUri("external")
									}
									var selection = "_id=?";
									var selectionArgs = new Array();
									selectionArgs[0] = split[1];
									callback(getDataColumn(main, contentUri, selection, selectionArgs));
								}
							}
							// MediaStore (and general)
							else if ("content" == uri.getScheme()) {
								callback(getDataColumn(main, uri, null, null));
							}
							// File
							else if ("file" == uri.getScheme()) {
								callback(uri.getPath());
							}
						}
					}
					main.startActivityForResult(intent, CODE_REQUEST);
				}

				function getDataColumn(main, uri, selection, selectionArgs) {
					plus.android.importClass(main.getContentResolver());
					let cursor = main.getContentResolver().query(uri, ['_data'], selection, selectionArgs,
						null);
						console.log(cursor)
					plus.android.importClass(cursor);
					if (cursor != null && cursor.moveToFirst()) {
						var column_index = cursor.getColumnIndexOrThrow('_data');
						var result = cursor.getString(column_index)
						cursor.close();
						return result;
					}
					return null;
				}
			}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值