0

私はこれを理解しようとしてきましたが、どこにも行きません。私がやろうとしているのはこれです:画像をアップロードできるaspxページがあり(サーバー上のフォルダーに保存されています)、1つのページでアップロードされたすべての画像を表示でき、リンク(タグ)を生成しますこれらの画像への参照を使用しましたが、今まで完全な画像を「サムネイル」としてロードし、サイズが大きすぎました (1920x1200px)。そのため、画像 src を汎用ハンドラーに置き換えました。フォルダーに戻り、209x133px のようにサイズ変更します。

しかし、私はどこから始めればよいかわかりません。

とにかく、事前に感謝します

これは、リピーターを使用してリンクと画像を作成する方法です。

protected void repImages_ItemDataBound(object sender, RepeaterItemEventArgs e)
{
    if (e.Item.ItemType == ListItemType.AlternatingItem ||
        e.Item.ItemType == ListItemType.Item)
    {
        string sFile = e.Item.DataItem as string;

        //Create the thumblink
        HyperLink hlWhat = e.Item.FindControl("hlWhat") as HyperLink;
        hlWhat.NavigateUrl = ResolveUrl("~/_img/_upload/" + sFile);
        hlWhat.ToolTip = System.IO.Path.GetFileNameWithoutExtension(sFile);
        hlWhat.Attributes["rel"] = "imagebox-bw";
        hlWhat.Attributes["target"] = "_blank";

        Image oImg = e.Item.FindControl("imgTheImage") as Image;
        oImg.ImageUrl = ResolveUrl("Thumbnail.ashx?img=" + sFile);
        oImg.Width = 203;
        oImg.CssClass = "galleryImgs";

    }

}

今のところ、私のハンドラーは次のようになります。

<%@ WebHandler Language="C#" Class="Thumbnail" %>

using System;
using System.Web;

public class Thumbnail : IHttpHandler {

    public void ProcessRequest (HttpContext context) {
        if (!string.IsNullOrEmpty(context.Request.QueryString["img"]))
        {
            string fileName = context.Request.QueryString["img"];

        }

        else
        {

        }

    }

    public bool IsReusable {
        get {
            return false;
        }
    }

}
4

3 に答える 3

0

System.DrawingおよびSystem.Drawing.Drawing2D名前空間を追加すると、画像のサイズを変更できます CodeBehind

public static System.Drawing.Image ScaleImage(System.Drawing.Image image, int maxHeight)
  {
      var ratio = (double)maxHeight / image.Height;
      var newWidth = (int)(image.Width * ratio);
      var newHeight = (int)(image.Height * ratio);
      var newImage = new Bitmap(newWidth, newHeight);
      using (var g = Graphics.FromImage(newImage))
      {
          g.DrawImage(image, 0, 0, newWidth, newHeight);
      }
      return newImage;
  }
于 2012-12-21T10:40:43.170 に答える
0

いくつかの調整が必要なコードを次に示しますが、先に進むのに役立ちます。

// 1x1 transparent GIF
private readonly byte[] GifData = {
    0x47, 0x49, 0x46, 0x38, 0x39, 0x61,
    0x01, 0x00, 0x01, 0x00, 0x80, 0xff,
    0x00, 0xff, 0xff, 0xff, 0x00, 0x00,
    0x00, 0x2c, 0x00, 0x00, 0x00, 0x00,
    0x01, 0x00, 0x01, 0x00, 0x00, 0x02,
    0x02, 0x44, 0x01, 0x00, 0x3b
};

public void ProcessRequest(HttpContext context)
{
    // render direct
    context.Response.BufferOutput = false;

    bool fFail = true;

    try
    {
      if (!string.IsNullOrEmpty(context.Request.QueryString["img"]))
      {
        string fileName = context.Request.QueryString["img"];         

        using( var inputImage = new Bitmap(fileName))
        {   
            // create the thubnail
            FinalImage = CreateThubNain();          

            // send it to browser
            FinalImage.Save(context.Response.OutputStream, ImageFormat.Jpeg);           
            // flag tha all ends up well
            fFail = false;
        }          
      }
    }
    catch(Exception x)
    {
        // log the error
        Debug.Fail("Check why is fail - error:" + x.ToString());
    }

    if(fFail)
    {
        // send something anyway
        context.Response.ContentType = "image/gif";
        context.Response.OutputStream.Write(GifData, 0, GifData.Length);
    }
    else
    {
        // this is a header that you can get when you read the image
        context.Response.ContentType = "image/jpeg";

        // the size of the image, saves from load the image, and send it here
        // context.Response.AddHeader("Content-Length", imageData.Length.ToString());

        // cache the image - 24h example
        context.Response.Cache.SetExpires(DateTime.Now.AddHours(24));
        context.Response.Cache.SetMaxAge(new TimeSpan(24, 0, 0));   
    }
}

サムネイルの作成方法に関する1つの質問:アスペクト比を維持しながらデータベース画像からサムネイルを作成する

いくつかのコメント。ハンドラーを使用してサムネイルを作成すると、同じものを何度も作成するために多くの処理時間がかかります。サムネイルを追跡してディスクに保存し、ディスクからファイルを直接使用することをお勧めします。

于 2012-12-21T10:34:17.687 に答える
0

次のような方法を使用します。

private Image ScaleFreeHeight(string imagePath, int newWidth)
{
    var byteArray = new StreamReader(imagePath).BaseStream;        
    var image = Image.FromStream(byteArray);
    var newHeight2 = Convert.ToInt32(newWidth * (1.0000000 * image.Height / image.Width));
    var thumbnail = new Bitmap(newWidth, newHeight2);
    var graphic = Graphics.FromImage(thumbnail);
    graphic.InterpolationMode = InterpolationMode.HighQualityBicubic;
    graphic.SmoothingMode = SmoothingMode.HighQuality;
    graphic.PixelOffsetMode = PixelOffsetMode.HighQuality;
    graphic.CompositingQuality = CompositingQuality.HighQuality

    graphic.DrawImage(image, 0, 0, newWidth, newHeight2);

    return thumbnail;
}
于 2012-12-21T10:35:45.650 に答える