亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

保存美麗記憶 用ASP.NET創建網絡相冊

2019-11-18 19:36:16
字體:
來源:轉載
供稿:網友

  在現在的數碼時代,我們會經常拍攝一些相片以供留念,而隨著數碼照片的增多,往往需要很好地管理這些照片,以便更好地查閱留念?,F在網上有不少的電子相冊,都能很好的實現這些功能,那我們能否自己動手創建自己的相冊呢?當然可以,在這篇文章中,我們將利用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://aspnet.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>


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国内精品视频| 欧美另类老女人| 国产精品入口日韩视频大尺度| 国产精品久久97| 精品人伦一区二区三区蜜桃免费| 日韩欧美aaa| 日韩精品免费看| 欧美高清videos高潮hd| 国产欧美最新羞羞视频在线观看| 成人午夜一级二级三级| 日本久久中文字幕| 日韩精品在线观看视频| 高清欧美性猛交xxxx| 成人黄色午夜影院| 欧美成人午夜剧场免费观看| 亚洲综合色av| 亚洲国产91精品在线观看| 久99久在线视频| 日韩电影中文字幕av| 欧美丰满老妇厨房牲生活| 亚洲人成电影在线| 欧美日韩一区二区在线| 日韩av网址在线观看| 国产主播在线一区| 亚洲色图av在线| 国产精品视频1区| 久久6精品影院| 91九色精品视频| 日韩av成人在线观看| 久久久久中文字幕2018| 欧美日韩成人精品| 国外视频精品毛片| 国产精品久久久久久久久久久久久| 欧美日韩一二三四五区| 精品女同一区二区三区在线播放| 国产女人18毛片水18精品| 欧美黄色免费网站| 日本欧美黄网站| 日韩av理论片| 日韩大片在线观看视频| 亚洲精品xxxx| 亚洲国产精品va在线| 中文字幕日韩欧美在线视频| 欧美另类高清videos| 国产精品久久久久久中文字| 日韩精品电影网| 成人女保姆的销魂服务| 久久影院资源站| 久久精品国产91精品亚洲| 亚洲影院色无极综合| 国产精品网站入口| 日韩av大片免费看| 热草久综合在线| 国产成人一区二区在线| 欧美激情在线视频二区| 97香蕉超级碰碰久久免费的优势| 欧美一级免费看| 日韩av男人的天堂| 欧美视频一二三| 日韩一二三在线视频播| 亚洲一区二区三区乱码aⅴ蜜桃女| 久久亚洲国产成人| 亚洲r级在线观看| 亚洲一区亚洲二区亚洲三区| 日韩天堂在线视频| 午夜精品蜜臀一区二区三区免费| 国产精品久久中文| 91精品国产777在线观看| 国内精品视频一区| 日本久久久久久久| 国产成人精品视| 影音先锋欧美在线资源| 欧美特黄级在线| 日韩激情视频在线播放| 2019中文字幕在线观看| 成人精品福利视频| 日韩中文字幕在线看| 国产原创欧美精品| 91精品免费看| 7777精品久久久久久| 欧美中文字幕精品| 日韩精品视频免费专区在线播放| 久久福利视频导航| 成人精品一区二区三区| 亚洲香蕉在线观看| 2019中文字幕免费视频| 在线观看视频亚洲| 国产亚洲精品一区二555| 欧美精品免费看| 精品久久久一区| 国产91九色视频| 中文字幕免费精品一区高清| 欧洲成人午夜免费大片| 久久青草精品视频免费观看| 久久精品国产视频| 91精品久久久久久久久久久久久| 国产成人福利网站| 欧美寡妇偷汉性猛交| 最近中文字幕日韩精品| 亚洲aa在线观看| 欧美日韩国产二区| 国产精品女人久久久久久| 美女黄色丝袜一区| 国产中文日韩欧美| 欧美色图在线视频| 精品久久久久久久久久ntr影视| 亚洲女人天堂av| 欧美视频二区36p| 欧美国产日韩一区二区在线观看| 日韩av在线天堂网| 18一19gay欧美视频网站| 秋霞午夜一区二区| 最近日韩中文字幕中文| 亚洲国产精品久久久久秋霞蜜臀| 国产精品美女久久| 在线观看精品自拍私拍| 亚洲成人在线视频播放| 日韩电影免费在线观看中文字幕| 在线性视频日韩欧美| 亚洲女人天堂网| 超碰97人人做人人爱少妇| 日韩视频免费中文字幕| 欧美一级黑人aaaaaaa做受| 亚洲第一免费播放区| 一区二区三区国产视频| 国产精品久久久久久超碰| 精品久久久久久久久中文字幕| 欧美在线视频播放| 亚洲欧美一区二区三区在线| 亚洲国产成人91精品| 中文字幕亚洲欧美日韩在线不卡| 日韩在线高清视频| 国产精品一香蕉国产线看观看| 国产精品亚洲一区二区三区| 久久久国产视频91| 欧美日本亚洲视频| 亚洲人成网站999久久久综合| 久久av在线看| 欧洲成人免费视频| 久久av资源网站| 亚洲aaaaaa| 96pao国产成视频永久免费| 精品国产一区二区三区久久狼5月| 精品国产鲁一鲁一区二区张丽| 久久躁狠狠躁夜夜爽| 成人免费在线视频网站| 日韩精品免费一线在线观看| 久久久亚洲天堂| 亚洲精品国精品久久99热| 国产69精品久久久久9| 91理论片午午论夜理片久久| 美女久久久久久久久久久| www高清在线视频日韩欧美| 亚洲高清一区二| 亚洲精品动漫100p| 九色成人免费视频| 欧美日韩国产综合新一区| 国产噜噜噜噜久久久久久久久| 亚洲第一网中文字幕| 国产亚洲精品久久久| 欧美精品福利在线| 精品久久久国产精品999| 亚洲精品欧美一区二区三区| 在线免费观看羞羞视频一区二区|