在安卓浏览器中将图像渲染为数据流

11

我制作了一个小型的测试 Web 应用程序,使用 Nihilogic 的canvas2image JavaScript 库将 HTML 画布转换为图像,然后用生成的图像替换画布,并显示消息提示用户触摸(长按)该图像以将其保存到手机上。

我遇到的问题是,安卓默认的网页浏览器(“Internet”)不会呈现代表图像的 base64 编码数据流,而是显示一个问号标记。有解决方法吗?如果有,应该怎么做?


你正在运行哪个Android版本?它可以在Jelly Bean(4.1.1)中工作。我可以从画布生成图像并且可以轻松保存它。 - alex
你可以尝试一下使用CSS样式background-image: url(data:image/png;base64datahere....);创建一个div,而不是创建一个带有src属性的img标签吗? - Prasanth
2个回答

4

使用自定义的ContentProvider并重写openFile()方法以返回流作为临时文件。

你可以在HTML A标签中使用URI作为资源地址。

<a src="Example://file"></a>

public class ExampleProvider extends ContentProvider {

    @Override
    public ParcelFileDescriptor openFile(Uri uri, String mode) throws FileNotFoundException {         
        //Get your bitmap
        Bitmap bmp = BitmapFactory.decodeResource(getContext().getResources(), R.drawable.file_example);
        File tempFile = null;
        try {
            //Create the tempfile form a stream
            tempFile = File.createTempFile("tempfile", ".thumb", getContext().getCacheDir());
            BufferedOutputStream out = new BufferedOutputStream(new FileOutputStream(tempFile));
            bmp.compress(Bitmap.CompressFormat.JPEG, 100, out);
            out.close();
            if(mode.equals("r")) {
              return ParcelFileDescriptor.open(tempFile, ParcelFileDescriptor.MODE_READ_ONLY);
            }
        }
        catch(IOException e)  {
            LOGGER.error("Couldn't generate temp file for thumb view, guid:" + guid, e);
        }
        finally {
            if(tempFile != null {
                //The unix filesystem automatically deletes the file once all handles are gone
                tempFile.delete();
            }
        }
    }
}

非常好的解决方案。这种解决方案总是为项目团队提供了完全可控的开发模式,允许您对异常进行处理并保持默认方式,当不需要处理异常时。但是我认为,只有在向后兼容性也是您关注的重点时,这似乎是一个不错的方法。 - Miere
@Ty S. 这到底是什么语言?我看不出来。 - Andrei Oniga
Android平台上的Java。 - Ty Smith
据我理解,这个解决方案仅适用于已应用软件修改的智能手机,是这样吗? - Andrei Oniga
这是针对设备上的本地Android应用程序特定的。 - Ty Smith
很抱歉,这是不可行的。如果有办法实现我所寻找的功能,它必须适用于所有设备。毕竟,这个Web应用程序并不是打算只在某一个移动设备上使用。 - Andrei Oniga

1

基于@goldenparrot的评论,可以看到图像。

<img src="_STRING_HERE" />

当页面加载时,如果已经存在base64数据,则可以使用建议的css背景图像。然而,当完全相同的数据字符串动态输入时,由于某种原因它不起作用。即使是静态加载的带有base64数据的图像也存在问题:它无法对长按做出任何反应,因此无法下载。我正在使用Android 2.3.6。

编辑:您还可以尝试添加其他下载链接。

<a href="data:application/octet-stream;base64,BASE64_STRING_HERE">download file</a>

但对我没有用。Android只是将该文件的内容显示为文本。普通桌面Web浏览器打开了“下载文件”对话框,但没有为该文件建议任何扩展名,因此用户必须手动添加。

另请参见{{link1:浏览器/HTML强制从src =“data:image / jpeg; base64 ...”下载图像}}

我的测试HTML页面是{{link2:http://kuitsi.bitbucket.org/stackoverflow12113616.html}}


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接