有时候我们需要实现一个按比例缩放的Image控件,因为在Web上的<image> 当设定了宽度和高度的时候,如果图片本身的长宽比跟它俩的比值不一样,那么图片就变形了。
下面的这个控件派生于System.Web.UI.WebControls.Image,它重写了RenderBeginTag、AddAttributesToRender和RenderEndTag方法,使Image呈现成一个DIV,DIV里面包一个跟实际图片比例完全相同的Image,变相地实现了一个按比例缩放的Image。
使用:
<
style
>
.imagecss
{
background-color
:
#D7CEE9
;
}
</
style
>
<
cc1:AutoSizeImageControl
ID
="AutoSizeImageControl1"
DivCSS
="imagecss"
Align
="center"
VAlign
="middle"
Width
="400"
Height
="600"
IsAutoZoom
="true"
ImageUrl
="Waterlilies.jpg"
runat
="server"
/>
呈现的HTML
<
div
class
="imagecss"
align
="center"
style
="TABLE-LAYOUT:fixed;width:400px;height:600px;TEXT-OVERFLOW:ellipsis;"
>
<
img
id
="AutoSizeImageControl1"
src
="Water%20lilies.jpg"
style
="height:300px;width:400px;border-width:0px;padding-top:150px"
/></
div
>
图片的原始大小为 300×400,但Image的宽度为400×600,效果如下:
源文件 下载
下面的这个控件派生于System.Web.UI.WebControls.Image,它重写了RenderBeginTag、AddAttributesToRender和RenderEndTag方法,使Image呈现成一个DIV,DIV里面包一个跟实际图片比例完全相同的Image,变相地实现了一个按比例缩放的Image。
使用:
data:image/s3,"s3://crabby-images/27624/27624eab42560442f038bc4037a34897f0a34e1c" alt=""
data:image/s3,"s3://crabby-images/6caa2/6caa24945ede236ed3a00eb2aa05e0dbe73f2cc8" alt=""
data:image/s3,"s3://crabby-images/e741f/e741f1886df64976fcf7dc86f960fa33c48fa0d0" alt=""
data:image/s3,"s3://crabby-images/6caa2/6caa24945ede236ed3a00eb2aa05e0dbe73f2cc8" alt=""
data:image/s3,"s3://crabby-images/bf0ab/bf0ab75e981cff85c0a167a4e1bc7b3b8b7617e5" alt=""
data:image/s3,"s3://crabby-images/ef738/ef7383c0cebcea895e00d7746c465b4e3d38981a" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/3b107/3b107162e0ad9494a3b10416a6180754a4893d2d" alt=""
data:image/s3,"s3://crabby-images/47820/47820d81b6555f1701a1331c8a8f4ae4593cd6eb" alt="实现一个按比例缩放的Image服务器控件"
源文件 下载