预览模式: 普通 | 列表

aspjpeg组件用法

一、图片缩略

<%
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
文字背景

Tags: asp

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 2594

aspupload 上传乱码问题

最近开发博客的时候由于用的是utf-8编码,上传图片的时候发现如果图片名是中文的时候上传的时候出现乱码,查了好多的地方,发现utf-8下aspupload容易出现以下几个问题:

aspupload组件在UTF-8编码下上传文件保存路径包含中文出错。
aspupload组件处理多选列表框中提交的多个值只能取到第一个。
提交的文本框中通过aspupload的form集合获取来的值都是乱码。
其实解决的方法很简单:

1、在UTF-8的页面头部声明此文档的编码类型为utf-8的:

<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%>
<%Session.CodePage=65001%>
<%Response.Charset="utf-8"%>

查看更多...

Tags: asp aspupload

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 3641

ASPUpload获取表单元素的说明

众所周知,ASPUpload可以用来上传文件至服务器,当然,也可以用来获取表单元素的内容。前几天测试学习ASPUpload组件时一般都在上传文件的同时混有表单元素的传送,也没出现什么问题,今天突然想如果只用ASPUpload获取表单元素内容而没有上传文件,那可不可以不用调用Save方法?输入下边代码进行测试:
 

 程序代码
<%
Dim Upload,Upfile
Set Upload = Server.CreateObject("Persits.Upload")
Response.Write(Upload.Form("text1"))
Set Upload = nothing
%>



结果无法取到表单text1的值,加入Upload.Save后就正常了:
 

 程序代码
<%
Dim Upload,Upfile
Set Upload = Server.CreateObject("Persits.Upload")
Upload.Save
Response.Write(Upload.Form("text1"))
Set Upload = nothing
%>



是不是在调用Form方法前必须先得调用Save方法?网上搜索了一番,最终在CSDN上看到了一句话:We must call Upload.Save or SaveVirtual before we can use Upload.Form!,在ASPUpload安装文件夹中搜索此句,位于Samples\02_simple\UploadScript3.asp第16行,此行为一注释语句。

Tags: asp aspupload

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 3567

最近为这两个事件对于多窗口浏览器和单窗口浏览器的问题郁闷了两天....现在总结下来.希望对郁闷中的朋友有用!

以下是指在js中实现,而非 <body onunload="close()"> 这种方法!
因为这样是在unload掉body的时候触发,而无聊任何浏览器,都会在关闭的时候unload掉body的!

模型1:
function close(){ 
alert("sdfsdfsdf");

window.onbeforeunload=close;

模型2:
function close(){ 
if(document.body.clientWidth-event.clientX< 170&&event.clientY< 0||event.altKey) 

alert("sdfsdfsdf");
}  

window.onbeforeunload=close;

查看更多...

Tags: javascript

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 4061

onbeforeunload和onunload用法

   onunload是在页面刷新或关闭时调用,可以在<script>脚本中通过window.onunload来指定到用户自定义函数,也可以在body里面指定。
   onbeforeunload是则也是在页面刷新或关闭时调用,不过是在onunload之前执行。它可以阻止onunload的执行。

   onunload和onbeforeunload的区别在于,onbeforeunload是在onunload之前调用的,可以在onbeforeunload指定的函数里面进行一个确认操作,如果确认执行,则页面会执行onunload里面指定的函数,即刷新或关闭页面;如果取消操作,则不会执行onunload指定的函数,也不会进行刷新或关闭页面。这种情况适用于当用户要离开一个网页时使用。下面是一个例子:

<html>
 <head>
  <script type="text/javascript">
   function whenUnload()
   {
    alert("触发了onunload");
   }

   function whenBeforeUnload()
   {
    return "确认离开?";               // 这句话显示在确认对话框中
    //alert("触发了onbeforeunload");   // 也可以执行其它逻辑
   }

查看更多...

Tags: javascript

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 7630

再回首——百度之死

再回首--百度之死
原唱:姜育恒
再回首
百度不再收
再回首
全部K了
今夜不会再有难舍的旧梦
曾经做的那网站
今后要向谁诉说
再回首
百度已远走
再回首
泪眼朦胧
留下你的蜘蛛
每天来爬网
不管怎么爬也不再更新
曾经在幽幽暗暗反反复复中追问
才知道平平淡淡从从容容是最真
再回首恍然如梦
再回首我心已死
只有那无数的蜘蛛伴着我

Tags: 百度

分类:随笔杂记 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 3270

 广告位

↑返回顶部↑