zoukankan      html  css  js  c++  java
  • WPF之基础概念

    一:App环境承载

       我们都知道Console和WinForm程序的入口都是Main函数,WPF同样也不例外,好了,我们就新建一个WPF应用程序,VS会给我们自动生成一个MainWindow.xaml和App.xaml文件。

       

       微软官方说WPF程序是从Application开始的,既然是开始总有个入口点吧,奇怪的是我们并没有发现Main函数,程序又是如何Run起来的呢?

       

    其实,wpf为了简化我们的工作,把一些机械性的代码透明了,那么我们如何找到这个Main函数呢?很简单,我们编译一下程序,发现

    App.xaml最后生成了App.g.cs的部分类,并且发现StartupUri是MainWindow.xaml,也就是说程序一运行,MainWindow.xaml将会启动。

        

    二:WPF中Application的生命周期

         我们知道webform中的Global文件定义了一个应用程序的全局生命周期,或许有人问,生命周期能够干些什么,其实干的事情可多着呢,

    比如我们可以做一些身份验证,或者一些信息的初始化,那么wpf中到底有哪些对应的方法和事件呢?

    1、OnStartup方法 => Startup事件

         这个就见名识意了,在上图中app.Run()时触发。

    2、OnSessionEnding方法 =>SessionEnding 事件

         系统关机前调用

    3、OnExit方法 => Exit事件

         应用程序关闭前调用。

    4、OnActivated方法 =>  Activated 事件

         应用程序获得焦点的时候触发。

    5、OnDeactivated方法 => DeActivated事件

         应用程序失去焦点的时候触发。

     1 using System;
     2 using System.Collections.Generic;
     3 using System.Configuration;
     4 using System.Data;
     5 using System.Linq;
     6 using System.Windows;
     7 
     8 namespace Wpf_Template
     9 {
    10     /// <summary>
    11     /// App.xaml 的交互逻辑
    12     /// </summary>
    13     public partial class App : Application
    14     {
    15         protected override void OnStartup(StartupEventArgs e)
    16         {
    17             base.OnStartup(e);
    18 
    19             //TODO your code
    20         }
    21         protected override void OnSessionEnding(SessionEndingCancelEventArgs e)
    22         {
    23             base.OnSessionEnding(e);
    24 
    25             //TODO your code
    26         }
    27         protected override void OnActivated(EventArgs e)
    28         {
    29             base.OnActivated(e);
    30 
    31             //TODO your code
    32         }
    33         protected override void OnDeactivated(EventArgs e)
    34         {
    35             base.OnDeactivated(e);
    36 
    37             //TODO your code
    38         }
    39         protected override void OnExit(ExitEventArgs e)
    40         {
    41             base.OnExit(e);
    42 
    43             //TODO your code
    44         }
    45     }
    46 }

    三:全局异常获取

         在webform中的Global文件中有一个Application_Error方法,专门用来捕获整个应用程序的异常,以至于不会出现“黄白页”给用户,以此来提高

    系统的健壮性和安全性,那么wpf中也有类似的方法吗?当然,wpf跟webform神似,他有的我也有,这里是一个DispatcherUnhandledException

    事件,然后我们在OnStartup注册一下就Ok了。

     1 namespace Demo
     2 {
     3     /// <summary>
     4     /// App.xaml 的交互逻辑
     5     /// </summary>
     6     public partial class App : Application
     7     {
     8         protected override void OnStartup(StartupEventArgs e)
     9         {
    10             base.OnStartup(e);
    11 
    12             //注册Application_Error
    13             this.DispatcherUnhandledException += new DispatcherUnhandledExceptionEventHandler(App_DispatcherUnhandledException);
    14 
    15         }
    16 
    17         //异常处理逻辑
    18         void App_DispatcherUnhandledException(object sender, System.Windows.Threading.DispatcherUnhandledExceptionEventArgs e)
    19         {
    20             //处理完后,我们需要将Handler=true表示已此异常已处理过
    21             e.Handled = true;
    22         }
    23     }
    24 }

    好,下面我们做了示例:

    首先我们拖一个button,事件处理中故意抛出异常。

     1 namespace Demo
     2 {
     3     /// <summary>
     4     /// MainWindow.xaml 的交互逻辑
     5     /// </summary>
     6     public partial class MainWindow : Window
     7     {
     8         public MainWindow()
     9         {
    10             InitializeComponent();
    11         }
    12 
    13         private void button1_Click(object sender, RoutedEventArgs e)
    14         {
    15             throw new Exception("我就害你,我就抛异常");
    16         }
    17     }
    18 }

    然后我们在Application_Error中进行处理,当然实际应用中应该是记一些log日志。

    1 //异常处理逻辑
    2         void App_DispatcherUnhandledException(object sender, System.Windows.Threading.DispatcherUnhandledExceptionEventArgs e)
    3         {
    4             MessageBox.Show("谁tmd惹祸了:" + e.Exception.Message);
    5 
    6             //处理完后,我们需要将Handler=true表示已此异常已处理过
    7             e.Handled = true;
    8         }

    最后看一下效果,注意,我们的程序并没有崩溃。

  • 相关阅读:
    共轭梯度法
    OpenGLGLUT教程(十一) GLUT子菜单
    怎样让函数返回数组
    OpenGLGLUT教程(九) GLUT鼠标
    OpenGLGLUT教程(七) GLUT高级键盘控制
    OpenGLGLUT教程(六) GLUT场景漫游
    OpenGLGLUT教程(五) GLUT键盘控制
    OpenGLGLUT教程(八) GLUT场景漫游II
    dos指令 批处理文件
    新的启程!
  • 原文地址:https://www.cnblogs.com/Tally/p/4255603.html
Copyright © 2011-2022 走看看