选择显示字体大小

用asp.net创建网络相册

在现在的数码时代,我们会经常拍摄一些相片以供留念,而随着数码照片的增多,往往需要很好地管理这些照片,以便更好地查阅留念。现在网上有不少的电子相册,都能很好的实现这些功能,那我们能否自己动手创建自己的相册呢?当然可以,在这篇文章中,我们将利用asp.net,来创建一个简单的在线相册,以收藏我们的照片。

  首先来看下,这个相册有哪些功能。在这个相册中,我们必须先把预先摄影好的照片放到一个目录下去,之后,可以供在网上使用“上一张,下一张”的链接一张张地查看。

  下面先介绍如何获得文件夹中的图片。我们可以使用system.io命名空间中的directoryinfo类来实现。将文件夹所在的路径做为参数传递到该类的构造函数中,并声明一个directoryinfo类的实例。directoryinfo类中有一个getfiles()的方法,会返回fileinfo的对象数组,而每一个fileinfo的实例将包含指定路径下文件的具体信息。下面的代码片段说明了该过程:

sub page_load(sender as object, e as eventargs)
 'get list of images
 dim dirinfo as new directoryinfo(server.mappath(""))
 dim images() as fileinfo = filterforimages(dirinfo.getfiles())
 ...

end sub

  其中,用server.mappath获得当前目录的路径,而dirinfo.getfiles()将会返回该目录下的所有文件。而由于我们的是相册,只需要看到比如jpg,bmp,gif等图象文件,所以我们可以通过程序实现,只装载这些类型的文件,这通过一个自定义的过程filterforimages来实现,该过程将只返回指定文件夹中图象类型的文件。代码如下:

function filterforimages(images() as fileinfo) as fileinfo()
 dim newimages as new arraylist(images.length)

 dim i as integer
 for i = 0 to images.length - 1
  if path.getextension(images(i).name) = ".jpg" orelse _
   path.getextension(images(i).name) = ".jpeg" orelse _
   path.getextension(images(i).name) = ".png" orelse _
   path.getextension(images(i).name) = ".gif" then
    newimages.add(images(i))
  end if
 next

 return ctype(newimages.toarray(gettype(fileinfo)), fileinfo())
end function

  该过程对于传递进来的fileinfo参数数组进行遍历,对文件夹中的文件的后缀名进行叛断,如果属于图象文件,则添加到newimages数组中去,并以arraylist形式返回。
  接下来,我们看下如何显示每一张图片,并以“上一张,下一张”来显示。为了知道当前浏览的是第几张图片,可以通过使用传递参数的方法来实现。先往窗体中添加一个image控件和文本框,程序代码如下:

sub page_load(sender as object, e as eventargs)
 ...

 ' dim imgindex as integer = 0
 if not request.querystring("n") is nothing andalso _
  isnumeric(request.querystring("n")) then
   imgindex = cint(request.querystring("n"))
 end if
 
 currentimgtitle.text = "you are viewing: " & _
  path.getfilenamewithoutextension(images(imgindex).name) & _
  " (" & imgindex + 1 & " of " & images.length & ")"
   currentimg.imageurl = path.getfilename(images(imgindex).name)
    ...
end sub

  html部分代码

<asp:label runat="server" id="currentimgtitle" /><br />
<asp:image runat="server" id="currentimg" />

  在上面的代码中,使用变量imgindex来表示当前浏览的是第几张图片,刚开始时候n=0,则获得images数组中的第一个变量,也即第一张图片,之后每次读取该变量值,则可以知道当前浏览的是第几张图片。

  而为了实现“下一张,上一张”的功能,往窗体增加两个hyperlink链接控件,并添加以下代码

sub page_load(sender as object, e as eventargs)
...

if imgindex > 0 then
 lnkprev.navigateurl = "default.aspx?n=" & imgindex - 1
end if

if imgindex < images.length - 1 then
 lnknext.navigateurl = "default.aspx?n=" & imgindex + 1
end if
...
end sub

  html 部分代码

<asp:hyperlink runat="server" id="lnkprev" text="< previous" />
<asp:hyperlink runat="server" id="lnknext" text="next >" />

  上面代码比较容易理解,当点下一张,上一张的链接时,参数n的值加1,或者减1。

  最后,为了实现比较直观的效果,我们放置一个datalist控件,其中显示图象文件夹下的所有文件,每当浏览一张新的图片时,则将当前正在浏览的图片的名称以链接的形式加亮显示,代码如下:

sub page_load(sender as object, e as eventargs)
 ...

 dlindex.datasource = images
 dlindex.databind()
end sub

sub dlindex_itemdatabound(sender as object, e as datalistitemeventargs)
 if e.item.itemtype = listitemtype.item orelse _
  e.item.itemtype = listitemtype.alternatingitem then
  'get the hyperlink
   dim hl as hyperlink = ctype(e.item.findcontrol("lnkpic"), hyperlink)

  'set the text and navigation properties
  hl.text = path.getfilenamewithoutextension(_
   databinder.eval(e.item.dataitem, "name").tostring()) & _
   " (" & _
    int(databinder.eval(e.item.dataitem, "length") / 1000) & _
   " kb)"
  hl.navigateurl = "default.aspx?n=" & e.item.itemindex
 end if
end sub

  html部分代码

<asp:datalist runat="server" id="dlindex" onitemdatabound="dlindex_itemdatabound"
repeatcolumns="3">
<itemtemplate>
<li><asp:hyperlink runat="server" id="lnkpic" /></li>
</itemtemplate>
</asp:datalist>

  在上面的代码中,在datalist的onitemdatabound事件中,首先判断当前触发的项目是否是列表项listitemtype或者是交替项alternatingitem,如果是的话,则动态生成链接hl,设置hl的值为当前正在浏览图象的文件名,并且注明了文件的大小,设置其链接的地址为当前浏览图象的地址,这样,用户可以直接点要浏览的图片了,不一要通过上一张,下一张的链接来实现。

  最后给出运行的一个例子(http://as.net.4guysfromrolla.com/london/)和全部代码:

<%@ import namespace="system.io" %>
<script runat="server" language="vb">
sub page_load(sender as object, e as eventargs)
 dim dirinfo as new directoryinfo(server.mappath(""))
 dim images() as fileinfo = filterforimages(dirinfo.getfiles())

 dim imgindex as integer = 0

 if not request.querystring("n") is nothing andalso isnumeric(request.querystring("n")) then
  imgindex = cint(request.querystring("n"))
 end if

 currentimgtitle.text = "you are viewing: " & _
  path.getfilenamewithoutextension(images(imgindex).name) & _
  " (" & imgindex + 1 & " of " & images.length & ")"
  currentimg.imageurl = path.getfilename(images(imgindex).name)

  if imgindex > 0 then
   lnkprev.navigateurl = "default.aspx?n=" & imgindex - 1
  end if

  if imgindex < images.length - 1 then
   lnknext.navigateurl = "default.aspx?n=" & imgindex + 1
  end if

  dlindex.datasource = images
  dlindex.databind()
end sub

function filterforimages(images() as fileinfo) as fileinfo()
 dim newimages as new arraylist(images.length)

 dim i as integer
 for i = 0 to images.length - 1
  if path.getextension(images(i).name) = ".jpg" orelse _
   path.getextension(images(i).name) = ".jpeg" orelse _
   path.getextension(images(i).name) = ".png" orelse _
   path.getextension(images(i).name) = ".gif" then
    newimages.add(images(i))
  end if
 next

 return ctype(newimages.toarray(gettype(fileinfo)), fileinfo())
end function

sub dlindex_itemdatabound(sender as object, e as datalistitemeventargs)
 if e.item.itemtype = listitemtype.item orelse e.item.itemtype =   listitemtype.alternatingitem then
  dim hl as hyperlink = ctype(e.item.findcontrol("lnkpic"), hyperlink)

  hl.text = path.getfilenamewithoutextension(databinder.eval(e.item.dataitem, "name").tostring()) & _
  " (" & int(databinder.eval(e.item.dataitem, "length") / 1000) & " kb)"
  hl.navigateurl = "default.aspx?n=" & e.item.itemindex
 end if
end sub
</script>

<html>
<head>
 <style type="text/css">
  body { font-family:verdana;font-size: medium;}
  .imagetitle { font-weight:bold; font-size:large;}
  .index {font-size: small;}
  .navlink { background-color: yellow; font-weight: bold; }
 </style>
</head>
<body>

<center>
<asp:label runat="server" id="currentimgtitle" cssclass="imagetitle" /><br />
<asp:image runat="server" id="currentimg" />
<asp:hyperlink runat="server" cssclass="navlink" id="lnkprev" text="< previous" />
<asp:hyperlink runat="server" cssclass="navlink" id="lnknext" text="next >" />
<asp:datalist runat="server" id="dlindex" onitemdatabound="dlindex_itemdatabound"
repeatcolumns="3" cssclass="index">
<itemtemplate>
<li><asp:hyperlink runat="server" id="lnkpic" /></li>
</itemtemplate>
</asp:datalist>
</center>
</body>
</html>

  


 


关键字 本文所属关键字

相关 与本文相关文章

分类 所有文章关键字导航

源码编程相关

Java   Asp   PHP   .Net   XML   C/C++   CGI   VB   Jsp   J2ee   J2se   J2me   EJB   Servlet   Tomcat   Resin   Struts   Weblogic   Eclipse   ANT   GUI   JMS   Web servise   IDEA   Webphere   Hibernate   Spring   Jboss   Applet   Swing   Socket   Javamail   Perl   Ajax   P2P   安全   模式   框架   测试   开源   游戏

SQL数据库相关

My-SQL   Ms-SQL   Access   DB2   Oracle   Sybase   SQLserver   索引   存储过程   加密   数据库   分页   视图  

手机无线相关

3G   Wap   CDMA   GRPS   GSM   IVR   彩信   短信   无线   增值业务

网页设计制作相关

HTML   CSS   网页配色   网页特效   Javascript   VBscript   Dreamweaver   Frontpage   JS   Web   网站设计

网站建设推广相关

建站经验   网站优化   网站排名   推广   Alexa

操作系统/服务器相关

Windows XP   Windows 2000   Windows 2003   Windows Me   Windows 9.x   Linux   UNIX   注册表   操作系统   服务器   应用服务器

图形图像多媒体相关

Photoshop   Fireworks   Flash   Coreldraw   Illustrator   Freehand   Photoimpact   多媒体   图形图像

标准 网站致力的规范

Valid CSS!

无不良内容,无不良广告,无恶意代码

Valid XHTML 1.0 Transitional

creativecommons