AspJpeg組件:介紹、注冊、高級使用方法 asp文字轉圖片 用aspjpeg實現(2010-12-22)


中超颁奖典礼海口 www.pljhu.icu 1、什么是AspJpeg?
  AspJpeg是一款功能強大的基于Microsoft IIS環境的圖片處理組件,網絡上對其進行詳細和深入介紹的中文文章并不多,即使有一般也只是牽涉到圖片縮略圖和圖片水印,這與其為英文版本有著密切的關系。
  AspJpeg可以使用很少的代碼在您的ASP/ASP.Net應用程序上動態的創建高質量的縮略圖象,支持的圖象格式有:JPEG, GIF, BMP, TIFF, PNG

AspJpeg主要可以做到:

生成縮略圖片
生成水印圖片
圖片合并
圖片切割
數據庫支持
安全碼技術

2、AspJpeg功能摘要
支持JPEG, GIF, BMP, TIFF 和 PNG 格式圖片. 輸出格式始終為 JPEG
源圖片可以來源于磁盤、內存、或者記錄集(數據庫)
縮略圖片可以保存到磁盤、內存、或者HTTP流
支持三種更改大小方式: nearest-neighbor, bilinear, and bicubic.
可以在圖片之上添加圖片或者文字.
支持畫中畫
支持復制,反轉,旋轉,銳化,灰度調節.
可以調節壓縮比率,以得到最佳輸出效果和大小.
從Jpeg圖片中抽取EXIF 和 IPTC數據.
CMYK-RGB轉換
Read/write access to individual pixels of an image. (從圖象中對任意象素進行讀/寫存取。)

3、AspJpeg系統需求
Windows 95/98/NT/2000/XP/2003, and
IIS 4.0+ and ASP/ASP.NET, or
Visual Basic 5.0+, or
Visual C++ 5.0+, or
any development environment supporting COM.

4、AspJpeg安裝
全新安裝:
在AspJpeg安裝過程中輸入序列號即可,如果安裝位置磁盤格式為NTFS,則可能出現訪問權限問題,需手工設置安裝目錄對Everyone有訪問權限。
AspJpeg v1.6.0.0
安裝sn:48958-77556-02411
AspJpeg v1.5.0
安裝sn:71316-48529-38722



更新安裝:
如果之前有裝過其它版本的AspJpeg組件,則需要先卸載原來的組件,再進行新版本的安裝。
先停止IIS
Net Stop iisadmin /y
卸載舊版組件
regsvr32 /u Path/aspjpeg.dl(Path為安裝路徑)
重啟IIS
Net Start w3svc

然后再進行全新安裝或復制AspJpeg.dll文件到安裝目錄進行手工安裝:
regsvr32 Path/aspjpeg.dll(Path為安裝路徑)

如果在正常安裝過程中沒有輸入序列號或手工安裝則必須在注冊表中加入以下項,為方便起見您可以直接將以下代碼保存為.reg文檔并導入注冊表:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\Persits Software\AspJpeg\RegKey]
@="48958-77556-02411"


5、如何創建一個AspJpeg實例?
Set Jpeg = Server.CreateObject("Persits.Jpeg")

6、如何查看到期時間(是否注冊成功)?
Set Jpeg = Server.CreateObject("Persits.Jpeg")
Response.Write Jpeg.Expires
注冊成功則到期時間為:9999-9-9
否則為:安裝日期加1個月期限

7、如何用AspJpeg組件生成圖片縮略圖?

<%
Set Jpeg = Server.CreateObject("Persits.Jpeg")
'創建實例
Path = Server.MapPath("../images/apple.jpg")
'處理圖片路徑
Jpeg.Open Path
'打開圖片
'調整寬度和高度為原來的50%
Jpeg.Width = Jpeg.OriginalWidth /
2
Jpeg.Height = Jpeg.OriginalHeight /
2
Jpeg.Save Server.MapPath("apple_small.jpg")
'保存圖片到磁盤
Jpeg.Close
Set Jpeg =
Nothing
%>

8、如何用AspJpeg組件生成圖片水???

<%
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) //hi.baidu.com/yongfa365."
'打印坐標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")
'保存
%>

9、如何用AspJpeg組件進行圖片合并?
AspJpeg 1.3+ enables you to place images on top of each other via the method DrawImage. To use this method, you must create two instances of the AspJpeg objects and populate both of them with images via calls to Open (or OpenBinary). When calling Canvas.DrawImage, the 2nd instance of AspJpeg is passed as an argument to this method, along with the X and Y offsets (in pixels):
使用該方法,您必需創建兩個AspJpeg實例對象

<%
Set Jpeg1 = Server.CreateObject("Persits.Jpeg"
)
Set Jpeg2 = Server.CreateObject("Persits.Jpeg"
)
Jpeg1.Open Server.MapPath("t.jpg"
)
Jpeg2.Open Server.MapPath("t1.jpg"
)
Jpeg1.Canvas.DrawImage 10, 10, Jpeg2
' optional arguments omitted
jpeg1.save Server.mappath("tt.jpg"
)
%>

10、如何用AspJpeg組件進行圖片切割?
AspJpeg 1.1+ is also capable of cutting off edges from, or cropping, the resultant thumbnails via the method Crop(x0, y0, x1, y1). The size of the cropped image is specified by the coordinates of the upper-left and lower-right corners within the resultant thumbnail, not the original large image.

<%
Set Jpeg = Server.CreateObject("Persits.Jpeg"
)
Jpeg.Open Server.MapPath("t.jpg"
)
jpeg.Crop 20, 30, jpeg.Width - 20, jpeg.Height -
10
jpeg.save Server.mappath("tt.jpg"
)
Response.Write(""
)
%>


11、如何用AspJpeg組件創建安全碼?
創建安全碼原理上和創建水印差不多。

<%
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

'生成安全碼的圖片。
random_num = make_randomize(4, 1)
''生成4位數字的安全碼
session("random_num") = random_num
'為么調用session,沒有session的安全碼是完全沒有意義的。呵呵 .

Set Jpeg = Server.CreateObject("Persits.Jpeg")
'調用組件
Jpeg.Open Server.MapPath("t.jpg")
'打開準備的圖片
Jpeg.Canvas.Font.Color = &HFFFFFF
Jpeg.Canvas.Font.Family =
"Arial Black"
Jpeg.Canvas.Font.Bold =
false
Jpeg.Canvas.PrintText 0, -2, random_num
jpeg.save Server.MapPath("tt.jpg")
'保存
%>



12、如何讓AspJpeg組件支援數據庫?
圖片存進數據庫只能以二進制數據保存,這里即利用AspJpeg的Binary方法,下面以兩個AspJpeg用戶手冊上的代碼為例,具體請參考AspJpeg用戶手冊:
Opening Images from Memory

<%
' Using ADO, open database with an image blob
strConnect = "DRIVER={Microsoft Access Driver (*.mdb)};DBQ=" & Server.MapPath("../db/aspjpeg.mdb"
)
Set rs = Server.CreateObject("adodb.recordset"
)
SQL = "select image_blob from images2 where id = " & Request("id"
)
rs.Open SQL, strConnect, 1,
3
Set Jpeg = Server.CreateObject("Persits.Jpeg"
)
' Open image directly from recordset
Jpeg.OpenBinary rs("image_blob").Value
' Resize
jpeg.Width = Request("Width"
)
' Set new height, preserve original aspect ratio
jpeg.Height = jpeg.OriginalHeight * jpeg.Width / jpeg.OriginalWidth
Jpeg.SendBinary
rs.Close
%>



Output to Memory

<%
...
Set rs = Server.CreateObject("adodb.recordset"
)
rs.Open "images", strConnect, 1,
3
rs.AddNew
rs("image_blob").Value = Jpeg.Binary
rs.Update
...
%>

一個生成文字水印的過程
<%
'call jpegclass(圖片相對路徑, 文字字體大小, 文字字體, 是否加粗, 距頂部距離, 距左邊距離, 水印內容)

Sub jpegclass(J_imgurl, J_fontsize, J_family, J_isbold, J_top, J_Left, J_Content)
'調用過程名

    
If Len(J_imgurl) = 0 Or Len(J_Content) = 0
Then Exit Sub
     Dim
JPEG, font_color, font_size, font_family, f_width, f_height, f_Content
    Set JPEG = Server.CreateObject("Persits.JPEG"
)
    
JPEG.Open Server.MapPath(J_imgurl
)
    
font_size =
10
    
font_family =
"宋體"
    
f_Left =
5
    
f_top =
5
    
If J_fontsize<>"" Then font_size = J_fontsize
'字體大小
    
If J_family<>"" Then font_family = J_family
'字體
    
If J_top<>"" Then f_Left = J_Left
'水印離圖片左邊位置
    
If J_Left<>"" Then f_top = J_top
'水印離圖片J_top位置
    
f_Content = J_Content
    
' 添加文字水印
    
JPEG.Canvas.Font.Color = &hff0000
' 紅色
    
JPEG.Canvas.Font.family = font_family
     JPEG.canvas.font.Size = font_size
    If J_isbold = 1
Then
        
JPEG.Canvas.Font.Bold =
True
     End If
    
JPEG.Canvas.Print f_Left, f_top, f_Content
     JPEG.Save Server.MapPath(J_imgurl
)
    
Set JPEG =
Nothing
End Sub
%>

在線客服 在線客服 付款方式 郵箱 關閉 老时时3老时时360走势图 重庆时时开彩结果下载 打老虎机 2019时时彩平台注册 时时彩双面盘平台 mg电子爆奖视频 奇趣腾讯分分彩免费计划软件 时时彩计划软件 福彩3d六码复式选择 时时彩平台官方网 七星彩内部会员资料 pk10如何学会看走势 一分赛车计划 山东时时怎么中奖号码 重庆时时彩开奖网站 pk10三码必中计划