阅读量:0
在 Android 中,处理 FileChooser 的回调需要使用 WebChromeClient 类
- 首先,确保你的 Activity 继承自 AppCompatActivity,并实现 WebChromeClient.FileChooserParams 接口。
import androidx.appcompat.app.AppCompatActivity; import android.webkit.WebChromeClient; import android.webkit.WebView; public class MainActivity extends AppCompatActivity { // ... }
- 在你的布局文件中添加一个 WebView。
android:id="@+id/webview" android:layout_width="match_parent" android:layout_height="match_parent" />
- 初始化 WebView 并设置 WebChromeClient。
import android.webkit.WebView; import android.webkit.WebSettings; import android.webkit.ValueCallback; private WebView webView; private ValueCallback<Uri[]> filePathCallback; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); webView = findViewById(R.id.webview); WebSettings webSettings = webView.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setLoadsImagesAutomatically(true); webView.setWebChromeClient(new WebChromeClient() { @Override public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { // 保存 filePathCallback 以便稍后使用 MainActivity.this.filePathCallback = filePathCallback; // 创建一个 Intent 用于选择文件 Intent intent = new Intent(Intent.ACTION_GET_CONTENT); intent.addCategory(Intent.CATEGORY_OPENABLE); intent.setType("*/*"); intent.putExtra(Intent.EXTRA_ALLOW_MULTIPLE, true); // 启动文件选择器 startActivityForResult(Intent.createChooser(intent, "选择文件"), FILECHOOSER_RESULTCODE); return true; } }); }
- 重写 onActivityResult 方法以处理文件选择结果。
import android.content.Intent; import android.net.Uri; private static final int FILECHOOSER_RESULTCODE = 1; @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == FILECHOOSER_RESULTCODE && resultCode == RESULT_OK && data != null) { Uri[] results = null; if (data.getData() != null) { // 单个文件选择 results = new Uri[]{data.getData()}; } else if (data.getClipData() != null) { // 多个文件选择 ClipData clipData = data.getClipData(); results = new Uri[clipData.getItemCount()]; for (int i = 0; i< clipData.getItemCount(); i++) { results[i] = clipData.getItemAt(i).getUri(); } } // 将结果传递给 filePathCallback if (filePathCallback != null) { filePathCallback.onReceiveValue(results); filePathCallback = null; } } }
现在,当你的 WebView 中的 JavaScript 代码调用 input
标签的 click()
方法时,应用程序将显示文件选择器。选定的文件将通过回调传递给 WebView。