The below code is used
mWebView = (WebView) findViewById(R.id.webview);
mWebView.getSettings().setAllowFileAccess(true);
mWebView.getSettings().setJavaScriptEnabled(true);
String base = Environment.getExternalStorageDirectory().getAbsolutePath().toString();
String imagePath = base + "/test.jpg";
mWebView.loadUrl(imagePath);
the image is not loading ...
also tried
mWebView = (WebView) findViewById(R.id.webview);
mWebView.getSettings().setAllowFileAccess(true);
mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.getSettings().setBuiltInZoomControls(true);
String base = Environment.getExternalStorageDirectory().getAbsolutePath().toString();
String imagePath = base + "/test.jpg";
String html = "<html><head></head><body><img src=\""+ imagePath + "\"></body></html>";
mWebView.loadData(html, "text/html","utf-8");
Please help
This did the trick as we have to append the"prefix "file://" before any file so as to display in the webview
I tried the methods mentioned before with no success, so this are the options that worked for me to load an image from the external storage:
Load the image directly into the WebView.
Supossing that i have an image called
image.jpg
inside the root of the external storage directory (in my case/storage/emulated/0/image.jpg
) .Loading the image using a html template to load into theWebView.
WebViews can display HTML not images. You either need to use an ImageView or generate some HTML with an image tag that displays your picture. If it needs to be dynamic you can generate it as a String and use the loadData() method to display it.
Edit: You're going to want something like this in your html String.