Windows Phone 7 使用选择器(Chooser)

Chooser选择器:调用Windows Phone 7的应用程序选择所需要的信息(例如照片,电话等)

Chooser的功能是去选择某一些东西;例如说一张图片、一个联络人资讯等等;而要使用Chooser 要先引入Microsoft.Phone.Task 的命名空间。

下面列出各种Chooser的种类——

CameraCaptureTask: 启动照相界面,拍照后返回照片图像。

EmailAddressChooserTask: 启动选Email地址界面,选择后返回Email地址。

PhoneNumberChooserTask: 启动电话号码选择界面,选择后返回电话号码。

PhotoChooserTask: 启动图片选择界面,选择后返回图像信息。

SaveEmailAddressTask: 启动保存Email地址界面,选择后返回保存是否成功。

SavePhoneNumberTask: 启动保存电话号码界面,选择后返回保存是否成功。


1、CameraCaptureTask

 

上面这三个画面中,最左侧的画面是呼叫出CameraCaptureTask 之后的拍照画面,右上角的图案就是拍照的按钮了,在您实际使用的时候会有白色的方框以及一个小黑色方框(例如最右侧的画面是取得拍照后的图片效果) 作为模拟的拍照画面,按下拍照按钮之后,便会出现中间的画面,要您确认拍照的结果或是重新拍一张新的照片,确认之后便会回到应用程式中,并且显示出拍摄到的画面,下面简单的来看一下程式码的部分

首先记得要引入相关的命名空间

using Microsoft.Phone.Tasks;

using System.Windows.Media.Imaging;

之后做Chooser 的宣告以及初始化的动作,例如

CameraCaptureTask cct ;

public CamerChooser()

{

InitializeComponent();

//挂载完成事件,建议要在初始化完成之后便挂载事件,与application lift cycle 有关

cct = new CameraCaptureTask();

cct.Completed += new EventHandler<PhotoResult>(cct_Completed);

}而怎么去呼叫 Chooser 出来呢?这部分相当的简单,只要呼叫Show 的方法就可以了,例如下面笔者是在Button 的Click 事件中

去做呼叫

private void btnShot_Click(object sender, RoutedEventArgs e)

{

//呼叫 Chooser

cct.Show();

}

而在Chooser 的使用上,最主要的部份就是处理Completed 的事件,例如下面

void cct_completed(object sender, PhotoResult e)

{

//判断结果是否成功

if (e.TaskResult == TaskResult.OK)

{

BitmapImage bmpSource = new BitmapImage();

bmpSource.SetSource(e.ChosenPhoto);

image1.Source = bmpSource;

}

else

{

image1.Source = null;

}

}

在处理Completed 的事件当中,必须要先判断TaskResult 属性,在这个属性当中,可以取得拍照动作的结果,例如当使用者按下确定(Accept) 的按钮时,会回应OK,而如果使用者按下返回键呢?这时候回传的就会是Cancel 的状态了;由这个状态,可以去判断接下来应用程式当中要处理的动作。

而怎么取得拍摄的照片呢?主要便是利用ChoosenPhoto 的属性;ChoosenPhoto 是一个Stream,是指向实体照片位置的资料流,还记得Isolated Storage 吗?拍照后图片是不会直接的储存到应用程式所属的隔离储存区中的,因为Chooser 所叫出的是另外的应用程式,不同应用程式之间是不能去交叉存取隔离储存区中的档案的;因此Chooser 会由这种方式来让我们的应用程式取得结果。

详细的代码如下:

 

  
  
  
  
  1. View Code   
  2.  
  3. <!--LayoutRoot contains the root grid where all other page content is placed--> 
  4.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  5.         <Grid.RowDefinitions> 
  6.             <RowDefinition Height="Auto"/> 
  7.             <RowDefinition Height="*"/> 
  8.         </Grid.RowDefinitions> 
  9.  
  10.         <!--TitlePanel contains the name of the application and page title--> 
  11.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="24,24,0,12"> 
  12.             <TextBlock x:Name="ApplicationTitle" Text="Chooser Demo" Style="{StaticResource PhoneTextNormalStyle}"/> 
  13.             <TextBlock x:Name="PageTitle" Text="CamerCapture" Margin="-3,-8,0,0" Style="{StaticResource PhoneTextTitle1Style}"/> 
  14.         </StackPanel> 
  15.  
  16.         <!--ContentPanel - place additional content here--> 
  17.         <Grid x:Name="ContentGrid" Grid.Row="1"> 
  18.             <Image Height="489" HorizontalAlignment="Left" Margin="21,19,0,0" Name="image1" Stretch="Fill" VerticalAlignment="Top" Width="447" /> 
  19.             <Button Content="Take a photo" Height="82" HorizontalAlignment="Left" Margin="191,535,0,0" Name="btnShot" VerticalAlignment="Top" Width="283" Click="btnShot_Click" /> 
  20.         </Grid> 
  21.     </Grid> 

2、EmailAddressChooserTask
EmailAddressChooserTask主要是用来取得联络人的电子邮件资料,先来看看执行时的画面效果

 

代码如下:

 

  
  
  
  
  1. View Code   
  2.  
  3. using System;  
  4. using System.Collections.Generic;  
  5. using System.Linq;  
  6. using System.Net;  
  7. using System.Windows;  
  8. using System.Windows.Controls;  
  9. using System.Windows.Documents;  
  10. using System.Windows.Input;  
  11. using System.Windows.Media;  
  12. using System.Windows.Media.Animation;  
  13. using System.Windows.Shapes;  
  14. using Microsoft.Phone.Controls;  
  15.  
  16. using Microsoft.Phone.Tasks;  
  17.  
  18. namespace ChooserDemo  
  19. {  
  20.     public partial class EmailAddressChooser : PhoneApplicationPage  
  21.     {  
  22.         EmailAddressChooserTask eac;  
  23.  
  24.         public EmailAddressChooser()  
  25.         {  
  26.             InitializeComponent();  
  27.  
  28.             eac = new EmailAddressChooserTask();  
  29.             eac.Completed += new EventHandler<EmailResult>(eac_Completed);  
  30.         }  
  31.  
  32.         void eac_Completed(object sender, EmailResult e)  
  33.         {  
  34.             if (e.TaskResult == TaskResult.OK)  
  35.             {  
  36.                 textBox1.Text = e.Email;  
  37.             }  
  38.         }  
  39.  
  40.         private void btnEmailaddress_Click(object sender, RoutedEventArgs e)  
  41.         {  
  42.             eac.Show();  
  43.         }  
  44.     }  

3、PhoneNumberChooserTask
接下来是PhoneNumberChooserTask,主要是用来选择联络人的电话号码,先来看一下执行的效果

 

代码如下:

 

  
  
  
  
  1. View Code   
  2.  
  3.  <!--LayoutRoot is the root grid where all page content is placed--> 
  4.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  5.         <Grid.RowDefinitions> 
  6.             <RowDefinition Height="Auto"/> 
  7.             <RowDefinition Height="*"/> 
  8.         </Grid.RowDefinitions> 
  9.  
  10.         <!--TitlePanel contains the name of the application and page title--> 
  11.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28"> 
  12.             <TextBlock x:Name="ApplicationTitle" Text="Chooser Demo" Style="{StaticResource PhoneTextNormalStyle}"/> 
  13.             <TextBlock x:Name="PageTitle" Text="Phone Number" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/> 
  14.         </StackPanel> 
  15.  
  16.         <!--ContentPanel - place additional content here--> 
  17.         <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  18.             <Button Content="Choose Phone number" Height="87" HorizontalAlignment="Left" Margin="12,6,0,0" Name="button1" VerticalAlignment="Top" Width="438" Click="button1_Click" /> 
  19.             <TextBox Height="75" HorizontalAlignment="Left" Margin="24,130,0,0" Name="textBox1" Text="" VerticalAlignment="Top" Width="323" /> 
  20.             <TextBlock Height="39" HorizontalAlignment="Left" Margin="37,108,0,0" Name="textBlock1" Text="Choosen Phone Number:" VerticalAlignment="Top" Width="334" /> 
  21.         </Grid> 
  22.     </Grid> 

 

  
  
  
  
  1. View Code   
  2.  
  3. using System;  
  4. using System.Collections.Generic;  
  5. using System.Linq;  
  6. using System.Net;  
  7. using System.Windows;  
  8. using System.Windows.Controls;  
  9. using System.Windows.Documents;  
  10. using System.Windows.Input;  
  11. using System.Windows.Media;  
  12. using System.Windows.Media.Animation;  
  13. using System.Windows.Shapes;  
  14. using Microsoft.Phone.Controls;  
  15.  
  16. using Microsoft.Phone.Tasks;  
  17.  
  18. namespace ChooserDemo  
  19. {  
  20.     public partial class PhoneNumberChooser : PhoneApplicationPage  
  21.     {  
  22.         PhoneNumberChooserTask pnc;  
  23.  
  24.         public PhoneNumberChooser()  
  25.         {  
  26.             InitializeComponent();  
  27.             pnc = new PhoneNumberChooserTask();  
  28.             pnc.Completed += new EventHandler<PhoneNumberResult>(pnc_Completed);  
  29.         }  
  30.  
  31.         void pnc_Completed(object sender, PhoneNumberResult e)  
  32.         {  
  33.             if (e.TaskResult == TaskResult.OK)  
  34.             {  
  35.                 textBox1.Text = e.PhoneNumber;  
  36.             }  
  37.         }  
  38.  
  39.         private void button1_Click(object sender, RoutedEventArgs e)  
  40.         {  
  41.             pnc.Show();  
  42.         }  
  43.     }  

4、PhotoChooserTask
PhotoChooserTask是用来选择图片用的,这部分使用上跟CameraCaptureTask是极其相似的,使用时您可以参考CameraCaptuerTask的相关程式码,下面这边来看看执行时的效果

 

到目前为止的动作都与CameraCaptureTask相同,下面来看看在PhotoChooser中特殊的属性,首先是ShowCamera的属性,ShowCamera的属性是一个布尔型态,当设定为真时,在选择图片的画面中,会出现拍照的按钮,让使用者也可以透过照相机来做为图片的来源,会向下图的样子(您可以看到多出了应用程序栏中并且多了照相的按钮)

 

 

接下来是PixelHeight,PixelWidth的属性,这两个属性是让使用者可以裁切原始的图形,比如说,现在应用程式要让使用者设定大头贴,大头贴的尺寸只需要100* 10,这时候过大的图形并没有用处,因此您就可以设定这两个属性,设定之后当使用者选定照片之后会出现裁切的方框,方框会依照您设定的长宽比例做调整,例如下方左图笔者是设定3:8的比例,而右图就是裁切之后的效果了

代码如下:

 

  
  
  
  
  1. View Code   
  2.  
  3.  <!--LayoutRoot is the root grid where all page content is placed--> 
  4.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  5.         <Grid.RowDefinitions> 
  6.             <RowDefinition Height="Auto"/> 
  7.             <RowDefinition Height="*"/> 
  8.         </Grid.RowDefinitions> 
  9.  
  10.         <!--TitlePanel contains the name of the application and page title--> 
  11.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28"> 
  12.             <TextBlock x:Name="ApplicationTitle" Text="Chooser Demo" Style="{StaticResource PhoneTextNormalStyle}"/> 
  13.             <TextBlock x:Name="PageTitle" Text="Photo" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/> 
  14.         </StackPanel> 
  15.  
  16.         <!--ContentPanel - place additional content here--> 
  17.         <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  18.             <Button Content="Choose photo" Height="85" HorizontalAlignment="Left" Margin="24,23,0,0" Name="button1" VerticalAlignment="Top" Width="417" Click="button1_Click" /> 
  19.             <Image Height="336" HorizontalAlignment="Left" Margin="38,139,0,0" Name="image1" Stretch="Uniform" VerticalAlignment="Top" Width="394" /> 
  20.             <TextBlock Height="90" HorizontalAlignment="Left" Margin="38,490,0,0" Name="textBlock1" Text="TextBlock" VerticalAlignment="Top" Width="394" TextWrapping="Wrap" /> 
  21.         </Grid> 
  22.     </Grid> 

 

  
  
  
  
  1. View Code   
  2.  
  3. using System;  
  4. using System.Collections.Generic;  
  5. using System.Linq;  
  6. using System.Net;  
  7. using System.Windows;  
  8. using System.Windows.Controls;  
  9. using System.Windows.Documents;  
  10. using System.Windows.Input;  
  11. using System.Windows.Media;  
  12. using System.Windows.Media.Animation;  
  13. using System.Windows.Shapes;  
  14. using Microsoft.Phone.Controls;  
  15.  
  16. using Microsoft.Phone.Tasks;  
  17. using System.Windows.Media.Imaging;  
  18.  
  19. namespace ChooserDemo  
  20. {  
  21.     public partial class PhotoChooser : PhoneApplicationPage  
  22.     {  
  23.         PhotoChooserTask pc;  
  24.  
  25.         public PhotoChooser()  
  26.         {  
  27.             InitializeComponent();  
  28.             pc = new PhotoChooserTask();  
  29.             pc.Completed += new EventHandler<PhotoResult>(pc_Completed);  
  30.         }  
  31.  
  32.         void pc_Completed(object sender, PhotoResult e)  
  33.         {  
  34.             if (e.TaskResult == TaskResult.OK)  
  35.             {  
  36.                 BitmapImage bmpSource = new BitmapImage();  
  37.                 bmpSource.SetSource(e.ChosenPhoto);  
  38.                 image1.Source = bmpSource;  
  39.                 textBlock1.Text = e.OriginalFileName;  
  40.             }  
  41.             else  
  42.             {  
  43.                 image1.Source = null;  
  44.             }  
  45.         }  
  46.  
  47.         private void button1_Click(object sender, RoutedEventArgs e)  
  48.         {  
  49.             //是否裁切相片,�K�O定裁切後相片的最大高度以及��度  
  50.             pc.PixelHeight = 30;  
  51.             pc.PixelWidth = 80;  
  52.  
  53.             //�O定是否出�F拍照的按�o(位於Application Bar)  
  54.             //pc.ShowCamera = true;  
  55.  
  56.             pc.Show();  
  57.         }  
  58.     }  

5、SaveEmailAddressTask,SavePhoneNumberTask
SaveEmailAddressTask是用来储存联络人中电子邮件的相关资料,而SavePhoneNumberTask则是用来储存联络人的电话号码,这两种选择器使用的方式是相同的,下面先来看看执行时的效果

 

启动了SaveEmailAddressTask之后,在上面中间这张图,您可以选择要将这个电子邮件储存到哪一个联络人,或是说要建立新的联络人都可以,而选择联络人之后就会出现右侧的这个画面,让您确认资料无误,按下确认(打勾)的按钮后,则进入到下一个步骤,大致会像下面这样的效果

 

代码如下:

 

  
  
  
  
  1. View Code   
  2.  
  3.   <!--LayoutRoot is the root grid where all page content is placed--> 
  4.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  5.         <Grid.RowDefinitions> 
  6.             <RowDefinition Height="Auto"/> 
  7.             <RowDefinition Height="*"/> 
  8.         </Grid.RowDefinitions> 
  9.  
  10.         <!--TitlePanel contains the name of the application and page title--> 
  11.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28"> 
  12.             <TextBlock x:Name="ApplicationTitle" Text="Chooser Demo" Style="{StaticResource PhoneTextNormalStyle}"/> 
  13.             <TextBlock x:Name="PageTitle" Text="Save Email Address" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/> 
  14.         </StackPanel> 
  15.  
  16.         <!--ContentPanel - place additional content here--> 
  17.         <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  18.             <TextBox Height="76" HorizontalAlignment="Left" Margin="0,72,0,0" Name="txtEmail" Text="" VerticalAlignment="Top" Width="444" /> 
  19.             <TextBlock HorizontalAlignment="Left" Margin="12,33,0,0" Name="textBlock1" Text="Email address" Width="350" Height="33" VerticalAlignment="Top" /> 
  20.             <Button Content="Save" Height="84" HorizontalAlignment="Left" Margin="249,167,0,0" Name="button1" VerticalAlignment="Top" Width="183" Click="button1_Click" /> 
  21.         </Grid> 
  22.     </Grid> 

 

  
  
  
  
  1. View Code   
  2.  
  3. using System;  
  4. using System.Collections.Generic;  
  5. using System.Linq;  
  6. using System.Net;  
  7. using System.Windows;  
  8. using System.Windows.Controls;  
  9. using System.Windows.Documents;  
  10. using System.Windows.Input;  
  11. using System.Windows.Media;  
  12. using System.Windows.Media.Animation;  
  13. using System.Windows.Shapes;  
  14. using Microsoft.Phone.Controls;  
  15.  
  16. using Microsoft.Phone.Tasks;  
  17.  
  18. namespace ChooserDemo  
  19. {  
  20.     public partial class SaveEmailAddress : PhoneApplicationPage  
  21.     {  
  22.         SaveEmailAddressTask sea;  
  23.  
  24.         public SaveEmailAddress()  
  25.         {  
  26.             InitializeComponent();  
  27.             txtEmail.InputScope = new InputScope()  
  28.             {  
  29.                 Names = { new InputScopeName() { NameValue = InputScopeNameValue.EmailNameOrAddress } }  
  30.             };  
  31.  
  32.             sea = new SaveEmailAddressTask();  
  33.             sea.Completed += new EventHandler<TaskEventArgs>(sea_Completed);  
  34.         }  
  35.  
  36.         void sea_Completed(object sender, TaskEventArgs e)  
  37.         {  
  38.             if (e.TaskResult == TaskResult.OK)  
  39.             {  
  40.                 //Success  
  41.                 MessageBox.Show("�Υ娉晒�!");  
  42.             }  
  43.             else  
  44.             {  
  45.                 MessageBox.Show("�Υ媸��!");  
  46.             }  
  47.         }  
  48.  
  49.         private void button1_Click(object sender, RoutedEventArgs e)  
  50.         {  
  51.             sea.Email = txtEmail.Text;  
  52.             sea.Show();  
  53.         }  
  54.     }  

 

  
  
  
  
  1. View Code   
  2.  
  3.  <!--LayoutRoot is the root grid where all page content is placed--> 
  4.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  5.         <Grid.RowDefinitions> 
  6.             <RowDefinition Height="Auto"/> 
  7.             <RowDefinition Height="*"/> 
  8.         </Grid.RowDefinitions> 
  9.  
  10.         <!--TitlePanel contains the name of the application and page title--> 
  11.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28"> 
  12.             <TextBlock x:Name="ApplicationTitle" Text="Chooser Demo" Style="{StaticResource PhoneTextNormalStyle}"/> 
  13.             <TextBlock x:Name="PageTitle" Text="Save Phone Number" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/> 
  14.         </StackPanel> 
  15.  
  16.         <!--ContentPanel - place additional content here--> 
  17.         <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  18.             <TextBox Height="76" HorizontalAlignment="Left" Margin="10,49,0,0" Name="txtPhoneNo" Text="" VerticalAlignment="Top" Width="444" /> 
  19.             <TextBlock Height="33" HorizontalAlignment="Left" Margin="22,10,0,0" Name="textBlock1" Text="Phone number" VerticalAlignment="Top" Width="350" /> 
  20.             <Button Content="Save" Height="84" HorizontalAlignment="Left" Margin="259,144,0,0" Name="button1" VerticalAlignment="Top" Width="183" Click="button1_Click" /> 
  21.         </Grid> 
  22.     </Grid> 

 

  
  
  
  
  1. View Code   
  2.  
  3.  <!--LayoutRoot is the root grid where all page content is placed--> 
  4.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  5.         <Grid.RowDefinitions> 
  6.             <RowDefinition Height="Auto"/> 
  7.             <RowDefinition Height="*"/> 
  8.         </Grid.RowDefinitions> 
  9.  
  10.         <!--TitlePanel contains the name of the application and page title--> 
  11.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28"> 
  12.             <TextBlock x:Name="ApplicationTitle" Text="Chooser Demo" Style="{StaticResource PhoneTextNormalStyle}"/> 
  13.             <TextBlock x:Name="PageTitle" Text="Save Phone Number" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/> 
  14.         </StackPanel> 
  15.  
  16.         <!--ContentPanel - place additional content here--> 
  17.         <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  18.             <TextBox Height="76" HorizontalAlignment="Left" Margin="10,49,0,0" Name="txtPhoneNo" Text="" VerticalAlignment="Top" Width="444" /> 
  19.             <TextBlock Height="33" HorizontalAlignment="Left" Margin="22,10,0,0" Name="textBlock1" Text="Phone number" VerticalAlignment="Top" Width="350" /> 
  20.             <Button Content="Save" Height="84" HorizontalAlignment="Left" Margin="259,144,0,0" Name="button1" VerticalAlignment="Top" Width="183" Click="button1_Click" /> 
  21.         </Grid> 
  22.     </Grid> 

 

你可能感兴趣的:(windows,选择器,phone,7,chooser)