image控件又称图像控件,主要用来显示用户的图片或图像信息。
一、属性
表1 image控件常用属性及说明
属性 |
说明 |
id |
控件id |
imagealign |
获取或设置image控件相对于网页上其他元素的对齐方式 |
imageurl |
获取或设置在image控件中显示的图像的位置 |
width |
控件的宽度 |
visible |
控件是否可见 |
cssclass |
控件呈现的样式 |
backcolor |
控件的背景颜色 |
enabled |
控件是否可用 |
image控件的大部分属性和label控件类似,在此主要讲解一下其imageurl属性设置。
imageurl属性用来获取image控件中要显示图像的地址,在设置该属性时,单击imageurl属性文本框后面的图标按钮,弹出一个如图1所示的“选择图像”对话框,用户可以选择要显示的图像。
图1 “选择图像”对话框
二、方法
image控件常用方法同label控件类似,具体请参见label控件常用方法。这里主要介绍一下该控件的resolveurl方法,resolveurl方法主要用来将url转换为在请求客户端可用的url。
例如,要使用resolveurl方法设置一个image控件的链接图像路径,可以编写如下代码。
image1.imageurl = resolveurl(~/image/image1.gif);
三、事件
image控件常用事件同label控件类似,具体请参见label控件常用事件。
四、示例
示例:
image控件示例
下面示例主要通过设置image控件的imageurl属性在该控件上显示链接图片。新建一个网站,默认主页为default.aspx,在default.aspx页面上添加一个image控件,其属性设置如表2所示。
表2 image控件属性设置
属性名称 |
属性值 |
id |
imageurl |
imageurl |
~/image/image1.gif(链接图片) |
imagealign |
middle(居中对齐) |
执行程序,示例运行结果如图2所示。
图2 image控件示例
程序完整代码如下:
default.aspx.cs代码文件
using system;
using system.data;
using system.configuration;
using system.web;
using system.web.security;
using system.web.ui;
using system.web.ui.webcontrols;
using system.web.ui.webcontrols.webparts;
using system.web.ui.htmlcontrols;
public partial class _default : system.web.ui.page
{
protected void page_load(object sender, eventargs e)
{
}
}
default.aspx 设计文件
<%@ page language="c#" autoeventwireup="true" codefile="default.aspx.cs" inherits="_default" %>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "">
<html xmlns="" >
<head runat="server">
<title>image控件示例</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:image id="image1" runat="server" height="177px" imagealign="middle"
imageurl="~/image/image1.gif" width="121px" />
</div>
</form>
</body>
</html>
五、扩展
image控件当没有图片时,显示"红色的x" 不够友好,可以设置其alternatetext属性,也可以显示指定的图片
1.普通显示
string str ="~/img/"+int.parse(textbox1.text)+".gif";
if (!file.exists(server.mappath(str)))//不存在时显示nophoto.gif
{
image1.imageurl = "~/img/nophoto.gif";
//response.write("bucunzai");
}
else//有的时候显示
{
image1.imageurl = str;
//response.write("cunzai");
}
2.还有一种可能是从数据库中读取二进制的图片时(红色部分需要从数据库中读取)
byte [] b=....;//从数据库中读取
if (b == null || b.length == 0)
{
//当没有图片数据时显示默认的图片nophoto.gif
filestream fs = new filestream(server.mappath("~/management/images/nophoto.gif"), filemode.open, fileaccess.read);
byte[] mydata = new byte[fs.length];
int length = convert.toint32(fs.length);
fs.read(mydata, 0, length);
fs.close();
this.response.outputstream.write(mydata, 0, length);
this.response.end();
}
else
{
response.contenttype = ...;//从数据库中读取图片的后缀名
response.outputstream.write(b, 0, b.length);
}
如对本文有疑问,
点击进行留言回复!!
相关文章:
-
-
-
-
-
.Net 异常记录
工作上什么不顺的bug就记录在这吧。。。。。。 1,空异常会常常考虑到,但是这里容易报一个序列不包含任何元素异常,假如dt没有行。 dt.AsEnume...
[阅读全文]
-
-
一秒扫雷
可以直接用CE进行雷总数修改,下面是通过C#直接修改雷总数内存地址 /// PROCESS_ALL_ACCESS -> (STANDARD_RIG...
[阅读全文]
-
-
-
-
网友评论