Puede codificar la imagen en base64. Por ejemplo
<img src="" alt="My Image data in base 64" />
Aquí es un ejemplo completo de cómo se puede lograr esto:
using System;
using System.IO;
using System.Runtime.InteropServices;
using System.Windows.Forms;
namespace ImageEncodedInBase64InAWebBrowser
{
[ComVisible(true)]
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
string url = Directory.GetCurrentDirectory() + "\\page.html";
webBrowser1.Url = new Uri(url);
webBrowser1.ObjectForScripting = this;
}
private void button1_Click(object sender, EventArgs e)
{
string imageInBase64 = ReadImageInBase64();
webBrowser1.Document.InvokeScript("setImageData", new[] { imageInBase64 });
}
private string ReadImageInBase64()
{
string imagePath = Directory.GetCurrentDirectory() + "\\opensource.png";
using (var fs = new FileStream(imagePath, FileMode.Open, FileAccess.Read))
{
var buffer = new byte[fs.Length];
fs.Read(buffer, 0, (int)fs.Length);
return Convert.ToBase64String(buffer);
}
}
}
}
Y este código Javascript:
function setImageData(imageBase64) {
var myImg = document.getElementById("myImg");
myImg.src = "data:image/png;base64," + imageBase64;
}
Usted podría intentar esto http://stackoverflow.com/questions/290035/how-do-i-get-ac-sharp-webbrowser-control-to-show-jpeg-files-raw y si eso no funciona, podría ver esto http://www.codeproject.com /KB/files/MhtBuilder.aspx e intenta convertir tu imagen a .mhtml y luego muéstrala. – user629926
cual es el objetivo, ¿por qué necesitas cargarlo desde la RAM? Si se trata de rendimiento, puede usar un SSD. –
¿Qué control WebBrowser estás usando? ¿El de WinForms, el de WPF o el de Silverlight? –