win 8 ProgressRing加多线程

当我们点击一个按钮执行放大 时,因为放大的数据可能很大,需要一定的等待时间,这个时候为了更好的体验,我们需要加一个ProgressRing,界面布局如下

 <Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">
        <Popup Name="popup" Visibility="Visible" IsOpen="False">
            <Grid Width="{Binding ElementName=pageRoot,Path=ActualWidth}" Height="{Binding ElementName=pageRoot,Path=ActualHeight}" Background="#89000000">
                <ProgressRing Visibility="Visible" Width="400" Height="400" Name="ring" IsActive="False" FontFamily="Global User Interface"></ProgressRing>
            </Grid>
        </Popup>
        
        <ScrollViewer ZoomMode="Enabled" ZoomSnapPointsType="None" MaxWidth="2000">
            <Grid Name="grid" Background="White">
                <Grid.RowDefinitions>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                    <RowDefinition></RowDefinition>
                </Grid.RowDefinitions>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                    <ColumnDefinition></ColumnDefinition>
                </Grid.ColumnDefinitions>
            </Grid>
        </ScrollViewer>       
    </Grid>
    <Page.BottomAppBar>
        <AppBar>
            <StackPanel>
                <Button x:Name="largeButton" Style="{StaticResource ZoomInAppBarButtonStyle}" AutomationProperties.Name="放大" Click="largeButton_Click" />
            </StackPanel>
        </AppBar>
    </Page.BottomAppBar>

后台初始化界面

 private void initButton()
        {
            for (int i = 0; i < 10; i++)
            {
                for (int j = 0; j < 14; j++)
                {
                    Button btn = new Button();
                    btn.Width = 60;
                    btn.Height = 60;
                    btn.BorderThickness = new Thickness(2);
                    btn.BorderBrush = new SolidColorBrush(Colors.Black);
                    btn.Foreground = new SolidColorBrush(Colors.Black);
                    btn.Content = i.ToString() + "," + j.ToString();
                    Grid.SetRow(btn, i);
                    Grid.SetColumn(btn, j);
                    this.grid.Children.Add(btn);
                }
            }

        }

就是简单的在前台加入一些按钮,执行对这些按钮的放大。

private void largeButton_Click(object sender, RoutedEventArgs e)
        {
            //showLoading();
            var task = Task.Factory.StartNew(() => showLoading());
            //Task task = new Task(() => longTime());            
            //task.Start();
            longTime();//如果没有多任务,直接执行这个函数,是不行的,前台线程会阻塞
            task.Wait();

            closeLoading();
        }
        /// <summary>
        /// 显示加载
        /// </summary>
        private void showLoading()
        {
            this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
                {
                    this.popup.IsOpen = true;
                    this.ring.IsActive = true;
                });

        }
        /// <summary>
        /// 关闭加载
        /// </summary>
        private void closeLoading()
        {
            this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
                {
                    this.popup.IsOpen = false;
                    this.ring.IsActive = false;
                });

        }
        /// <summary>
        /// 耗时间的操作
        /// </summary>
        private void longTime()
        {
            this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
                {
                    for (int i = 0; i < 100; i++)
                    {
                        foreach (Button btn in this.grid.Children)//耗时间的操作
                        {
                            btn.Width += 10;
                            btn.Height += 6;
                        }
                    }
                });
        }


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值