<%
Class ImgWHInfo ''获取图片宽度和高度的类,支持JPG,GIF,PNG,BMP
暗淡ASO
私有子类_初始化
设置 ASO=Server.CreateObject(ADODB.Stream)
ASO.模式=3
ASO.类型=1
ASO开放
结束子
私有子类_终止
错误清除
设置 ASO=无
结束子
私有函数 Bin2Str(Bin)
昏暗的我,Str
对于 I=1 到 LenB(Bin)
克劳=MidB(Bin,I,1)
如果 ASCB(clow)<128 则
Str = Str & Chr(ASCB(克洛))
别的
我=我+1
如果 I <= LenB(Bin) 则 Str = Str & Chr(ASCW(MidB(Bin,I,1)&clow))
结束如果
下一个
Bin2Str = Str
结束功能
私有函数 Num2Str(Num,Base,Lens)
昏暗的雷特
视网膜色素 =
while(Num>=Base)
Ret = (Num Mod Base) & Ret
Num = (Num - Num Mod Base)/基础
文德
Num2Str = Right(字符串(镜头,0) & Num & Ret,镜头)
结束功能
私有函数 Str2Num(Str,Base)
昏暗的雷特,我
保留 = 0
对于 I=1 至 Len(Str)
Ret = Ret *base + Cint(Mid(Str,I,1))
下一个
Str2Num=Ret
结束功能
私有函数 BinVal(Bin)
昏暗的雷特,我
保留 = 0
对于 I = LenB(Bin) 至 1 步骤 -1
Ret = Ret *256 + AscB(MidB(Bin,I,1))
下一个
BinVal=Ret
结束功能
私有函数 BinVal2(Bin)
昏暗的雷特,我
保留 = 0
对于 I = 1 至 LenB(Bin)
Ret = Ret *256 + AscB(MidB(Bin,I,1))
下一个
BinVal2=Ret
结束功能
私有函数 GetImageSize(filespec)
暗淡bFlag
昏暗的雷特(3)
ASO.LoadFromFile(文件规范)
bFlag=ASO.Read(3)
选择案例十六进制(binVal(bFlag))
案例 4E5089:
ASO.阅读(15)
ret(0)=PNG
ret(1)=BinVal2(ASO.Read(2))
ASO.读取(2)
ret(2)=BinVal2(ASO.Read(2))
案例 464947:
ASO.读取(3)
ret(0)=gif
ret(1)=BinVal(ASO.Read(2))
ret(2)=BinVal(ASO.Read(2))
案例 535746:
ASO. 读取(5)
binData=ASO.Read(1)
sConv=Num2Str(ascb(binData),2 ,8)
nBits=Str2Num(左(sConv,5),2)
sConv=中(sConv,6)
while(len(sConv)<nBits*4)
binData=ASO.Read(1)
sConv=sConv&Num2Str(AscB(binData),2 ,8)
文德
ret(0)=SWF
ret(1)=Int(Abs(Str2Num(Mid(sConv,1*nBits+1,nBits),2)-Str2Num(Mid(sConv,0*nBits+1,nBits),2))/20)
ret(2)=Int(Abs(Str2Num(Mid(sConv,3*nBits+1,nBits),2)-Str2Num(Mid(sConv,2*nBits+1,nBits),2))/20)
案例 FFD8FF:
做
执行: p1=binVal(ASO.Read(1)):当 p1=255 而不是 ASO.EOS 时循环
如果 p1>191 且 p1<196 则退出 Do Else ASO.read(binval2(ASO.Read(2))-2)
Do:p1=binVal(ASO.Read(1)):当 p1<255 并且不是 ASO.EOS 时循环
当 True 时循环
ASO.读取(3)
ret(0)=JPG
ret(2)=binval2(ASO.Read(2))
ret(1)=binval2(ASO.Read(2))
其他情况:
如果 left(Bin2Str(bFlag),2)=BM 则
ASO.阅读(15)
ret(0)=BMP
ret(1)=binval(ASO.Read(4))
ret(2)=binval(ASO.Read(4))
别的
ret(0)=
结束如果
结束选择
ret(3)=宽度=&ret(1)&高度=&ret(2)&
获取图像大小=ret
结束功能
公共函数 imgW(IMGPath)
暗淡 FSO、IMGFile、FileExt、Arr
设置 FSO = Server.CreateObject(Scripting.FileSystemObject)
如果 (FSO.FileExists(IMGPath)) 那么
设置 IMGFile = FSO.GetFile(IMGPath)
FileExt=FSO.GetExtensionName(IMGPath)
选择案例文件扩展名
案例 gif、bmp、jpg、png:
Arr=GetImageSize(IMGFile.Path)
imgW = 到达(1)
结束选择
设置 IMGFile=无
别的
图像W = 0
结束如果
设置 FSO=无
结束功能
公共函数 imgH(IMGPath)
暗淡 FSO、IMGFile、FileExt、Arr
设置 FSO = server.CreateObject(Scripting.FileSystemObject)
如果 (FSO.FileExists(IMGPath)) 那么
设置 IMGFile = FSO.GetFile(IMGPath)
FileExt=FSO.GetExtensionName(IMGPath)
选择案例文件扩展名
案例 gif、bmp、jpg、png:
Arr=getImageSize(IMGFile.Path)
imgH = 到达(2)
结束选择
设置 IMGFile=无
别的
图像高 = 0
结束如果
设置 FSO=无
结束功能
结束课程
%>
<%
IMGPath=测试.jpg
设置 PP = 新 ImgWHInfo
W = PP.imgW(服务器.Mappath(IMGPath))
H = PP.imgH(服务器.Mappath(IMGPath))
设置 pp = 无
%>
<%
暗淡 W,PX 高度
Dim Pp '//比例
如果 W=0 或 W= 那么
PX宽度=0
PX高度=0
别的
Pp=FormatNumber(W/H,2) '//长宽比
结束如果
如果 W>=H 则
如果 W>=300 则
PX宽度=300
PX高度=格式编号(300/Pp,0)
别的
PX宽度=W
PX高度=H
结束如果
别的
如果 PHeight>=260 那么
PX高度=260
PX宽度=格式编号(260*Pp,0)
别的
PX宽度=W
PX高度=H
结束如果
结束如果
响应.Write(PXWidth)
%>
<img src=Test.jpg border=0 width=<%=PXWidth%>
高度=<%=PXHeight%>>