有時候我們要在邏輯程式碼裡面動態的改變某張圖片,可以通過改變圖片的來源達到(就是改變Image控制元件的source)。
1、從伺服器端獲取路徑
加入有個silverlight專案,在伺服器端有個Images資料夾(在**.web 專案的根目錄下),裡面放著一些圖片,客戶端要通過wcf從伺服器端獲取這些照片(其實這裡是獲取路徑,或者說連結),獲取這些照片路徑的程式碼如下:
先獲取伺服器名稱,再獲取埠號(可能沒有),最後獲取應用程式的名稱,這三個名稱組成了基本路徑。要精確定位到某張圖片,還要加上圖片所在的資料夾(一般放在silverlight解決方案的 .web專案的根目錄下)——這裡是image ,在加上圖片的名字,再加上字尾名
1 [OperationContract]
2 public string GetPhotosPath(string name, out string picturePath)
3 {
4 //圖片路徑。images是 .web專案下放圖片的資料夾。name是要查詢照片的名字
5 picturePath = GetBaseDirectory() + "images/"+ name + ".jpg";
6 return picturePath;
7 }
8
9 private string GetBaseDirectory()
10 {
11 // 伺服器名稱
12 string serverName = HttpContext.Current.Request.ServerVariables["Server_Name"];
13
14 //埠號
15 string port = HttpContext.Current.Request.ServerVariables["SERVER_PORT"];
16
17 // 應用服務名稱
18 string applicationName = HttpContext.Current.Request.ApplicationPath;
19
20 string path = "http://" + serverName + (port.Length > 0 ? ":" + port : string.Empty) + applicationName;
21 return path;
22 }
2、在客戶端改變照片源
程式碼如下,e.Result是返回的照片路徑。
有時候不需要從伺服器端獲取,可以直接從客戶端獲取另一張圖片,獲取路徑方法:"Image/" + name + ".jpg" ,
假設 照片放在客戶端專案的image(在客戶端專案的根目錄下)資料夾裡, 字尾名可以是其他格式,name表示照片名字。
客戶端訪問程式碼如下:
1 void client_GetPhotosPathCompleted(object sender, ServiceRefEmpInfo.GetPhotosPathCompletedEventArgs e)
2 {
3 string imageURL = e.Result;
4
5 //如果返回的照片路徑有誤,則顯示出錯提示
6 if (string.IsNullOrEmpty(imageURL))
7 {
8 imageURL = @"Images/falsePhotos.jpg";// 相對路徑格式
9
10 }
11
12 Uri uri = new Uri(imageURL, UriKind.RelativeOrAbsolute);
13 BitmapImage image = new BitmapImage(uri);
14 ((MainPage)App.Current.RootVisual).imageEmp.Source = image;
15
16 // ((MainPage)App.Current.RootVisual).imageEmp.Source = new BitmapImage(new Uri(imageURL, UriKind.RelativeOrAbsolute));
17
18 }
獲取到照片的路徑了,如何改變照片源呢?
1、新建一個 Uri 物件 :Uri uri = new Uri(imageURL, UriKind.RelativeOrAbsolute);
imageURL是照片的路徑,UriKind.RelativeOrAbsolute表示imageURL是絕對路徑還是相對路徑。
如果是 new Uri(imageURL) 則表示imageURL是以絕對路徑
2、用剛才新建的Uri物件的例項作為引數建立一個BitmapImage 物件:BitmapImage image = new BitmapImage(uri);
3、把新的BitmapImage 例項作為照片源賦給 Image :
((MainPage)App.Current.RootVisual).imageEmp.Source = image;
((MainPage)App.Current.RootVisual).imageEmp表示Image控制元件的名字