ASPJPEG综合操作的CLASS类

<% 
'ASPJPEG综合操作CLASS 
Class AspJpeg 
Dim AspJpeg_Obj,obj 
Private Img_MathPath_From,Img_MathPath_To,Img_Reduce_Size,CoverIf 
Private Img_Frame_Size,Img_Frame_Color,Img_Frame_Solid,Img_Frame_Width,Img_Frame_Height 
Private Img_Font_Content,Img_Font_Family,Img_Font_Color,Img_Font_Quality,Img_Font_Size,Img_Font_Bold,Img_Font_X,Img_Font_Y 
Private Img_PicIn_Path,Img_PicIn_X,Img_PicIn_Y 
'--------------取原文件路径 
Public Property Let MathPathFrom(StrType) 
Img_MathPath_From=StrType 
End Property

'--------------取文件保存路径 
Public Property Let MathPathTo(strType) 
Img_MathPath_To=strType 
End Property

'--------------保存文件时是否覆盖已有文件 
Public Property Let CovePro(LngSize) 
If LngSize=0 or LngSize=1 or LngSize=true or LngSize=false then 
CoverIf=LngSize 
End If 
End Property

'---------------取缩略图/放大图 缩略值 
Public Property Let ReduceSize(LngSize) 
If isNumeric(LngSize) then 
Img_Reduce_Size=LngSize 
End If 
End Property

'---------------取描边属性 
'边框粗细 
Public Property Let FrameSize(LngSize) 
If isNumeric(LngSize) then 
Img_Frame_Size=Clng(LngSize) 
End If 
End Property 
'边框宽度 
Public Property Let FrameWidth(LngSize) 
If isNumeric(LngSize) then 
Img_Frame_Width=Clng(LngSize) 
End If 
End Property 
'边框高度 
Public Property Let FrameHeight(LngSize) 
If isNumeric(LngSize) then 
Img_Frame_Height=Clng(LngSize) 
End If 
End Property 
'边框颜色 
Public Property Let FrameColor(strType) 
If strType<>"" then 
Img_Frame_Color=strType 
End If 
End Property 
'边框是否加粗 
Public Property Let FrameSolid(LngSize) 
If LngSize=1 or LngSize=0 or LngSize=true or LngSize=false then 
Img_Frame_Solid=LngSize 
End If 
End Property

'---------------取插入文字属性 
'插入的文字 
Public Property Let Content(strType) 
If strType<>"" then 
Img_Font_Content=strType 
End If 
End Property 
'文字字体 
Public Property Let FontFamily(strType) 
If strType<>"" then 
Img_Font_Family=strType 
End If 
End Property 
'文字颜色 
Public Property Let FontColor(strType) 
If strType<>"" then 
Img_Font_Color=strType 
End If 
End Property 
'文字品质 
Public Property Let FontQuality(LngSize) 
If isNumeric(LngSize) then 
Img_Font_Quality=Clng(LngSize) 
End If 
End Property 
'文字大小 
Public Property Let FontSize(LngSize) 
If isNumeric(LngSize) then 
Img_Font_Size=Clng(LngSize) 
End If 
End Property 
'文字是否加粗 
Public Property Let FontBold(LngSize) 
If LngSize=1 or LngSize=0 or LngSize=true or LngSize=false then 
Img_Font_Bold=LngSize 
End If 
End Property 
'输入文字的X坐标 
Public Property Let FontX(LngSize) 
If isNumeric(LngSize) then 
Img_Font_X=Clng(LngSize) 
End If 
End Property 
'输入文字的Y坐标 
Public Property Let FontY(LngSize) 
If isNumeric(LngSize) then 
Img_Font_Y=Clng(LngSize) 
End If 
End Property

'---------------取插入图片属性 
'插入图片的路径 
Public Property Let PicInPath(strType) 
Img_PicIn_Path=strType 
End Property 
'图片插入的X坐标 
Public Property Let PicInX(LngSize) 
If isNumeric(LngSize) then 
Img_PicIn_X=Clng(LngSize) 
End If 
End Property 
'图片插入的Y坐标 
Public Property Let PicInY(LngSize) 
If isNumeric(LngSize) then 
Img_PicIn_Y=Clng(LngSize) 
End If 
End Property

Private Sub Class_Initialize() 
Set AspJpeg_Obj=createObject("Persits.Jpeg") 
Img_MathPath_From="" 
Img_MathPath_To="" 
Img_Reduce_Size=150 
Img_Frame_Size=1 
'Img_Frame_Width=0 
'Img_Frame_Height=0 
'Img_Frame_Color="&H000000" 
'Img_Frame_Bold=false 
Img_Font_Content="GoldenLeaf" 
'Img_Font_Family="Arial" 
'Img_Font_Color="&H000000" 
Img_Font_Quality=3 
Img_Font_Size=14 
'Img_Font_Bold=False 
Img_Font_X=10 
Img_Font_Y=5 
'Img_PicIn_X=0 
'Img_PicIn_Y=0 
CoverIf=1

End Sub 
Private Sub Class_Terminate() 
Err.Clear 
Set AspJpeg_Obj=Nothing 
End Sub 
'判断文件是否存在 
Private Function FileIs(path) 
Set fsos=Server.createObject("Scripting.FileSystemObject") 
FileIs=fsos.FileExists(path) 
Set fsos=Nothing 
End Function

'判断目录是否存在 
Private Function FolderIs(path) 
Set fsos=Server.createObject("Scripting.FileSystemObject") 
FolderIs=fsos.FolderExists(path) 
Set fsos=Nothing 
End Function 
'******************************************* 
'函数作用:取得当前文件的上一级路径 
'******************************************* 
Private Function UpDir(ByVal D) 
If Len(D) = 0 then 
UpDir="" 
Else 
UpDir=Left(D,InStrRev(D,"\")-1) 
End If 
End Function

Private Function Errors(Errors_id) 
select Case Errors_id 
Case "0" 
Errors="指定文件不存在" 
Case 1 
Errors="指定目录不存在" 
Case 2 
Errors="已存在相同名称文件" 
Case 3 
Errors="参数溢出" 
End select 
End Function

'取图片宽度 
Public Function ImgInfo_Width(Img_MathPath) 
If Not(FileIs(Img_MathPath)) then 
'Exit Function 
ImgInfo_Width=Errors(0) 
Else 
AspJpeg_Obj.Open Img_MathPath 
ImgInfo_Width=AspJpeg_Obj.width 
End If 
End Function 
'取图片高度 
Public Function ImgInfo_Height(Img_MathPath) 
If Not(FileIs(Img_MathPath)) then 
'Exit Function 
ImgInfo_Height=Errors(0) 
Else 
AspJpeg_Obj.Open Img_MathPath 
ImgInfo_Height=AspJpeg_Obj.height 
End If 
End Function 
'生成缩略图/放大图 
Public Function Img_Reduce() 
If Not(FileIs(Img_MathPath_From)) then 
Img_Reduce=Errors(0) 
Exit Function 
End If 
If Not(FolderIs(UpDir(Img_MathPath_To))) then 
Img_Reduce=Errors(1) 
Exit Function 
End If 
If CoverIf=0 or CoverIf=False then 
If FileIs(Img_MathPath_To) then 
Img_Reduce=Errors(2) 
Exit Function 
End If 
End If 
AspJpeg_Obj.Open Img_MathPath_From 
AspJpeg_Obj.PreserveAspectRatio = True 
If AspJpeg_Obj.OriginalWidth>AspJpeg_Obj.OriginalHeight Then 
AspJpeg_Obj.Width=Img_Reduce_Size 
Else 
AspJpeg_Obj.Height=Img_Reduce_Size 
End If 
If AspJpeg_Obj.OriginalWidth>Img_Reduce_Size or AspJpeg_Obj.OriginalHeight>Img_Reduce_Size Then 
If AspJpeg_Obj.Width<Img_Reduce_Size or AspJpeg_Obj.Height<Img_Reduce_Size then 
Set AspJpeg_Obj_New=createObject("Persits.Jpeg") 
AspJpeg_Obj_New.new Img_Reduce_Size,Img_Reduce_Size,&HFFFFFF 
AspJpeg_Obj_New.DrawImage (150-AspJpeg_Obj.width)/2,(150-AspJpeg_Obj.height)/2,AspJpeg_Obj 
If Img_Frame_Size>0 then 
Call Img_Pen(AspJpeg_Obj_New) 
End If 
If Img_Font_Content<>"" then 
Img_Font_X=AspJpeg_Obj_New.Width/2 
Img_Font_Y=AspJpeg_Obj_New.Height-15 
Call Img_Font(AspJpeg_Obj_New) 
End If 
AspJpeg_Obj_New.Sharpen 1, 130 
AspJpeg_Obj_New.Save Img_MathPath_To 
Set AspJpeg_Obj_New=Nothing 
Else 
If Img_Frame_Size>0 then 
Call Img_Pen(AspJpeg_Obj) 
End If 
If Img_Font_Content<>"" then 
Img_Font_X=AspJpeg_Obj.Width/2 
Img_Font_Y=AspJpeg_Obj.Height-15 
Call Img_Font(AspJpeg_Obj) 
End If 
AspJpeg_Obj.Sharpen 1, 130 
AspJpeg_Obj.Save Img_MathPath_To 
End If 
Else 
If Img_Frame_Size>0 then 
Call Img_Pen(AspJpeg_Obj) 
End If 
If Img_Font_Content<>"" then 
Img_Font_X=AspJpeg_Obj.Width/2 
Img_Font_Y=AspJpeg_Obj.Height-15 
Call Img_Font(AspJpeg_Obj) 
End If 
AspJpeg_Obj.Sharpen 1, 130 
AspJpeg_Obj.Save Img_MathPath_To 
End If 
End Function 
'生成水印 
Public Function Img_WaterMark() 
If Not(FileIs(Img_MathPath_From)) then 
Img_WaterMark=Errors(0) 
Exit Function 
End If 
If Img_MathPath_To="" then 
Img_MathPath_To=Img_MathPath_From 
ElseIf Not(FolderIs(UpDir(Img_MathPath_To))) then 
Img_WaterMark=Errors(1) 
Exit Function 
End If 
If CoverIf=0 or CoverIf=false then 
If Img_MathPath_To<>Img_MathPath_From and FileIs(Img_MathPath_To) then 
Img_WaterMark=Errors(2) 
Exit Function 
End If 
End If 
AspJpeg_Obj.Open Img_MathPath_From 
If Img_PicIn_Path<>"" then 
If Not(FileIs(Img_PicIn_Path)) then 
Img_WaterMark=Errors(0) 
Exit Function 
End If 
Set AspJpeg_Obj_New=createObject("Persits.Jpeg") 
AspJpeg_Obj_New.Open Img_PicIn_Path 
AspJpeg_Obj.PreserveAspectRatio = True 
AspJpeg_Obj_New.PreserveAspectRatio = True 
If AspJpeg_Obj.OriginalWidth<Img_Reduce_Size or AspJpeg_Obj.OriginalHeight<Img_Reduce_Size then 
Img_WaterMark=Errors(3) 
Exit Function 
End If 
If AspJpeg_Obj_New.OriginalWidth>AspJpeg_Obj_New.OriginalHeight Then 
AspJpeg_Obj_New.Width=Img_Reduce_Size 
Else 
AspJpeg_Obj_New.Height=Img_Reduce_Size 
End If 
If Img_PicIn_X="" then Img_PicIn_X=AspJpeg_Obj.Width-AspJpeg_Obj_New.Width 
If Img_PicIn_Y="" then Img_PicIn_Y=AspJpeg_Obj.Height-AspJpeg_Obj_New.Height 
AspJpeg_Obj.DrawImage Img_PicIn_X,Img_PicIn_Y,AspJpeg_Obj_New 
Set AspJpeg_Obj_New=Nothing 
End If 
If Img_Frame_Size>0 then 
Call Img_Pen(AspJpeg_Obj) 
End If 
If Img_Font_Content<>"" then 
Call Img_Font(AspJpeg_Obj) 
End If 
'AspJpeg_Obj.Sharpen 1, 130 
AspJpeg_Obj.Save Img_MathPath_To 
End Function 
'生成框架 
Private Function Img_Pen(Obj) 
If Img_Frame_Width=0 then Img_Frame_Width=Obj.Width 
If Img_Frame_Height=0 then Img_Frame_Height=Obj.Height 
Obj.Canvas.Pen.Color = Img_Frame_Color 
Obj.Canvas.Pen.Width = Img_Frame_Size 
Obj.Canvas.Brush.Solid = Img_Frame_Solid 
Obj.Canvas.Bar 1,1,Img_Frame_Width,Img_Frame_Height 
End Function 
'生成水印字 
Private Function Img_Font(Obj) 
Obj.Canvas.Font.Color = Img_Font_Color 
Obj.Canvas.Font.Family = Img_Font_Family 
Obj.Canvas.Font.Quality=Img_Font_Quality 
Obj.Canvas.Font.Size=Img_Font_Size 
Obj.Canvas.Font.Bold = Img_Font_Bold 
Obj.Canvas.Print Img_Font_X,Img_Font_Y,Img_Font_Content 
End Function 
End Class 
%> 
这个类可以公开调用 
1. ImgInfo_Height 取图片高度 
2. ImgInfo_Width 取图片宽度 
调用方法: 


代码如下:

Dim NewObj,Pic_h,Pic_w  
Set NewObj=New AspJpeg  
Pic_h=NewObj.ImgInfo_Height("f:/test.jpg")  
Pic_w=NewObj.ImgInfo_Width("f:/test.jpg")  
Set NewObj=Nothing  
Response.Write "This Picture's Height is "&Pic_h  
Response.Write "This Picture's Width is "&Pic_w  
Response.End

3. Img_Reduce 对指定图片缩小或放大并保存(可选择是否加水印,是否加框架) 
必须定义声明 MathPathFrom,MathPathTo 
默认为缩放至150X150 图案 如按比例缩放后图案小于该尺寸,则补充空白图片 
默认文件自动覆盖 
实例: 


代码如下:

Dim NewObj,NewCommand  
Set NewObj=New AspJpeg  
NewObj.MathPathFrom="f:/test.jpg"  
NewObj.MathPathTo="f:/reduce.jpg"  
NewCommand=NewObj.Img_Reduce  
Set NewObj=Nothing  
If NewCommand<>"" then  
Response.Write "Success"  
Else  
'图片操作过程中出现错误  
Response.Write "Failed"  
End If

4. Img_WaterMark 给指定图片添加水印 
水印可以为图片 文字 或 2者结合

(0)

相关推荐

  • Java语言class类用法及泛化(详解)

    这篇文章主要介绍了Java语言class类用法及泛化(详解),大家都知道Java程序在运行过程中,对所有的对象进行类型标识,也就是RTTI.这项信息记录了每个对象所属的类.虚拟机通常使用运行时类型信息选准正确方法去执行,用来保存这些类型信息的类是Class类.Class类封装一个对象和接口运行时的状态,当装载类时,Class类型的对象自动创建,具体内容介绍如下: 说白了就是: Class类也是类的一种,只是名字和class关键字高度相似.Java是大小写敏感的语言. Class类的对象内容是你创

  • php class类的用法详细总结

    一:结构和调用(实例化): class className{} ,调用:$obj = new className();当类有构造函数时,还应传入参数.如$obj = new className($v,$v2-); 二:构造函数和析构函数: 1.构造函数用于初始化:使用__construct(),可带参数. 2.但析构函数不能带参数(用于在销去一个类之前执行一些操作或功能).析构函数用__destruct()做名称.在脚本执行结束时,会销掉内存中的对象,因此可不用析造函数,但有些比如COOKIE等

  • ASPJPEG综合操作的CLASS类

    <%  'ASPJPEG综合操作CLASS  Class AspJpeg  Dim AspJpeg_Obj,obj  Private Img_MathPath_From,Img_MathPath_To,Img_Reduce_Size,CoverIf  Private Img_Frame_Size,Img_Frame_Color,Img_Frame_Solid,Img_Frame_Width,Img_Frame_Height  Private Img_Font_Content,Img_Font_F

  • PHP实现的简单操作SQLite数据库类与用法示例

    本文实例讲述了PHP实现的简单操作SQLite数据库类与用法.分享给大家供大家参考,具体如下: SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了.它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tcl.PHP.Java等,还有ODBC接口,同样比起MySQL.PostgreSQL这两款开源世界著名

  • 一款简单实用的php操作mysql数据库类

    本文实例讲述了一款简单实用的php操作mysql数据库类.分享给大家供大家参考.具体如下: 复制代码 代码如下: /* 本款数据库连接类,他会自动加载sql防注入功能,过滤一些敏感的sql查询关键词,同时还可以增加判断字段 show table status的性质与show table类 获取数据库所有表名等.*/ @ini_set('mysql.trace_mode','off'); class mysql {  public $dblink;  public $pconnect;  priv

  • PHP实现适用于文件内容操作的分页类

    本文实例为大家分享了PHP实现文件内容操作的分页类,强调一下只针对文件的操作,供大家参考,具体内容如下 <?php class StrPage { private $current; //当前页 private $file; //操作文件 private $totalPage; //总的页数 private $url; //传递的参数 private $pageLen; //每页显示的长度 function __construct( $file,$len = 200 ){ $this->fil

  • C#操作Access通用类实例

    本文实例讲述了C#操作Access通用类.分享给大家供大家参考.具体如下: using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using Syst

  • C#操作session的类实例

    本文实例讲述了C#操作session的类.分享给大家供大家参考.具体分析如下: 这个C#类对session操作进行了再次封装,可以大大简化session的常用操作,同时这个类可以将session值设置为数组,也可以将值读取为数组列表,如果你有这方面的需要可以使用这个类,扩这自己对这个C#类进行扩展. using System.Web; namespace DotNet.Utilities { public static class SessionHelper2 { /// <summary>

  • C#操作CSV文件类实例

    本文实例讲述了C#操作CSV文件类.分享给大家供大家参考.具体分析如下: 这个C#类用于转换DataTable为CSV文件.CSV文件转换成DataTable,如果需要进行CSV和DataTable之间进行转换,使用这个类非常合适. using System.Data; using System.IO; namespace DotNet.Utilities { /// <summary> /// CSV文件转换类 /// </summary> public static class

  • PHP封装类似thinkphp连贯操作数据库Db类与简单应用示例

    本文实例讲述了PHP封装类似thinkphp连贯操作数据库Db类与简单应用.分享给大家供大家参考,具体如下: <?php header("Content-Type:text/html;charset=utf-8"); /** *php操作mysql的工具类 */ class Db{ private $_db = null;//数据库连接句柄 private $_table = null;//表名 private $_where = null;//where条件 private $

  • php curl操作API接口类完整示例

    本文实例讲述了php curl操作API接口类.分享给大家供大家参考,具体如下: <?php namespace curl; /** * Created by PhpStorm. * User: Administrator * Date: 2017/6/16 * Time: 9:54 */ class ApiClient { //请求的token const token='token_str'; //请求url private $url; //请求的类型 private $requestType

  • Java操作XML工具类XmlUtil详解

    本文实例为大家分享了Java操作XML工具类的具体代码,供大家参考,具体内容如下 一.代码 public class XmlUtil { /** * 将XML文件输出到指定的路径 * * @param doc * @param fileName * @throws Exception */ public static void outputXml(Document doc, String fileName) throws Exception { TransformerFactory tf = T

随机推荐