使用ASP.NET內置類生成圖片縮略圖及水印_.Net教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦:揭秘.Net開發常用十大輔助軟件
      1.EditPlus:文字處理軟件 EditPlus是一款功能強大的文字處理軟件。它可以充分的替換記事本,它也提供網頁作家及程序設計師許多強悍的功能。支持HTML、CSS、PHP、ASP、Perl、C/C++、Java、JavaScript、VBScript等多種語法的著色顯示。程序內嵌網頁瀏覽器,其

          ASP.NET Image Generation內置了ImageResizeTransform類,可以實現圖片大小調整功能。也可以擴展ImageTransform實現自己的圖片變換類。
          下面使用ASP.NET Image Generation生成圖片縮略圖及水印的代碼。
      數據庫:

      CREATE TABLE t_images
      (
      image_id INT,
      image_data IMAGE,
      last_modified_date, DATETIME
      )

      Default.aspx:

      <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="NET35Lab.GeneratedImage.Web._Default" %>

      <%@ Register Assembly="Microsoft.Web.GeneratedImage" Namespace="Microsoft.Web" TagPrefix="cc1" %>
      <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
      <html xmlns="http://www.w3.org/1999/xhtml">
      <head runat="server">
          <title></title>
      </head>
      <body>
          <form id="form1" runat="server">
          <div>
              <asp:DataList ID="DataList1" runat="server" DataSourceID="SqlDataSource1" RepeatColumns="2"
                  RepeatDirection="Horizontal" CellPadding="4" CellSpacing="4">
                  <ItemTemplate>
                      <cc1:GeneratedImage ID="GeneratedImage1" runat="server" ImageHandlerUrl="~/ImageHandler1.ashx"
                          Timestamp=’<%# Eval("last_modified_date") %>’>
                          <Parameters>
                              <cc1:ImageParameter Name="imageid" Value=’<%# Eval("image_id") %>’ />
                          </Parameters>
                      </cc1:GeneratedImage>
                      <br />
                  </ItemTemplate>
              </asp:DataList>
          </div>
          <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\Database.mdf;Integrated Security=True;User Instance=True;"
              ProviderName="System.Data.SqlClient" SelectCommand="SELECT [image_id], [image_data], [last_modified_date] FROM [t_images]">
          </asp:SqlDataSource>
          </form>
      </body>
      </html>

      ImageHandler1.ashx:

      <%@ WebHandler Language="C#" CodeBehind="ImageHandler1.ashx.cs" Class="NET35Lab.GeneratedImage.Web.ImageHandler1" %>

      ImageHandler1.ashx.cs :

      using System;
      using System.Collections.Generic;
      using System.Linq;
      using System.Web;
      using Microsoft.Web;
      using System.Collections.Specialized;
      using System.Data.SqlClient;
      using System.Drawing;

      namespace NET35Lab.GeneratedImage.Web
      {

          public class ImageHandler1 : ImageHandler
          {

              public ImageHandler1()
              {
                  this.ImageTransforms.Add(new ImageResizeTransform { Width = 320, Mode = ImageResizeMode.Fit });
                  this.ImageTransforms.Add(new CopyrightTransform { Text = "Guushuuse .NET" });
                  this.EnableClientCache = true;
                  this.EnableServerCache = true;

              }

              public override ImageInfo GenerateImage(NameValueCollection parameters)
              {

                  int imageID = int.Parse(parameters["imageid"]);

                  SqlConnection connection = new SqlConnection(
                      @"Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\Database.mdf;Integrated Security=True;User Instance=True;");

                  connection.Open();

                  SqlCommand command = new SqlCommand("select image_data from t_images where image_id=" + imageID, connection);

                  SqlDataReader dr = command.ExecuteReader();

                  dr.Read();

                  return new ImageInfo((Byte[])dr[0]);

              }
          }

          public class CopyrightTransform : ImageTransform
          {
              private const int VERTICAL_PADDING = 5;
              private const int HORIZONAL_PADDING = 5;

              public string Text { get; set; }
              public Font Font { get; set; }
              public Color FontColor { get; set; }

              public CopyrightTransform()
              {
                  //Assign Defaults
                  FontColor = Color.FromArgb(128, 255, 0, 0);
                  Font = new Font("Courier", 13);
              }


              public override System.Drawing.Image ProcessImage(System.Drawing.Image img)
              {
                  Graphics gra = Graphics.FromImage(img);
                  SizeF sz = gra.MeasureString(Text, Font);
                  gra.DrawString(Text, Font, new SolidBrush(FontColor), img.Width - sz.Width - HORIZONAL_PADDING, img.Height - sz.Height - VERTICAL_PADDING);
                  return img;
              }

              public override string UniqueString
              {
                  get
                  {
                      return base.UniqueString + Text + FontColor.ToString() + Font.ToString();
                  }
              }
          }
      }
       

      分享:解析DataList如何實現“行轉列”代碼
      開發中經常遇到行轉列的情況,一般都是在SQL中用case來解決這類問題,但有時候我們會需要知道列數并做一些事情。 這時,DataList就發揮它的作用了。主要應用的就是它的RepeatDirection屬性. %@PageLanguage=C#AutoEventWireup=trueCodeFile=DataList.as

      來源:模板無憂//所屬分類:.Net教程/更新時間:2010-04-13
      相關.Net教程