[转贴]取得上传图片大小

此博客展示了一段代码,用于获取图片的宽度和高度。代码中定义了 imgInfo 类,包含多个私有函数用于二进制数据处理、数值转换等,还定义了公共函数 imgW 和 imgH 来获取图片的宽高,支持 GIF、BMP、JPG、PNG 等格式。

<% 
imgpath="default_22.jpg"

 set  pp=new  imgInfo 
 w = pp.imgW(server.mappath(imgpath)) 
 h = pp.imgH(server.mappath(imgpath))
 set pp=nothing
 
response.write "<img src='"&imgpath&"' border=0><br>宽:"&w&";高:"&h


Class  imgInfo 
 dim  aso 
 Private  Sub  Class_Initialize 
   set  aso=CreateObject("Adodb.Stream") 
   aso.Mode=3   
   aso.Type=1   
   aso.Open   
 End  Sub 
 Private  Sub  Class_Terminate
   err.clear
   set  aso=nothing 
 End  Sub 
 
 Private  Function  Bin2Str(Bin) 
   Dim  I,  Str 
   For  I=1  to  LenB(Bin) 
     clow=MidB(Bin,I,1) 
     if  ASCB(clow)<128  then 
       Str  =  Str  &  Chr(ASCB(clow)) 
     else 
       I=I+1 
       if  I  <=  LenB(Bin)  then  Str  =  Str  &  Chr(ASCW(MidB(Bin,I,1)&clow)) 
     end  if 
   Next   
   Bin2Str  =  Str 
 End  Function 
  
 Private  Function  Num2Str(num,base,lens) 
   dim  ret 
   ret  =  "" 
   while(num>=base) 
     ret  =  (num  mod  base)  &  ret 
     num  =  (num  -  num  mod  base)/base 
   wend 
   Num2Str  =  right(string(lens,"0")  &  num  &  ret,lens) 
 End  Function 
  
 Private  Function  Str2Num(str,base) 
   dim  ret 
   ret  =  0 
   for  i=1  to  len(str) 
     ret  =  ret  *base  +  cint(mid(str,i,1)) 
   next 
   Str2Num=ret 
 End  Function 
  
 Private  Function  BinVal(bin) 
   dim  ret 
   ret  =  0 
   for  i  =  lenb(bin)  to  1  step  -1 
     ret  =  ret  *256  +  ascb(midb(bin,i,1)) 
   next 
   BinVal=ret 
 End  Function 
  
 Private  Function  BinVal2(bin) 
   dim  ret 
   ret  =  0 
   for  i  =  1  to  lenb(bin) 
     ret  =  ret  *256  +  ascb(midb(bin,i,1)) 
   next 
   BinVal2=ret 
 End  Function 
  
 Private  Function  getImageSize(filespec)   
   dim  ret(3) 
   aso.LoadFromFile(filespec) 
   bFlag=aso.read(3) 
   select  case  hex(binVal(bFlag)) 
   case  "4E5089": 
     aso.read(15) 
     ret(0)="PNG" 
     ret(1)=BinVal2(aso.read(2)) 
     aso.read(2) 
     ret(2)=BinVal2(aso.read(2)) 
   case  "464947": 
     aso.read(3) 
     ret(0)="GIF" 
     ret(1)=BinVal(aso.read(2)) 
     ret(2)=BinVal(aso.read(2)) 
   case  "535746": 
     aso.read(5) 
     binData=aso.Read(1) 
     sConv=Num2Str(ascb(binData),2  ,8) 
     nBits=Str2Num(left(sConv,5),2) 
     sConv=mid(sConv,6) 
     while(len(sConv)<nBits*4) 
       binData=aso.Read(1) 
       sConv=sConv&Num2Str(ascb(binData),2  ,8) 
     wend 
     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) 
   case  "FFD8FF": 
     do   
       do:  p1=binVal(aso.Read(1)):  loop  while  p1=255  and  not  aso.EOS 
       if  p1>191  and  p1<196  then  exit  do  else  aso.read(binval2(aso.Read(2))-2) 
       do:p1=binVal(aso.Read(1)):loop  while  p1<255  and  not  aso.EOS 
     loop  while  true 
     aso.Read(3) 
     ret(0)="JPG" 
     ret(2)=binval2(aso.Read(2)) 
     ret(1)=binval2(aso.Read(2)) 
   case  else: 
     if  left(Bin2Str(bFlag),2)="BM"  then 
       aso.Read(15) 
       ret(0)="BMP" 
       ret(1)=binval(aso.Read(4)) 
       ret(2)=binval(aso.Read(4)) 
     else 
       ret(0)="" 
     end  if 
   end  select 
   ret(3)="width="""  &  ret(1)  &"""  height="""  &  ret(2)  &"""" 
   getimagesize=ret 
 End  Function 
  
 Public Function  imgW(pic_path) 
     Set  fso1  =  server.CreateObject("Scripting.FileSystemObject") 
     If (fso1.FileExists(pic_path)) Then
   Set  f1  =  fso1.GetFile(pic_path) 
   ext=fso1.GetExtensionName(pic_path) 
   select  case  ext 
    case  "gif","bmp","jpg","png": 
     arr=getImageSize(f1.path) 
     imgW = arr(1) 
   end  select 
   Set  f1=nothing
  else
      imgW = 0
  End if  
     Set  fso1=nothing 
 End  Function 
 
 Public Function  imgH(pic_path) 
     Set  fso1  =  server.CreateObject("Scripting.FileSystemObject")
  If (fso1.FileExists(pic_path)) Then
   Set  f1  =  fso1.GetFile(pic_path) 
   ext=fso1.GetExtensionName(pic_path) 
   select  case  ext 
    case  "gif","bmp","jpg","png": 
     arr=getImageSize(f1.path) 
     imgH = arr(2) 
   end  select 
   Set  f1=nothing 
  else
   imgH = 0
  End if 
     Set  fso1=nothing 
 End  Function 
End  Class

%>

下载方式:https://pan.quark.cn/s/b4d8292ba69a 在构建食品品牌的市场整合营销推广方案时,我们必须首先深入探究品牌的由来、顾客的感知以及市场环境。 此案例聚焦于一款名为“某饼干产品”的食品,该产品自1998年进入河南市场以来,经历了销售业绩的波动。 1999至2000年期间,其销售额取得了明显的上升,然而到了2001年则出现了下滑。 在先前的宣传活动中,品牌主要借助大型互动活动如ROAD SHOW来吸引顾客,但收效甚微,这揭示了宣传信息与顾客实际认同感之间的偏差。 通过市场环境剖析,我们了解到消费者对“3+2”苏打夹心饼干的印象是美味、时尚且充满活力,但同时亦存在口感腻、价位偏高、饼身坚硬等负面评价。 实际上,该产品可以塑造为兼具美味、深度与创新性的休闲食品,适宜在多种情境下分享。 这暗示着品牌需更精确地传递产品特性,同时消解消费者的顾虑。 在策略制定上,我们可考虑将新产品与原有的3+2苏打夹心进行协同推广。 这种策略的长处在于能够借助既有产品的声誉和市场占有率,同时通过新产品的加入,刷新品牌形象,吸引更多元化的消费群体。 然而,这也可能引发一些难题,例如如何合理分配新旧产品间的资源,以及如何保障新产品的独特性和吸引力不被既有产品所掩盖。 为了提升推广成效,品牌可以实施以下举措:1. **定位修正**:基于消费者反馈,重新确立产品定位,突出其美味、创新与共享的特性,减少消费者感知的缺陷。 2. **创新宣传**:宣传信息应与消费者的实际体验相契合,运用更具魅力的创意手段,例如叙事式营销,让消费者体会到产品带来的愉悦和情感共鸣。 3. **渠道选择**:在目标消费者常去的场所开展活动,例如商业中心、影院或在线平台,以提高知名度和参与度。 4. **媒体联...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值