zoukankan      html  css  js  c++  java
  • [转]在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

  • 相关阅读:
    转:高层游戏引擎——基于OGRE所实现的高层游戏引擎框架
    转: Orz是一个基于Ogre思想的游戏开发架构
    转:Ogre源代码浅析——脚本及其解析(一)
    IntelliJ IDEA添加过滤文件或目录
    为什么要使用ConcurrentHashMap
    volatile关键字解析
    Spring Boot MyBatis 通用Mapper 自动生成代码
    使用mysql乐观锁解决并发问题
    使用Redis分布式锁处理并发,解决超卖问题
    浅析 pagehelper 分页
  • 原文地址:https://www.cnblogs.com/xiurui12345/p/2381268.html
Copyright © 2011-2022 走看看