Awesomium 如何在不重新下载的情况下保存已加载的图像

Awesomium how save a loaded image without redownload it

如何在不重新下载的情况下将 Awesomium 浏览器中已加载的图像复制或保存到本地磁盘?

有下载图片的方法:
http://docs.awesomium.net/html/M_Awesomium_Windows_Controls_WebControl_SaveImageAt.htm

但是它有两个问题:

  1. 重新下载图片。
  2. 它显示了一个弹出窗口来保存图像,但我不想要它。

还javascript中的每一种方式重新下载目标图像!
解决方法是什么?
我们如何从缓存文件夹中抓取下载的图像?

您可以尝试这样的操作:

    /// <summary>
    /// Returns Base64 string of image content. Without redownloading image. If it is not on the same domain, WebSecurity must be set to false.
    /// </summary>
    /// <param name="getElementQuery">
    /// <para>Any Javascript query to get an element.</para>
    /// <para>Examples:</para>
    /// <para>"document.getElementById('id')"</para>
    /// <para>"document.getElementsByClassName('name')[0]"</para>
    /// <para>"document.evaluate(\"//a[contains(@href, 'something')]\", document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null ).singleNodeValue" (XPath)</para>
    /// </param>
    /// <param name="leaveOnlyBase64Data">if true, removes "data:image/type;base64," from the beginning of the string</param>
    /// <returns>Base64 string or empty string in case of error</returns>
    public static string JsGetImgBase64String(string getElementQuery, bool leaveOnlyBase64Data = true)
    {
        string data = webView.ExecuteJavascriptWithResult(@"
                                        function getImgBase64String(img)
                                        {
                                            var cnv = document.createElement('CANVAS');
                                            var ctx = cnv.getContext('2d');
                                            ctx.drawImage(img, 0, 0);
                                            return cnv.toDataURL();
                                        }
                            " + String.Format("getImgBase64String({0});", getElementQuery));

        if (data == "undefined")
            return string.Empty;

        if (leaveOnlyBase64Data && data.Contains(","))
        {
            data = data.Substring(data.IndexOf(",") + 1);
        }

        return data;
    }

用法:

 string imgBase64 = JsGetImgBase64String("document.getElementById('imageId')");
 byte[] imgBytes = Convert.FromBase64String(imgBase64 );

如果图像不在同一个域中,您可能需要在 WebPreferences 中将 WebSecurity 设置为 false