All articles| All Pictures| All Softwares| All Video| Go home page| Write articles| Upload pictures

Reading number is top 10 articles
C#中父窗口和子窗口之间实现控件互操作_[Asp.Net教程]
掌握Ajax 第1部分-Ajax简介_[AJAX教程]
Javscript实现表单复选框的全选功能_JavaScript技术_编程技术
Delphi以XPManifest组件显示界面
配置ASP.net的运行环境_[Asp.Net教程]
PHP Token(令牌)设计_[PHP教程]
PHP5,OOP编程之代理与定制异常_php资料_编程技术
数据库优化之让你的SQL运行得更快_[SQL Server教程]
数据库死锁导致站点访问故障解决方案_[SQL Server教程]
asp.net乱码处理_[Asp.Net教程]
Reading number is top 10 pictures
餐桌上的鱼
Breasts woman big set 2
这玉米,买还是不卖?
全球清廉国家排行
mythology hero1
美女当网吧管理员的悲剧
西游四格漫画(二)
The little girl with long hair1
Plump, too plump!2
So beauty, will let you spray blood8
Download software ranking
功夫熊猫2(下集)
ASP.NET.2.0.XML.高级编程(第3版)
Tram sex maniac 2 (H) rar bag7
Boxer Classic video1
The hero
Boxer's Top ten classic battle6
Unix video tutorial8
Unix video tutorial20
Rio big adventure
C#编程思想
归海一刀 published in(发表于) 2014/1/30 1:31:00 Edit(编辑)
使用ASP.NET内置类生成图片缩略图及水印_[Asp.Net教程]

使用ASP.NET内置类生成图片缩略图及水印_[Asp.Net教程]

使用ASP.NET内置类生成图片缩略图及水印_[Asp.Net教程]
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" %>









RepeatDirection="Horizontal" CellPadding="4" CellSpacing="4">

Timestamp=’<%# Eval("last_modified_date") %>’>

’ />








ProviderName="System.Data.SqlClient" SelectCommand="SELECT [image_id], [image_data], [last_modified_date] FROM [t_images]">






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();
}
}
}
}


运行效果:



添加到del.icio.us 添加到新浪ViVi 添加到百度搜藏 添加到POCO网摘 添加到天天网摘365Key 添加到和讯网摘 添加到天极网摘 添加到黑米书签 添加到QQ书签 添加到雅虎收藏 添加到奇客发现 diigo it 添加到饭否 添加到飞豆订阅 添加到抓虾收藏 添加到鲜果订阅 digg it 貼到funP 添加到有道阅读 Live Favorites 添加到Newsvine 打印本页 用Email发送本页 在Facebook上分享


Disclaimer Privacy Policy About us Site Map

If you have any requirements, please contact webmaster。(如果有什么要求,请联系站长)
Copyright ©2011-
uuhomepage.com, Inc. All rights reserved.