使用ASP.NET內(nèi)置類(lèi)生成圖片縮略圖及水印_.Net教程
教程Tag:暫無(wú)Tag,歡迎添加,賺取U幣!
推薦:揭秘.Net開(kāi)發(fā)常用十大輔助軟件1.EditPlus:文字處理軟件 EditPlus是一款功能強(qiáng)大的文字處理軟件。它可以充分的替換記事本,它也提供網(wǎng)頁(yè)作家及程序設(shè)計(jì)師許多強(qiáng)悍的功能。支持HTML、CSS、PHP、ASP、Perl、C/C++、Java、JavaScript、VBScript等多種語(yǔ)法的著色顯示。程序內(nèi)嵌網(wǎng)頁(yè)瀏覽器,其
ASP.NET Image Generation內(nèi)置了ImageResizeTransform類(lèi),可以實(shí)現(xiàn)圖片大小調(diào)整功能。也可以擴(kuò)展ImageTransform實(shí)現(xiàn)自己的圖片變換類(lèi)。下面使用ASP.NET Image Generation生成圖片縮略圖及水印的代碼。
數(shù)據(jù)庫(kù): 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如何實(shí)現(xiàn)“行轉(zhuǎn)列”代碼開(kāi)發(fā)中經(jīng)常遇到行轉(zhuǎn)列的情況,一般都是在SQL中用case來(lái)解決這類(lèi)問(wèn)題,但有時(shí)候我們會(huì)需要知道列數(shù)并做一些事情。 這時(shí),DataList就發(fā)揮它的作用了。主要應(yīng)用的就是它的RepeatDirection屬性. %@PageLanguage=C#AutoEventWireup=trueCodeFile=DataList.as
相關(guān).Net教程:
- asp.net如何得到GRIDVIEW中某行某列值的方法
- .net SMTP發(fā)送Email實(shí)例(可帶附件)
- js實(shí)現(xiàn)廣告漂浮效果的小例子
- asp.net Repeater 數(shù)據(jù)綁定的具體實(shí)現(xiàn)
- Asp.Net 無(wú)刷新文件上傳并顯示進(jìn)度條的實(shí)現(xiàn)方法及思路
- Asp.net獲取客戶端IP常見(jiàn)代碼存在的偽造IP問(wèn)題探討
- VS2010 水晶報(bào)表的使用方法
- ASP.NET中操作SQL數(shù)據(jù)庫(kù)(連接字符串的配置及獲取)
- asp.net頁(yè)面?zhèn)髦禍y(cè)試實(shí)例代碼
- DataGridView - DataGridViewCheckBoxCell的使用介紹
- asp.net中javascript的引用(直接引入和間接引入)
- 三層+存儲(chǔ)過(guò)程實(shí)現(xiàn)分頁(yè)示例代碼
.Net教程Rss訂閱編程教程搜索
.Net教程推薦
- asp.net中“從客戶端中檢測(cè)到有潛在危險(xiǎn)的Request.Form值”的錯(cuò)誤
- 如何實(shí)現(xiàn)vs.net控件updatePanel無(wú)刷新
- 教你簡(jiǎn)單方便獲取Web設(shè)計(jì)的免費(fèi)資源
- 揭秘ASP.NET頁(yè)面刷新的幾種方法
- 解析WPF綁定層次結(jié)構(gòu)數(shù)據(jù)的應(yīng)用詳解
- 淺談ASP.NET中顯示Linq To SQL輸出的SQL語(yǔ)句
- ASP.NET立即上手教程(11)
- ASP.NET2.0服務(wù)器控件之創(chuàng)建復(fù)雜屬性
- c#自定義控件中事件的處理
- ASP.NET立即上手教程(6)
- 相關(guān)鏈接:
- 教程說(shuō)明:
.Net教程-使用ASP.NET內(nèi)置類(lèi)生成圖片縮略圖及水印。