在网页上显示数据库中读出来的图片,因为在数据库中的图片大小各不相同
而我在页面上的div宽度设置在595,高度设置在196,如果数据库中的图片比
这个宽度和高度要小必须填满,如果要比这个大必须缩放到这个宽度和高度
还有一种可能如果图片是正方形,不必要填满,但是要按等比例缩放进这个div
也就是说正方形还是正方形,在div里显示的是放大或缩小的正方形图片,有没有高手
帮我解这个算法,谢谢了!

解决方案 »

  1.   

    <script language="JavaScript">
    //图片按比例缩放,可输入参数设定初始大小   
    function resizeimg(ImgD,iwidth,iheight) {   
         var image=new Image();   
         image.src=ImgD.src;   
         if(image.width>0 && image.height>0){   
            if(image.width/image.height>= iwidth/iheight){   
               if(image.width>iwidth){   
                   ImgD.width=iwidth;   
                   ImgD.height=(image.height*iwidth)/image.width;   
               }else{   
                      ImgD.width=image.width;   
                      ImgD.height=image.height;   
                    }   
                   ImgD.alt=image.width+"×"+image.height;   
            }   
            else{   
                    if(image.height>iheight){   
                           ImgD.height=iheight;   
                           ImgD.width=(image.width*iheight)/image.height;   
                    }else{   
                            ImgD.width=image.width;   
                            ImgD.height=image.height;   
                         }   
                    ImgD.alt=image.width+"×"+image.height;   
                }   
         ImgD.style.cursor= "pointer"; //改变鼠标指针   
         ImgD.onclick = function() { window.open(this.src);} //点击打开大图片   
            if (navigator.userAgent.toLowerCase().indexOf("ie") > -1){    
            //判断浏览器,如果是IE   
            ImgD.title = "请使用鼠标滚轮缩放图片,点击图片可在新窗口打开";   
            ImgD.onmousewheel = function img_zoom() //滚轮缩放   
          {   
              var zoom = parseInt(this.style.zoom, 10) || 100;   
              zoom += event.wheelDelta / 12;   
              if (zoom> 0) this.style.zoom = zoom + "%";   
              return false;   
          }   
         } else { //如果不是IE   
                ImgD.title = "点击图片可在新窗口打开";   
             }   
        }   
    }  
    </script>
    <img src ="E:/编程语言排行榜.jpg" onload="javascript:resizeimg(this,800,600)"> 
      

  2.   

    可以利用js来验证  用一个div 小了就放大填满div  
      

  3.   

    非ie浏览器可用css中 max-width;max-height 来控制 ie下就需要自己写算法了  自带的那总好像比较耗性能!
      

  4.   

    我以前做了个头像上传,里面带有图片剪裁、压缩与放大(包括等比) 如需要发邮件给我吧。[email protected]