10

This is my code, all it does is clear the web page and draw the image, so the rest of the form disappears! I need to show the image inside the form.

This is my User Control to display the images:

protected void Page_Load(object sender, EventArgs e)
    {

        if (Session["ObjHoteles"] == null)
        {
            Label1.Text = "Por favor, primero seleccione un hotel para desplegar las fotos.";
        }
        else
        {
            if (!IsPostBack)
            {
                List<Byte[]> ArrayFotos = new List<Byte[]>();
                string NombreDelHotel = "";

                Hoteles Hotel1 = (Hoteles)Session["ObjHoteles"];
                NombreDelHotel = Hotel1.NombreHotel;

                ArrayFotos = Persistencia.PersistenciaFotos.FotosDeHotel(NombreDelHotel);
                Session["CantFotos"] = ArrayFotos.Count();

                Byte[] Foto = ArrayFotos[0];

                Response.Buffer = true;
                Response.Clear();
                Response.ContentType = "image/jpeg";
                Response.Expires = 0;
                Response.BinaryWrite(Foto);
                Session["NumFoto"] = 0;
            }
            else
            {
                List<Byte[]> ArrayFotos = new List<Byte[]>();
                string NombreDelHotel = "";

                Hoteles Hotel1 = (Hoteles)Session["ObjHoteles"];
                NombreDelHotel = Hotel1.NombreHotel;

                ArrayFotos = Persistencia.PersistenciaFotos.FotosDeHotel(NombreDelHotel);
                Session["CantFotos"] = ArrayFotos.Count();

                Byte[] Foto = ArrayFotos[(int)Session["NumFoto"]];

                Response.Buffer = true;
                Response.Clear();
                Response.ContentType = "image/jpeg";
                Response.Expires = 0;
                Response.BinaryWrite(Foto);

            }
        }

I need to find a way that doesnt clear all the page, just draw the image inside the user control.

1
  • Hmm.. Please revise your question so it will list this specific demand of using a user control to achieve this.. made by your client according to what I read in your comments. Commented Aug 11, 2013 at 22:49

3 Answers 3

15

There is also another simple way:

  1. On your .aspx page:

    <asp:Image id="Image1" runat="server"></asp:Image>
    
  2. Then in your CodeBehind file .aspx.cs:

    Image1.ImageUrl = "data:image/jpeg;base64," + Convert.ToBase64String(Foto)
    
Sign up to request clarification or add additional context in comments.

1 Comment

Used this for my web application and it worked a treat. I wouldn't worry too much about IE7 and below as mentioned in previous comments. Most users will have IE8 and above or chrome/firefox etc... most people use the latest versions of available browsers now. Shire +1
14

You could write a page .aspx or a handler maybe .ashx that send the content of the picture back to the browser. You could pass information in the url. Then use the url to this page with an html tag or html control to display it.

EDIT: You need to use a Control. You could convert the binary data to base64 and output the content to the html page.

I give you an example with an img html tag:

<img alt="" src=""/>

You can also use base64 encoding for image with CSS:

background-image: url()

To convert into base64 from C# you can use:

using System;

and:

Convert.ToBase64String(Foto);

4 Comments

Hi, my client requested that i use a User Control.
Could you explain how to do it with CSS and base64 data?
This will not work with Internet Explorer 7 and earlier, because the data URI scheme is not supported at all and has limited support in Internet Explorer 8; read Data URI scheme for more information.
I tried this after converting an image from a byte array to a base64 string. It didn't work until I remove the trailing "2Q==" from the end of the base64 string, then it was fine.
3

Response.Clear(); is deleting all the buffered content (i.e. everything in your page).

Instead of a user control to display a dynamic image, consider an HTTP handler (.ashx), like this:

ImageHandler.ashx:

public class ImageHandler : System.Web.IHttpHandler
{
    public void ProcessRequest(HttpContext context)
    {
        // Logic to get byte array here
        byte[] buffer = WhateverLogicNeeded;
        context.Response.ContentType = "image/jpeg";
        context.Response.OutputStream.Write(buffer, 0, buffer.Length);
    }

    public bool IsReusable
    {
        get { return false; }
    }
}

Then in your .aspx page:

<asp:Image ID="image1" runat="server" ImageUrl="~/ImageHandler.ashx" />

Note: If you want a specific image, then you can pass a query string (i.e. image ID) to the handler and have the byte array logic account for using the query string value.

1 Comment

Hi Karl, thanks for your answer! My client requested specifically that i use a user control!

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.