zoukankan      html  css  js  c++  java
  • ASPJpeg和ASPUpload组件的一些属性和方法

    自己整理出来的ASPJpeg和ASPUpload组件的一些属性和方法

    aspUpload
    Set Upload = Server.CreateObject("Persits.Upload")
    创建对象
    方法:
    save "path"
    保存到指定路径
    如果不指定路径则保存在内存中
    saveas "path"
    把内存中的文件保存到指定位置
    Upload.CreateDirectory Path, True
    建立文件夹
    Upload.OpenFile(SavePath)
    打开指定路径文件进行操作
    Upload.DeleteFile FilePath
    删除指定文件
    -------------------------------------
    属性:
    Set File = Upload.Files("FILE1")
    创建文件对象
    files
    获取表单文件控件元素,可以用for each 遍历
    For Each File in Upload.Files
     Response.Write File.Name & "= " & File.Path & " (" & File.Size &" bytes)<BR>"
    Next
    file.Filename 获取上传文件名
    File.Ext 获取文件扩展名
    file.path 获取上传保存路径
    file.size 获取上传文件大小
    File.Delete 删除已经上传的文件
    File.Copy 复制一个文件到指定路径
    File.ImageType 指定上传上文件类型默认为GIF, JPEG, BMP, PNG 未知UNKNOWN
    File.ImageWidth 获取上传图片宽
    File.ImageHeight获取上传图片高
    Upload.Form 获取表单所有元素
    File.MD5Hash 使用MD5加密编码,唯一值可做
    File.Binary 将转换过的二进制文件写入数据库
    Upload.CodePage = 65001  支持UTF-8支持中文
    SetMaxSize 字节, True
    最大能上传总字节,同时上传多个时计为总和
    Count = Upload.Save "path"
    获取上传的文件个数
     
     
    一、图片缩略
    <%
    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"
    %>
    <IMG SRC="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") 保存
    %>
     
    三、安全码
    安全玛的道理和加水印差不多,很多朋友问我要具体的代码技术,在这里我就写出来和大家分享,一般人我还不告诉他。呵呵。
    <%
    生成安全码的函数 www.knowsky.com
    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("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") 保存
    %> <img src="infos/random_pic/random_index.bmp" border="0" align="absmiddle">
    自己做做看。呵呵。
     

    四、图片切割
    一直以来,对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") 保存
    怎么样,很简单吧
     
    五、图片合并
    我们这里是要把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,再输入也可以。我个人不大喜欢用sendBinary方法,在网速慢的时候容易出错。在速度方面也不怎样。呵呵。
     
    六、数据库支持
    这里不多说了。其实就是Binary方法,大家知道图片存进数据库只能存为二进制的文件的。所以代码就懒的写了。
     
    七、更多方法介绍
    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
    文字背景
    上次做过图片水印,效果很差,没办法把图片弄成背景透明的,用背景透明gif会自动填充成白色。用去掉某种颜色的功能,图片颜色总是不纯,出来的效果斑斑点点。今天灵机一动,把这两个结合起来,用背景透明的gif,并且抽取水印底色,果然成功了!
        ogvbox.Canvas.Pen.Color  = &H000000  \\\'// 边框的颜色
        ogvbox.Canvas.Pen.Width  = 1    \\\'// 边框的粗细
        ogvbox.Canvas.Brush.Solid = False   \\\'// 图片边框内是否填充颜色
        ogvbox.DrawImage ogvbox.Width-210, ogvbox.Height-74, Logobox  ,0.3,&HFFFFFF    \\\'// 加入图片的位置坐标(添加水印图片),我用图片大小减去水印大小,把水印加在右下角。参数顺序为:水平坐标,垂直坐标,水印图片地址,水银透明度,抽取颜色(&H表示16进制)
        ogvbox.Canvas.Bar 0, 0, ogvbox.Width, ogvbox.Height \\\'// 图片边框线的位置坐标和大小
        ogvbox.Save Server.MapPath(imagename)  \\\'// 生成文件

    \'//------Pollener.com AspJpeg组件的预览和水印生成------开始------
    \'创建预览图片:call CreateView(原始文件的路径,预览文件名及路径)
    Sub CreateView(imagename,tempFilename)
    \'定义变量。
    Dim PreviewImageFolderName
    Dim ogvbox,objFont
    Dim Logobox,LogoPath
    LogoPath = Server.MapPath("images") & "\\shuiyin.gif"  \'//加入图片所在路径及文件名(我的是论坛\\images\\shuiyin.gif)。
    Select Case upload_ViewType
    Case 0
    \'---------------------CreatePreviewImage---------------
    set ogvbox = Server.CreateObject("CreatePreviewImage.cGvbox")
    ogvbox.SetSavePreviewImagePath=Server.MapPath(tempFilename)   \'预览图存放路径。
    ogvbox.SetPreviewImageSize =SetPreviewImageSize      \'预览图宽度。
    ogvbox.SetImageFile = trim(Server.MapPath(imagename))    \'imagename原始文件的物理路径。
    \'创建预览图的文件。
    If ogvbox.DoImageProcess=false Then
    Response.write "生成预览图错误:"& ogvbox.GetErrString
    End If
    Case 1
    \'---------------------AspJpegV1.2---------------
    Set Logobox = Server.CreateObject("Persits.Jpeg")
    \'//建议不要图片和文字水印同时使用,本代码为使用图片水印。
    Logobox.Open LogoPath  \'//读取添加的图片。
    \'//重新设置图片的大小。
    Logobox.Width = 186  \'//用做水印的图片的宽度值(像素)。
    Logobox.Height = 52  \'//用做水印的图片的高度值(像素)。
    \'//添加水印。
    Set ogvbox = Server.CreateObject("Persits.Jpeg")
    \'//读取要处理的原文件。
    ogvbox.Open Trim(Server.MapPath(imagename))
    If ogvbox.OriginalWidth<Cint(ImageWidth) or ogvbox.Originalheight<Cint(ImageHeight) Then
      F_Viewname=""
      Set ogvbox = Nothing
      Exit Sub
    Else
    IF ImageMode<>"" and FileExt<>"gif" Then  \'//如果将这行改为IF ImageMode<>"" Then则可给上传的GIF图片也加上水印,但是那些动画的GIF在加了水印以后就只剩第一桢了,根据你的需求酌情处理吧。
    \'//关于修改字体及文字颜色的。
    \'//ogvbox.Canvas.Font.Color = &H0000FF  \'//水印文字的颜色,&H后面输入色彩值。
    \'//ogvbox.Canvas.Font.Size = 18  \'//水印文字的大小。
    \'//ogvbox.Canvas.Font.Family = "Arial"  \'//水印文字的字体名称。
    \'//ogvbox.Canvas.Font.ShadowColor = &H000000  \'//水印文字的阴影色彩。
    \'//ogvbox.Canvas.Font.ShadowXoffset = 1  \'//水印文字阴影向右偏移的像素值,输入负值则向左偏移。
    \'//ogvbox.Canvas.Font.ShadowYoffset = 1  \'//水印文字阴影向下偏移的像素值,输入负值则向右偏移。
    \'//ogvbox.Canvas.Font.Quality = 3  \'//水印文字的清晰度,从0~4,变换不是很大,建议用2或3。
    \'//ogvbox.Canvas.Font.Bold = True  \'//水印文字是否为粗体,True=粗体 False=正常。
    \'ogvbox.Canvas.Print 10, 10, ImageMode  \'//水印文字的起始坐标(像素)。
    ogvbox.Canvas.Pen.Color  = &H000000  \'//增加水印后图片的边框色彩。
    ogvbox.Canvas.Pen.Width  = 1   \'//增加水印后图片的边框宽度。
    ogvbox.Canvas.Brush.Solid = False  \'//边框内是否填充颜色,你可以试试看值为True时的效果^o^
    ogvbox.DrawImage ogvbox.width-186, ogvbox.height-52, Logobox, 0.5  \'//水印图片的起始坐标,我这里ogvbox.width-186, ogvbox.height-52,表示图片在右下角,因为我的图片宽是186,高是52,所以这样写,你可以根据自己的图片进行调整。0.5是透明度,我这里是半透明,1表示不透明,你也可以试试看0.7或者0.8的效果。
    ogvbox.Canvas.Bar 0, 0, ogvbox.Width, ogvbox.Height  \'//水印可用的范围。我这里表示左上角至右下角,即整张图片的任意为止都可加水印。
    ogvbox.Save Server.MapPath(imagename)  \'//根据以上参数生成增加水印后的图片文件。
       End If
       ogvbox.Width = ImageWidth
       ogvbox.height = ImageHeight
       \'ogvbox.height = ogvbox.Originalheight*ImageWidth\\ogvbox.OriginalWidth
       ogvbox.Sharpen 1, 120
       ogvbox.Save Server.MapPath(tempFilename)  \'//生成增加水印后的图片的预览图片。
      End If
      Set Logobox=Nothing
     
    <%
    \'函数功能:远程图片自动保存到本地服务器,并利用aspjpeg为图片加上水印
    \'(注意:请先在目录下创建images目录,用来保存临时图片)
    \'程序落伍者:我是星星
    \'加入落伍第二份原创程序,HOHO,今天一定要落伍类,5.6日注册,5.7日落伍,庆祝一下!
    \'本程序需要在服务器上安装"aspjpeg组件"否则无法正常使用
    \'也可以只取\'\'\'\'\'22222222\'\'\'\'\'\'\'以上的部分,这部分可以保存图片,第二部分是进行水印增加
    \'使用方法,请保存为saveimg.asp
    \'saveimg.asp?url=UploadFile/2005-6/2005615155335734.gif  即可以取下图片啦,HOHO. 其他需要加的功能,大家自己扩展好啦
    \'如何获取其他后缀名的文件呢? 当然也可以啦
    \'(jpg|gif|png|bmp)改成(mp3)明白吧? 就是取mp3后缀的文件名.以此类推. 嘻嘻
    \'俺要落伍. 发了二份原创,一份是惊云下载系统偷天空时防止出现连接来自天空软件站的程序,有需要的在落伍里面搜索我的贴子
    \'不要忘了使用时在目录下建images的保存目录哦
    Server.ScriptTimeOut=99999
    const savepath="images" \'图片保存路径
    url=request("url")
     
    function myreplace(str)
    newstr=str
    set objregEx = new RegExp
    objregEx.IgnoreCase = true
    objregEx.Global = true
    objregEx.Pattern = "http://(.+?)\\.(jpg|gif|png|bmp)" \'定义文件后缀
    set matches = objregEx.execute(str)
    for each match in matches
    newstr=replace(newstr,match.value,saveimg(match.value))
    next
    myreplace=newstr
    end function
    function saveimg(url)
    temp=split(url,".")
    \'以下是用时间与随机数重命名文件名
    randomize
    ranNum=int(90000*rnd)+10000
    filename=year(now)&month(now)&day(now)&hour(now)&minute(now)&second(now)&ranNum&"."&temp(ubound(temp))
    \'文件名重命名结束
    set xmlhttp=server.createobject("Microsoft.XMLHTTP")
    xmlhttp.open "get",url,false
    xmlhttp.send
    img=xmlhttp.ResponseBody
    set xmlhttp=nothing
    set objAdostream=server.createobject("ADODB.Stream")
    objAdostream.Open()
    objAdostream.type=1
    objAdostream.Write(img)
    objAdostream.SaveToFile(server.mappath(savepath&filename))
    objAdostream.SetEOS
    set objAdostream=nothing
    \'\'\'\'\'\'\'222222222\'\'\'\'\'\'\'\'\'\'\'
    saveimg=savepath&filename \'获取保存路径
    Dim Jpeg
    Set Jpeg = Server.CreateObject("Persits.Jpeg")
    Jpeg.Open Server.MapPath(saveimg) \'打开保存图片的路径
    \' 添加文字水印
    Jpeg.Canvas.Font.Color = &HFF0000\' 红色
    Jpeg.Canvas.Font.Family = "宋体"
    Jpeg.Canvas.Font.Bold = True 
    Jpeg.Canvas.Print Jpeg.OriginalWidth-200,Jpeg.OriginalHeight-50, "www.sina.com"  \'水印离左边的距离,离顶端的距离,这个是放在右下脚了
    \'保存文件
    Jpeg.Save Server.MapPath(saveimg) \'保存添加水印后的图片
    \' 注销对象
    Set Jpeg = Nothing
    end function
    %>

    Set objImg = Server.CreateObject("Persits.Jpeg")
    objImg.Interpolation = 2
    \\\'影像加强 0-2
    objImg.open xFilePath
    response.write "<:::原始值:::>
    AspJpeg版本=" & objImg.Version & "
    宽=" & objImg.OriginalWidth & "像素
    " & "高=" & objImg.OriginalHeight & "像素
    "
    response.write "品质=" & objImg.Quality & " (0-100)
    " & "路径=" & objImg.Version & "
    "
    \\\'objImg.Width = objImg.OriginalWidth / 2
    \\\'变更图片宽度(范例为50%)
    \\\'objImg.Height = objImg.OriginalHeight / 2
    \\\'变更图片高度(范例为50%)
    \\\'objImg.Sharpen 2, 250
    \\\'锐利处理
    \\\'objImg.Crop 0,0,150,150
    \\\'切割处理
    \\\'objImg.FlipH
    \\\'左右翻转
    \\\'objImg.FlipV
    \\\'上下翻转
    \\\'objImg.RotateL
    \\\'向左旋转90度
    \\\'objImg.RotateR
    \\\'向右旋转90度
    \\\' 将图片秀上文字:------------------------
    objImg.Canvas.Font.Color = &HFF0000
    \\\'颜色
    objImg.Canvas.Font.Family = "细明体"
    \\\'字型
    objImg.Canvas.Font.Bold = True
    \\\'是否使用粗体
    objImg.Canvas.Font.BkMode = False
    \\\'是否使用字体背景色
    objImg.Canvas.Font.BkColor = &H000000
    \\\'字体背景色
    objImg.Canvas.Font.Italic = False
    \\\'是否使用斜体字
    objImg.Canvas.Font.Rotation = 0
    \\\'字体旋转角度
    objImg.Canvas.Font.ShadowColor = &H000000
    \\\'字影颜色
    objImg.Canvas.Font.ShadowXOffset = 50
    \\\'字影X坐标
    objImg.Canvas.Font.ShadowYOffset = 150
    \\\'字影Y坐标
    objImg.Canvas.Font.Size = 14
    \\\'字体大小
    objImg.Canvas.Font.Underlined = True
    \\\'是否加底限
    objImg.Canvas.Circle 100,100,10
    \\\'画圆圈
    objImg.Canvas.Pen.Color = &H009900
    \\\'画圆的圆内填满颜色
    objImg.Canvas.Pen.Width = 1
    \\\'画圆的圆周粗细值
    objImg.Canvas.Ellipse 0,0,150,150
    \\\'画椭圆
    objImg.Canvas.Line 0,0,150,150
    \\\'画线
    \\\'objImg.Canvas.Arc = 100,50,0,200
    \\\'---不清楚这个用法--
    objImg.Canvas.Print 100, 100, "I am Odysseus" ,136
    \\\'位置及文字---------------------------------

    \\\' 编辑图片外框:----------------------------
    objImg.Canvas.Pen.Color = &H000000
    \\\'图片外框颜色
    objImg.Canvas.Pen.Width = 1
    \\\'图片外框宽度(像素)
    objImg.Canvas.Brush.Solid = False
    \\\'是否使用区域内填满
    objImg.Canvas.Brush.Color = &HFF0000
    \\\'区域内填满颜色
    objImg.Canvas.Bar 5, 5, objImg.Width, objImg.Height
    \\\'框线产生位置------------------------------
    objImg.save xFileCopyToPath
    response.write "<:::变化后:::>
    宽=" & objImg.Width & "像素
    " & "高=" & objImg.Height & "像素
    "
    Set objImg = Nothing
  • 相关阅读:
    内核驱动系列中断和定时器
    apue2 阅读笔记第四章
    apue2 阅读笔记 第五章
    apue2阅读笔记 第6.7章
    再试试windows7版得writer
    内核驱动系列内核调试方法
    apue2 阅读笔记第三章
    杂谈关于代码库
    know everything about something
    React的父子传值(父传子)
  • 原文地址:https://www.cnblogs.com/happyday56/p/971311.html
Copyright © 2011-2022 走看看