国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

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

2024-07-10 12:51:59
字體:
來源:轉載
供稿:網友

推薦:揭秘.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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 高碑店市| 曲阳县| 抚顺县| 当阳市| 四会市| 鹤山市| 漳州市| 平阳县| 佛山市| 涡阳县| 玉屏| 海原县| 临湘市| 云林县| 扶沟县| 确山县| 伊宁市| 疏勒县| 崇信县| 全南县| 顺义区| 德阳市| 九江市| 信阳市| 鄂托克前旗| 庐江县| 科技| 抚州市| 曲松县| 巴彦县| 剑阁县| 温泉县| 措美县| 陇西县| 石首市| 囊谦县| 乳山市| 康马县| 林周县| 旅游| 新源县|