[转]在WP7上实现Listbox中长按弹出ContextMenu效果

#目标

在WP7中,为了达到长按弹出选项菜单效果,可以采用ContextMenu实现。

#前提条件

带有ContextMenu的toolkit,可以通过访问http://silverlight.codeplex.com/releases/view/71550获取最新的toolkit以及相应的源码及XAP。

如果需要检查,可访问$:\Program Files\Reference Assemblies\Microsoft\Framework\Silverlight\v4.0\Profile (其中$为SDK安装盘符)。对于WP7.0,访问WindowsPhone目录;对于WP7.1,访问WindowsPhone71目录。

#实现过程

至此,准备工作已经就绪,可以开始实现效果了。

方法一、通过代码来实现,利用ContextMenuService

  1. ContextMenu menu = new ContextMenu(); 
  2. MenuItem menuItem1 = new MenuItem(); 
  3. menuItem1.Header = "This is Menu Item 1"
  4. menuItem1.Click += new RoutedEventHandler(MenuItem_Click); 
  5. menu.Items.Add(menuItem1); 
  6. MenuItem menuItem2 = new MenuItem(); 
  7. menuItem2.Header = "This is Menu Item 2"
  8. menuItem2.Click += new RoutedEventHandler(MenuItem_Click); 
  9. menu.Items.Add(menuItem2); 
  10. ContextMenuService.SetContextMenu(rc, menu);  //这里的rc,表示的是矩形框的名字,也可以说是ContextMenu依附的那个控件的名字。

方法二、通过修改xaml文件来实现

1.在工程references中引入Microsoft.Phone.Controls.Toolkit。

2.在需要实现的页面(例如,demo.xaml)文件中加入toolkit声明如下:

  1. xmlns:toolkit="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone.Controls.Toolkit" 

  3.在demo.xaml中加入实现代码如下:

  1. <!--ContentPanel - place additional content here-->
  2.        
  3. <StackPanelx:Name="ContentPanel"Grid.Row="1"Margin="12,0,12,0">
  4.           <GridBackground="Blue">
  5.               <TextBlockText="Select a color from the Context Menu"/>
  6.     <ListBoxx:Name="listBox">
  7.         <ListBox.ItemTemplate>
  8.             <DataTemplate>
  9.                 <StackPanelOrientation="Horizontal">
  10.                     <toolkit:ContextMenuService.ContextMenu>
  11.                         <toolkit:ContextMenu>
  12.                             <toolkit:MenuItemHeader="Add Color"Click="MenuItem_Click"/>
  13.                             <toolkit:MenuItemHeader="Remove Color"Click="MenuItem_Click"/>
  14.                         </toolkit:ContextMenu>
  15.                     </toolkit:ContextMenuService.ContextMenu>
  16.                     <ImageSource="{Binding ImageUri}"Stretch="None"/>
  17.                     <TextBlockText="{Binding Text}"/>
  18.                 </StackPanel>
  19.             </DataTemplate>
  20.         </ListBox.ItemTemplate>
  21.     </ListBox>
  22.           </Grid>
  23.       </StackPanel>

如此即可完成长按弹出菜单效果。

#效果演示

 

图片分享:

 

#问题

1.在WP7.0上则存在被缩放的部分有显示问题,当背景颜色对比大时更加明显。

2.在mango(WP7.1+)上效果非常好,与系统现象一致。看来微软已经FIX此问题。

#参考链接

1.http://silverlight.codeplex.com/releases/view/71550,以获取最新的toolkit和source code。

2.http://www.windowsphonegeek.com/tips/wp7-contextmenu-answers-to-popular-questions

转载于:https://www.cnblogs.com/xiurui12345/archive/2012/03/06/2381268.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值