Windows Phone 8.1中的Popup

开篇之前,照例推荐王磊老师的Windows 8.1中的Popup控件用法

链接:Windows 8.1中Popup

同时推荐老周-易之道的一篇关于自定义Popup的一篇文章

链接:新时尚Windows8开发(17):自己也来做一做弹出对话框

以上两位的博客对学习Windows 8.1和Windows Phone 8.1都有很大的帮助,推荐大家可以看看

可以先来总结下一些具有弹出效果的控件和类吧:

a.MessageDialog类,这是最简单的弹出框了应该

b.DatePicker控件和TimePicker控件

c.Flyout控件(这其中有几种表现方式),可以参考关于Flyout控件的另外一篇博客

链接:WP8.1的Flyout控件

d.Popup控件

那么Popup控件在Windows Phone 8.1中是怎么表现的呢?

首先它的重要的属性和方法有哪些呢

a.Child属性   -----   Popup的内容

b.HorizontalOffset属性   -----   水平方向上的偏移量

c.VerticalOffset属性   -----   垂直方向上的偏移量

d.IsLightDismissEnabled属性   -----    点击非Popup区域是否也可以关闭Popup,默认是false

e.ChildTransitions属性   -----    显示弹出框是,内容的过渡效果

这个属性很有用也很好玩,特别是后面做类似Toast效果的弹出框的时候很像那么回事

f.IsOpen属性   -----    Popup是否处于打开状态

g.Opened事件    -----    Popup打开时触发的事件

h.Closed事件     -----    Popup关闭时触发的事件

在贴代码之前,列举一下我的认识和收获:

a.在.cs中设置前台标签的背景或者其他涉及到颜色的属性的时候,纯色的话必须要用到SolidColorBrush画刷类

例如:Border border = new Border();   border.Background = new SolidColorBrush(Colors.Green)

b.在一个容器控件中添加内容Child,可以有两种方法(这边Border是父容器,TextBlock是内容)

其一先是实例内容对象,然后对这个对象添加各种各样的属性和方法,最后再添加到父类容器控件中

其二是直接添加到父类容器控件中,在添加的同时进行内容对象的构造函数的实例化

例如:

其一:Border border = new Border();

TextBlock textBlock = new TextBlock();

textBlock.Text = "Border里的内容";

border.Child = textBlock;

其二:Border border = new Border();

border.Child = new TextBlock(){Text="Border里的内容"};

以上两种实际上是一样的,但是很显然第二种更加省事。

c.如果不将Popup添加到某个容器内,则Popup的默认显示位置在屏幕的左上角

d.类似Toast通知的弹出Popup效果,主要用到了ChildTransition属性,具体如下:

ChildTransition->TransitionCollection->PaneThemeTransition的属性Edge

(Edge = EdgeTransitionLocation.Left)

下面贴代码,其实代码和王磊老师的Windows 8.1中的代码差不多,我只不过移植到WP8.1中看是否依旧适用而已

前台XAML:

<Page
    x:Class="TestUnion.PopupDemo"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:TestUnion"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d"
    Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">

    <Grid>
        <StackPanel>
            <StackPanel>
                <Button x:Name="btnOpen" Content="弹出" Click="btnOpen_Click" />
                <CheckBox x:Name="checkBox" IsChecked="True" Content="IsLightDismissEnabled" />
            </StackPanel>
            <Popup x:Name="popup" IsLightDismissEnabled="{Binding Path=IsChecked,ElementName=checkBox,Mode=OneWay}">
                <Popup.Child>
                    <Border BorderBrush="Red" BorderThickness="1" Background="Blue" Width="200" Height="200">
                        <StackPanel HorizontalAlignment="Center" VerticalAlignment="Center">
                            <TextBlock Text="我是Popup" FontSize="25" HorizontalAlignment="Center"/>
                            <Button x:Name="btnClose" Content="关闭" Click="btnClose_Click" HorizontalAlignment="Center"/>
                        </StackPanel>
                    </Border>
                </Popup.Child>
                <Popup.ChildTransitions>
                    <TransitionCollection>
                        <PopupThemeTransition />
                    </TransitionCollection>
                </Popup.ChildTransitions>
            </Popup>
            <Button x:Name="openLikePopup" Content="弹出仿制Popup" Click="openLikePopup_Click" />
            <Button x:Name="closeLikePopup" Content="关闭仿制Popup" Click="closeLikePopup_Click"/>
        </StackPanel>
    </Grid>
</Page>

后台.cs:

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.Foundation;
using Windows.Foundation.Collections;
using Windows.UI;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Controls.Primitives;
using Windows.UI.Xaml.Data;
using Windows.UI.Xaml.Input;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Media.Animation;
using Windows.UI.Xaml.Navigation;

// “空白页”项模板在 http://go.microsoft.com/fwlink/?LinkID=390556 上有介绍

namespace TestUnion
{
    /// <summary>
    /// 可用于自身或导航至 Frame 内部的空白页。
    /// </summary>
    public sealed partial class PopupDemo : Page
    {
        //仿制toast的Popup
        private Popup _popupToast = new Popup(); 

        public PopupDemo()
        {
            this.InitializeComponent();
        }

        /// <summary>
        /// 在此页将要在 Frame 中显示时进行调用。
        /// </summary>
        /// <param name="e">描述如何访问此页的事件数据。
        /// 此参数通常用于配置页。</param>
        protected override void OnNavigatedTo(NavigationEventArgs e)
        {
        }

        private void btnOpen_Click(object sender, RoutedEventArgs e)
        {
            if(!popup.IsOpen)
            {
                popup.IsOpen = true;
            }
        }

        private void btnClose_Click(object sender, RoutedEventArgs e)
        {
            if(popup.IsOpen)
            {
                popup.IsOpen = false;
            }

        }

        private void openLikePopup_Click(object sender, RoutedEventArgs e)
        {
            //设置Popup中的内容
            Border border = new Border();
            border.BorderBrush = new SolidColorBrush(Colors.Green);
            border.BorderThickness = new Thickness(1);
            border.Background = new SolidColorBrush(Colors.Coral);
            border.Width = 300;
            border.Height = 100;
            border.Child = new TextBlock() { Text="我是Popup",FontSize=25,HorizontalAlignment=HorizontalAlignment.Center,VerticalAlignment=VerticalAlignment.Center};

            //设置Popup的相关属性
            _popupToast.IsLightDismissEnabled = true;
            _popupToast.Child = border;
            //通过HorizontalOffset和VerticalOffset指定Popup的显示位置
            //如果不将Popup添加到某个容器内,则Popup的默认显示位置在屏幕左上角
            _popupToast.VerticalOffset = 100d;
            _popupToast.ChildTransitions = new TransitionCollection
            {
                new PaneThemeTransition(){Edge = EdgeTransitionLocation.Left}
            };
            _popupToast.IsOpen = true;
        }

        private void closeLikePopup_Click(object sender, RoutedEventArgs e)
        {
            if(_popupToast.IsOpen)
            {
                _popupToast.IsOpen = false;
            }
        }
    }
}

运行截图:

初始界面:

点击弹出按钮:

(Popup就会弹出来,然后不管点击关闭按钮或是在非Popup控件区域,Popup就会关闭)

(如果把CheckBox钩取消,那么点击非Popup区域,Popup不会关闭)

点击弹出仿制Popup按钮会发现Popup回想Toast通知一样从左侧滑出来,很好玩:

                        

多写写代码,多试试效果,多尝试自己所想的效果,実に おもしろい

时间: 2024-12-27 07:19:49

Windows Phone 8.1中的Popup的相关文章

Windows Phone 8.1中数据显示控件基石------ItemsControl

在Windows Phone 8.1中数据显示交互控件无外乎FlipView,ListView,GridView等,但我们用的时候总不能直接写 <FlipView/>,<ListView/>,<GridView/>之类来使用吧,虽说这样也可以,但这样呈现出来的画面就很难看了,哪 个用户会高兴看呢,反正我是不高兴看. 在这里问题就来了,不光要求数据能绑定到位,功能也到位,界面也总得美化美化吧. 好了进入正题了: 这些数据呈现控件的基石是谁呢?当然是ItemsControl

windows平台在tomcat中启动cas报错解决

windows平台在tomcat中启动cas报错: Caused by: java.lang.UnsatisfiedLinkError: Could not load library. Reasons: [no jansi in java.library.path, 系统找不到指定的路径.] 解决办法:将jansi.dll文件放到C:\Windows\System32目录下即可. 注意:jansi.dll文件在使用gradle编译打包cas时会下载到C:\Users\${用户名}\.gradle

Windows Server 2012 R2中通过IIS实现AD帐号密码修改功能

现在越来越多的企业会对AD帐号进行分类,例如将业务帐号.服务帐号同员工帐号分开管理,那么这类帐号也会因为业务应用特定类型而选择是否开启邮箱功能,再或者有些企业会采用腾讯企业邮箱或网易企业邮箱等等,这些平台本身同AD域是独立的,而且很多企业又使用MAC系统或计算机根本不加域,这时企业内网要搭建OA.WIKI.JIRA等一些需要调用AD中的LDAP让员工登录的系统时,则面临后期密码到期后用户没有入口去修改密码的问题.那么在今天我就要给大家介绍的是如何利用Windows Server 2012 R2中

怎样修复“Windows/System32/Config/System中文件丢失或损坏”故障

怎样修复“Windows/System32/Config/System中文件丢失或损坏”故障 英文原文引自 http://xphelpandsupport.mvps.org/how_do_i_repair_a_missing_or_cor1.htm 此类错误通常说明计算机由于注冊表的原因不能启动,下列操作应该可以修正以上错误.然而,须要特别注意的是,你须要将5个注冊表区域所有进行替换.仅仅简单的替换一个或者两个将会潜在的导致其它的错误 注意 假设你使用的是WindowsXP的OEM版本号,那么你

在Windows控制台应用程序中使用CString

CString是在windows平台下开发中经常使用的字符串类, CString已从MFC中剥离出来了,可以单独使用,只需引用atlstr.h头文件即可. 1 include "stdafx.h" 2 #include <atlstr.h> 3 #include <iostream> 4 5 using namespace std; 6 7 int _tmain(int argc, _TCHAR* argv[]) 8 { 9 //控制台应用程序中使用CStrin

Windows Phone获得IsolatedStorage中指定目录下的所有文件

在Windows Phone 中对隔离存储空间中的文件操作需要通过System.Io.IsolatedStorage下的类进行操作 获得指定文件夹下的所有文件: 参数:是指定文件夹的路径加上通配符,格式:\folder1\* List<string> GetFileNames(string _strFolder) { List<string> returnlst = new List<string>(); using (IsolatedStorageFile stora

windows 进程管理器中的内存是什么意思?

*内存 - 工作集:私人工作集中的内存数量与进程正在使用且可以由其他进程共享的内存数量的总和. *内存 - 峰值工作集:进程所使用的工作集内存的最大数量. *内存 - 工作集增量:进程所使用的工作集内存中的更改量. *内存 - 私人工作集:工作集的子集,它专门描述了某个进程正在使用且无法与其他进程共享的内存数量. *内存 - 提交大小:为某进程使用而保留的虚拟内存的数量. *内存 - 页面缓冲池:由内核或驱动程序代表进程分配的可分页内核内存的数量.可分页内存是可写入其他存储媒体(例如硬盘)的内存

Windows Server 2008 R2中Windows Server Backup功能之备份、恢复

在Windows Server 2008 R2中Windows Server Backup功能只有增量备份和完整备份 默认情况下,Windows Server Backup功能是没有被开启的,需要手动添加此功能. 打开服务器管理>点击功能>右键"添加功能" 选择需要添加的功能,下一步 再点击"安装" 正在安装中--. 提示已经安装成功,点"完成" 安装完成后,在开始菜单>所有程序>管理工具>Windows Serve

Windows Server 2008网络中顺畅访问“邻居”

通过网上邻居窗口寻找共享资源,是很多局域网用户经常要做的一项"功课",为了做好这项"功课",不少朋友积累和总结了不少网上邻居故障排除经验;然而这些经验在Windows Server 2008网络环境中,多数是没有多少用武之地的,毕竟Windows Server 2008系统是一种全新的工作环境,要想从Windows Server 2008网络中顺畅找到自己想要交往的"邻居",还需要总结新的网上邻居故障排除经验.为此,本文现在就对Windows S