在网络视图中从相机上传图像不起作用

2023-12-02

我一直在尝试从 facebook 通过 webview 从画廊和相机上传 Workplace 中的图像。

从图库中它工作正常,但从相机中图像不会出现在上传中。

我看过类似的帖子有这个问题this and this但我不明白有什么问题。

这是我的课:

public class WorkplaceActivity extends BaseActivity implements WorkplaceContract.View {

private WorkplacePresenter workplacePresenter;
private Tracker trackerGA;
private MyApplicaton appGA;
private Toolbar toolbar;
private WebView ctWebView;
private ValueCallback<Uri[]> mUploadMessage;
private final static int FILECHOOSER_RESULTCODE = 1;
private Uri mCameraURI;

@Override
public void setupWorkplace() {
    WebViewClient webclient = new WebViewClient();

    ctWebView = (WebView) findViewById(R.id.ctWebView);
    ctWebView.getSettings().setAppCacheEnabled(true);
    ctWebView.getSettings().setJavaScriptEnabled(true);
    ctWebView.getSettings().setLoadWithOverviewMode(true);
    ctWebView.getSettings().setAllowFileAccess(true);
    ctWebView.setWebViewClient(webclient);
    ctWebView.loadUrl(ConstantsStrings.WORKPLACE_URL);
}

@Override
public void setupGA() {
    // Google Analytics
    appGA = (MyApplicaton) getApplication();
    trackerGA = appGA.getDefaultTracker();
    sendGA(ConstantsStrings.WORKPLACE_GA_IN);
}

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_workplace);
    toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    workplacePresenter = new WorkplacePresenter();
    workplacePresenter.attachView(this);
    workplacePresenter.checkPermissions(WorkplaceActivity.this);

    ActionBar actionBar = this.getSupportActionBar();
    if (actionBar != null) {
        actionBar.setDisplayHomeAsUpEnabled(false);
        actionBar.setDisplayShowHomeEnabled(false);
        actionBar.setHomeAsUpIndicator(R.drawable.ic_arrow_left);
        actionBar.setTitle("");

        // add back button
        ImageButton back_button = (ImageButton) findViewById(R.id.back_button);
        back_button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                if (ctWebView.canGoBack()) {
                    ctWebView.goBack();
                }

                Log.d("WORKPLACE", "click back");
            }
        });

        // add close button
        ImageButton close_button = (ImageButton) findViewById(R.id.close_button);
        close_button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                finish();

                Log.d("WORKPLACE", "click close");
            }
        });

    }

    setupGA();
    setupWorkplace();
    ctWebView.setWebChromeClient(new WebChromeClient() {
        @Override
        public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) {
            WorkplaceActivity.this.openFileChooser(filePathCallback);
            return true;
        }
    });
}

@Override
public void onBackPressed() {
    super.onBackPressed();
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent intent) {
    if (requestCode == FILECHOOSER_RESULTCODE) {
        if (mUploadMessage != null) {
            Uri[] temp = new Uri[1];
            if (intent != null && intent.getData() != null) {
                temp[0] = intent.getData();
            } else if (mCameraURI != null) {
                temp[0] = mCameraURI;
            }
            mUploadMessage.onReceiveValue(temp);
            mUploadMessage = null;
        }
    }
}

public static Intent newInstance(Context context) {
    return new Intent(context, WorkplaceActivity.class);
}

@Override
public void onAttachedToWindow() {
    super.onAttachedToWindow();
    workplacePresenter.attachView(this);
}

@Override
public void onDetachedFromWindow() {
    super.onDetachedFromWindow();
    workplacePresenter.detachView();
}

@Override
public void showLoading() {
}

@Override
public void hideLoading() {
}

@Override
public void sendGA(String msg) {
    // Google Analytics
    trackerGA = appGA.getDefaultTracker();
    trackerGA.setScreenName(msg);
    trackerGA.send(new HitBuilders.ScreenViewBuilder().build());
}

private void openFileChooser(ValueCallback<Uri[]> uploadMsg) {
    mUploadMessage = uploadMsg;

    try {
        Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
        ActivityCompat.requestPermissions(WorkplaceActivity.this, new String[]{Manifest.permission.CAMERA}, FILECHOOSER_RESULTCODE);
        ActivityCompat.requestPermissions(WorkplaceActivity.this, new String[]{Manifest.permission_group.STORAGE}, 6);
        ActivityCompat.requestPermissions(WorkplaceActivity.this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 5);
        File storageDir = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES);
        File cameraDir = new File(storageDir.getAbsolutePath() + File.separator + "browser-photos");
        cameraDir.mkdirs();
        String mCameraFilePath = cameraDir.getAbsolutePath() + File.separator + ".jpg";
        mCameraURI = Uri.fromFile(new File(mCameraFilePath));
        takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, mCameraURI);


        Intent contentSelectionIntent = new Intent(Intent.ACTION_GET_CONTENT);
        contentSelectionIntent.addCategory(Intent.CATEGORY_OPENABLE);
        contentSelectionIntent.setType("image/*");

        Intent chooserIntent = new Intent(Intent.ACTION_CHOOSER);
        chooserIntent.putExtra(Intent.EXTRA_INTENT, contentSelectionIntent);
        chooserIntent.putExtra(Intent.EXTRA_TITLE, "Image Chooser");
        chooserIntent.putExtra(Intent.EXTRA_INITIAL_INTENTS, new Parcelable[]{takePictureIntent});

        startActivityForResult(chooserIntent, FILECHOOSER_RESULTCODE);
    } catch (Exception e) {
        Toast.makeText(getBaseContext(), "Camera Exception:" + e, Toast.LENGTH_LONG);
    }
}

当我尝试从相机上传图像时,我的手机会保存图像,但它不会出现在上传屏幕上。


检查一下它对我有用。

public class MainActivity extends Activity {

    private WebView webView;
    private ValueCallback<Uri> mUploadMessage;
    private ValueCallback<Uri[]> mUploadMessages;
    private Uri mCapturedImageURI = null;
    private static final int MY_CAMERA_REQUEST_CODE = 100;
    private static final int FILECHOOSER_RESULTCODE = 1;

    @RequiresApi(api = Build.VERSION_CODES.M)
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        webView = findViewById(R.id.webView);

        webView.setWebViewClient(new WebViewClient());

        WebSettings webSettings = webView.getSettings();
        webSettings.setJavaScriptEnabled(true);
        webSettings.setDomStorageEnabled(true);
        webView.getSettings().setJavaScriptEnabled(true);
        webView.getSettings().setDomStorageEnabled(true);
        webView.getSettings().setPluginState(WebSettings.PluginState.ON);
        webView.getSettings().setAppCacheEnabled(false);
        webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);
        webView.getSettings().setUseWideViewPort(true);
        webView.getSettings().setLoadWithOverviewMode(true);
        webView.getSettings().setBuiltInZoomControls(false);
        webView.getSettings().setSupportZoom(false);
        webView.getSettings().setDefaultZoom(WebSettings.ZoomDensity.FAR);
        webView.getSettings().setDomStorageEnabled(true);
        webView.getSettings().setDatabaseEnabled(true);
        webView.getSettings().setDatabasePath("/data/data/" + webView.getContext().getPackageName() + "/databases/");

        webView.loadUrl("url");

        webView.setWebChromeClient(new WebChromeClient() {

            // For api level bellow 24
            public boolean shouldOverrideUrlLoading(WebView view, String url) {

                if (url.startsWith("http")) {
                    // Return false means, web view will handle the link
                    return false;
                }

                return false;
            }


            // From api level 24
            @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
            public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
                /*Toast.makeText(mcontext, "New Method",Toast.LENGTH_SHORT).show();*/

                // Get the tel: url
                String url = request.getUrl().toString();

                if (url.startsWith("http")) {
                    // Return false means, web view will handle the link
                    return false;
                }

                return false;
            }

            // openFileChooser for Android 3.0+

            public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType) {
                mUploadMessage = uploadMsg;
                openImageChooser();
            }

            // For Lollipop 5.0+ Devices

            public boolean onShowFileChooser(WebView mWebView, ValueCallback<Uri[]> filePathCallback, WebChromeClient.FileChooserParams fileChooserParams) {
                mUploadMessages = filePathCallback;
                openImageChooser();
                return true;
            }

            // openFileChooser for Android < 3.0

            public void openFileChooser(ValueCallback<Uri> uploadMsg) {
                openFileChooser(uploadMsg, "");
            }

            //openFileChooser for other Android versions

            public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture) {
                openFileChooser(uploadMsg, acceptType);
            }
        });

    }

    private void openImageChooser() {
        try {

            File imageStorageDir = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES), "FolderName");

            if (!imageStorageDir.exists()) {
                imageStorageDir.mkdirs();
            }
            File file = new File(imageStorageDir + File.separator + "IMG_" + String.valueOf(System.currentTimeMillis()) + ".jpg");
            mCapturedImageURI = Uri.fromFile(file);

            final Intent captureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
            captureIntent.putExtra(MediaStore.EXTRA_OUTPUT, mCapturedImageURI);

            Intent i = new Intent(Intent.ACTION_GET_CONTENT);
            i.addCategory(Intent.CATEGORY_OPENABLE);
            i.setType("image/*");

            Intent chooserIntent = Intent.createChooser(i, "Image Chooser");
            chooserIntent.putExtra(Intent.EXTRA_INITIAL_INTENTS, new Parcelable[]{captureIntent});

            startActivityForResult(chooserIntent, FILECHOOSER_RESULTCODE);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent intent) {
        super.onActivityResult(requestCode, resultCode, intent);

        if (requestCode == FILECHOOSER_RESULTCODE) {

            if (null == this.mUploadMessage && null == this.mUploadMessages) {
                return;
            }

           /* Uri result;
            if (requestCode != RESULT_OK){
                result = null;
            }else {
                result = intent == null ? this.mCapturedImageURI : intent.getData();
            }
            this.mUploadMessage.onReceiveValue(result);
            this.mUploadMessage = null;*/
            if (null != mUploadMessage) {
                handleUploadMessage(requestCode, resultCode, intent);

            } else if (mUploadMessages != null) {
                handleUploadMessages(requestCode, resultCode, intent);
            }
        }
    }

    private void handleUploadMessage(int requestCode, int resultCode, Intent intent) {
        Uri result = null;
        try {
            if (resultCode != RESULT_OK) {
                result = null;
            } else {
                // retrieve from the private variable if the intent is null

                result = intent == null ? mCapturedImageURI : intent.getData();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        mUploadMessage.onReceiveValue(result);
        mUploadMessage = null;
    }

    @TargetApi(Build.VERSION_CODES.LOLLIPOP)
    private void handleUploadMessages(int requestCode, int resultCode, Intent intent) {
        Uri[] results = null;
        try {
            if (resultCode != RESULT_OK) {
                results = null;
            } else {
                if (intent != null) {
                    String dataString = intent.getDataString();
                    ClipData clipData = intent.getClipData();
                    if (clipData != null) {
                        results = new Uri[clipData.getItemCount()];
                        for (int i = 0; i < clipData.getItemCount(); i++) {
                            ClipData.Item item = clipData.getItemAt(i);
                            results[i] = item.getUri();
                        }
                    }
                    if (dataString != null) {
                        results = new Uri[]{Uri.parse(dataString)};
                    }
                } else {
                    results = new Uri[]{mCapturedImageURI};
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        mUploadMessages.onReceiveValue(results);
        mUploadMessages = null;
    }

}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在网络视图中从相机上传图像不起作用 的相关文章

随机推荐

  • 在 SSMS 中自动换行 IsNull([text], 0) 中选定文本的键盘快捷键

    是否有某种方法可以在 SQL Server Management Studio SSMS 中提供快捷方式 以便在选择文本时将该文本包装在 IsNull 语句中 例如 我突出显示以下文本 My column name 当我单击键盘快捷键时 突
  • C++ 除以 0

    我正在运行长时间模拟 我将结果记录到向量中以计算有关数据的统计信息 我意识到 从理论上讲 这些样本可能是除以零的结果 这只是理论上的 我很确定事实并非如此 为了避免修改代码后重新运行模拟 我想知道这种情况下会发生什么 我能知道是否发生了除以
  • 这两种使用express中间件的方法有区别吗?

    我遇到过两种不同的方式来定义 express use 中间件 我想知道它们之间是否有任何区别 或者它是否只是语法糖 A const app express app use cors app use responseTime app use
  • 如何使用 jQuery 添加基于 URL 的“选定”类?

    我的 wikispace 主题中有一个侧边栏链接列表 当前使用 jQuery 根据 com 之后的 URL 将类应用到每个侧边栏链接 您可以在下面的代码中看到这一点的应用 div class WikiCustomNav WikiElemen
  • 使用 Python 从私钥输入中提取公钥

    我需要从私钥生成公钥 而不需要像我们在 sshgen 中那样在本地临时位置 所以我使用这个 这里我将我的私钥作为输入传递 如下所示 在执行时 python codekey py BEGIN RSA PRIVATE KEY nMIhhhhhh
  • Web 作业上的 Windows Azure 管理库认证错误

    我构建了一个 Azure Web 作业控制台 它引用了 Windows Azure 管理库 我尝试使用公共设置方法来验证我的应用程序 该程序在我的本地运行良好 但在 Azure Web 作业上失败并出现 X509Certificates 错
  • MySQL 错误 1005?

    我正在尝试创建一个数据库 但收到一个奇怪的错误 这是我的代码 DROP TABLE IF EXISTS Person DROP TABLE IF EXISTS Address DROP TABLE IF EXISTS Email DROP
  • 如何从 CUDA C 调用 ptx 函数?

    我正在尝试找到一种从 CUDA C 调用 ptx 函数 func 的方法 假设我有一个像这样的 ptx 函数 func reg s32 res inc ptr reg s32 ptr reg s32 inc add s32 res ptr
  • 为什么名称函数表达式在函数体外部不可用[重复]

    这个问题在这里已经有答案了 命名函数表达式定义为 var ninja function myNinja 有一种我无法理解的行为 看看下面的代码 var ninja function myNinja console log typeof my
  • 如何按键对 JSON 进行分组并按其计数排序?

    我从类似于此的 jsonlines 文件开始 kw foo age 1 kw foo age 1 kw foo age 1 kw bar age 1 kw bar age 1 请注意 每一行都是有效的 json 但整个文件不是 我正在寻找的
  • 我无法在我的 github 博客上更改 jekyll 语法荧光笔

    我创建了我的 github 博客 我想将语法荧光笔更改为 rouge 我做这个 gem install rouge rougify style monokai sublime gt assets css syntax css default
  • 处理 Android 中最近的应用程序点击和主页按下

    我正在为孩子们制作一个应用程序 一旦你进入该应用程序 如果没有我在菜单中要求的密码 你就无法退出 现在我希望如果在应用程序内按下应用程序中的主页按钮 它应该保持相同的活动 我搜索了很多 但到处的解决方案都是在清单中添加过滤器 但这些对我来说
  • 如果线程 B 希望看到线程 A 所做的更改,是否只能对 volatile 变量进行最后的更改,而不是对所有变量进行更改?

    我看过这个答案 并说明了如何 在新的内存模型下 当线程A写入易失性 变量 V 线程 B 从 V 读取任何变量值 现在保证在写入 V 时对 A 可见 对 B 可见 因此 给出示例 public class Main static int va
  • 如何将 Swing 应用程序转换为 Applet?

    我使用 Swing 应用程序框架创建了一个桌面应用程序 现在如何将其转换为小程序 主类扩展了 SingleFrame Application 编辑 这是起始类 使用 NetBeans GUI 构建器 public class PhotoAp
  • 如何在不更改url的情况下将所有页面请求重定向到一个页面

    我想将我网站上的所有页面 包括索引 重定向到UnderWork html我正在使用 htaccess用这个代码 RewriteEngine on RewriteRule UnderWork html 而且效果很好 现在我正在向我的 htac
  • Spring Security 更改 spring_security_login 表单

    我正在使用 spring security 我想知道如何更改默认登录表单 我发现我需要指向我的新表单位置 我想保留具有所有登录异常显示的现有默认表单的现有功能 所以我必须首先知道如何重现它 在我的研究中我遇到了它 http www code
  • 在 R 中:获取第一个标点符号之前的所有数字字符

    我有一个向量s字符串 或 NA 并且希望在第一次出现标点符号之前获得一个长度相同的向量 s lt c ABC1 2 22A 2 NA 我想要这样的结果 1 ABC1 22A NA 您可以使用以下类似 Perl 的正则表达式从第一个点删除所有
  • Webview保存页面状态

    我正在使用的网络视图有一个小问题 我正在尝试使用网络视图来允许用户填写注册表 当用户在一个会话中完成表单时 这种方法效果很好 但如果用户锁定手机 则 webview 活动将被破坏 我的记忆中有两项活动 其中一项是内存密集型的 我认为我遇到的
  • 从字符串 "" 到 long 的转换无效

    即使经过大约一个小时的研究 我也遇到了无法解决的错误 从字符串 Waseem PC Waseem 到 long 的转换无效 这个错误真的很烦人 我尝试了一切 我非常感谢您的帮助 我很想对你的答案竖起大拇指 但我必须有更大的代表 这是我的代码
  • 在网络视图中从相机上传图像不起作用

    我一直在尝试从 facebook 通过 webview 从画廊和相机上传 Workplace 中的图像 从图库中它工作正常 但从相机中图像不会出现在上传中 我看过类似的帖子有这个问题this and this但我不明白有什么问题 这是我的课