可以采用ASP的(de)組件JPEG來(lai)做,可以先做一個(ge)圖片,上面是你的(de)網站LOGO相關的(de)東(dong)西,然(ran)后將(jiang)文字寫在上面,以下方法搜集了幾種方法,大家可以參考一下。
aspjpeg的高級用法中,包括以下常用技術:
圖片(pian)縮略 圖片(pian)水(shui)印(yin) 安全碼(ma)技術 圖片(pian)切割 圖片(pian)合并(bing) 數據庫支持等。
aspjpeg唯一點不足(zu)的就是輸出(chu)方(fang)式比(bi)較(jiao)單一。在這(zhe)里,我(wo)們主(zhu)要談將圖片處理(li)保(bao)存后再調用的這(zhe)種(zhong)輸出(chu)方(fang)法。另(ling)外(wai),本(ben)人比(bi)較(jiao)懶,所以有些代碼仍然引用于原文檔,不懂的地方(fang)偶會加以解釋!
學過vb或者.net的同志(zhi)肯定一(yi)看就(jiu)明白了(le)。刷子來著。呵呵。
一、圖片縮略
<%
Set Jpeg = Server.CreateObject("Persits.Jpeg") 調用組件
Path = Server.MapPath("images") & "clock.jpg" 待處理圖片路徑
Jpeg.Open Path 打開圖片
高與寬為原圖片的1/2
Jpeg.Width = Jpeg.OriginalWidth / 2
Jpeg.Height = Jpeg.OriginalHeight / 2
保存圖片
Jpeg.Save Server.MapPath("images") & "clock_small.jpg"
%> 查看處理的圖片
二、圖片水印
<%
Set Jpeg = Server.CreateObject("Persits.Jpeg")
Jpeg.Open Server.MapPath("images/dodge_viper.jpg")
開始寫文字
Jpeg.Canvas.Font.Color = &000000' red 顏色
Jpeg.Canvas.Font.Family = "Courier New" 字體
Jpeg.Canvas.Font.Bold = True 是否加粗
Jpeg.Canvas.Print 10, 10, "Copyright (c) XYZ, Inc."
打印坐標x 打印坐標y 需要打印的字符
以下是對圖片進行邊框處理
Jpeg.Canvas.Pen.Color = &H000000' black 顏色
Jpeg.Canvas.Pen.Width = 2 畫筆寬度
Jpeg.Canvas.Brush.Solid = False 是否加粗處理
Jpeg.Canvas.Bar 1, 1, Jpeg.Width, Jpeg.Height
起始X坐標 起始Y坐標 輸入長度 輸入高度
Jpeg.Save Server.MapPath("images/dodge_viper_framed.jpg") 保存
%>
三、安全碼
安全瑪的道理和加水印差不多,很多朋友問我要具體的代碼技術,在這里和大家分享。
<%
生成安全碼的函數
function make_randomize(max_len,w_n) max_len 生成長度,w_n:0 可能包含字母,1:只為數字
randomize
for intcounter=1 to max_len
whatnext=int((1-0+1)*rnd+w_n)
if whatnext=0 then
upper=122
lower=97
else
upper=57
lower=48
end if
strnewpass=strnewpass & chr(int((upper-lower+1)*rnd)+lower)
next
make_randomize=strnewpass
end function
%>
生成安(an)全碼的圖片。當(dang)然你(ni)要(yao)預先準備一張背景圖哦
<%random_num=make_randomize(4,1) 生成4位數字的安全碼
session("random_num")=random_num 為什么(me)調用session,沒有(you)session的(de)安全(quan)碼(ma)是完(wan)全(quan)沒有(you)意義的(de)。呵呵
Set Jpeg = Server.CreateObject("Persits.Jpeg") 調用組件
Jpeg.Open Server.MapPath("infos/random_pic/random_index.gif") 打開準備的圖片
Jpeg.Canvas.Font.Color = &H006699
Jpeg.Canvas.Font.Family = "Arial Black"
Jpeg.Canvas.Font.Bold = false
Jpeg.Canvas.PrintText 0, -2, random_num
jpeg.save Server.MapPath("infos/random_pic/random_index.bmp") 保存
%>
自己做做看。呵呵。
四、圖片切割
一直以來,對aspjpeg不了解的人以為是無法用它來進行切割的。
其實有這樣的一個方法的
crop x1,y1,x2,y2
切割長方型左上角x坐標,y坐標 右下角x坐標 y坐標
下面我就做一個演示哈
Set Jpeg = Server.CreateObject("Persits.Jpeg")
jpeg.open server.MapPath("/pic/1.gif")
jpeg.width=70
Jpeg.Height = Jpeg.OriginalHeight*70 / jpeg.Originawidth
jpeg.crop 0,0,70,52 開始切割其實是把超過52象素的下部分去掉
jpeg.save server.MapPath("/temp_pic/small_1.gif") 保(bao)存
這樣就行了。
五、圖片合并
我們這里是要把logo圖片加到dodge_viper.jpg圖片上去
其實,圖片合并的方法也可以用來動態打水印哦
Set Photo = Server.CreateObject("Persits.Jpeg")
PhotoPath = Server.MapPath("images") & "dodge_viper.jpg"
Photo.Open PhotoPath
Set Logo = Server.CreateObject("Persits.Jpeg")
LogoPath = Server.MapPath("images") & "clock.jpg"
Logo.Open LogoPath
Logo.Width = 70
Logo.Height = Logo.Width * Logo.OriginalHeight / Logo.OriginalWidth
Photo.DrawImage 0, 0, Logo
Photo.SendBinary 這里用了sendBinary的輸出方法。
當然,你也可以先保存更改后的dodge_viper.jpg,再輸入也可以。
個人不大(da)喜歡用sendBinary方法,在網速慢的時候容(rong)易出錯。在速度方面也不怎樣。
六、數據庫支持
這里不(bu)多說了。其實就是Binary方(fang)法(fa),大(da)家(jia)知道圖片存進(jin)數據(ju)庫只能存為(wei)二進(jin)制的文件的。
七、更多方法介紹
Canvas.Line(Left, Top, Right, Bottom)
畫一條直線
Canvas.Ellipse(Left, Top, Right, Bottom)
畫出一個橢圓
Canvas.Circle(X, Y, Radius)
畫出一個圓
Canvas.Bar(Left, Top, Right, Bottom)
畫出一個長方形,上面有代碼介紹了
Canvas.Font.ShadowColor
文字陰影顏色
Canvas.Font.ShadowXOffset As Long
陰影X坐標設定
Canvas.Font.ShadowYOffset As Long
Y坐標設定
Canvas.Font.BkMode As String
文字背景
旗下網站:耐思智慧 - - - 中文域(yu)名:
耐(nai)思智慧 © 版權(quan)所有(you) Copyright © 2000-2025 szjicheng.cn,Inc. All rights reserved
備案號碼:
公安備案號:
聲明:本(ben)網站(zhan)中所(suo)使(shi)用到的(de)其他各種版權(quan)(quan)內(nei)容,包括(kuo)但(dan)不限于(yu)文章、圖片、視頻、音頻、字(zi)體等內(nei)容版權(quan)(quan)歸原作(zuo)者所(suo)有(you),如權(quan)(quan)利所(suo)有(you)人(ren)發現,請及時告知,以(yi)便我們(men)刪(shan)除版權(quan)(quan)內(nei)容
本站程序(xu)界(jie)面、源代碼受(shou)相關法律保護, 未經(jing)授(shou)權(quan), 嚴(yan)禁(jin)使(shi)用(yong); 耐思智慧 © 為(wei)我(wo)公司注冊商標, 未經(jing)授(shou)權(quan), 嚴(yan)禁(jin)使(shi)用(yong)
法律顧問: