通过App.xaml理解wpf中的Application类

  这个章节来了解Application类,我考虑了一晚上决定跳过控件类相关的学习,因为控件如果只是入门的话每个控件F12跳过去看一下属性、事件就能大致了解的差不多,而且控件比较多,每个都这样看一遍,感觉意义不大。同时控件的使用一般又同时包含了,资源、样式、触发器、模板、绑定、列表控件的话,可能还包含列表虚拟化和数据虚拟化。所以想了一下。打算先讲Application类。

  教程的第一篇我们从hello world开始了解什么是程序。它是如何编译、生成和运行的。现在这一个篇从App.xaml讲解Application类中能包含哪些东西,。这个Application类有哪些应用场景。

App.xaml 里包含什么

我们新创建一个WPF的程序,默认什么代码也不改动的情况下双击程序代码中的App.xaml。我们看到如下代码:

<Application x:Class="ApplicationLifeCycle.App"
       xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
       xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
       xmlns:local="clr-namespace:ApplicationLifeCycle"
       StartupUri="MainWindow.xaml">
  <Application.Resources>

  </Application.Resources>
</Application>

我们就讲这些里面一部分常用的,剩下的建议以我们同样的分析思路,去观察一下其他的。

1)首先我们看程序启动后的第一步。通过OnStartUp()方法做启动参数检查。
我们通过OnStartUp()方法的重写来区分不同启动参数,可以让程序干很多不同的事情,我们打开任务管理器=》Name列右键点击=》勾选显示Command line,位置如下:

这样我们就可以看到当前很多其他程序,都是由启动参数的,启动参数按空格分割,有的程序会有一组参数,所以对我们来说,启动参数同样也是很重要的东西。不管是单例,还是让程序启动不同的功能,启动参数就是软件功能解耦的第一步。

我们找到上上个截图的OnStartup方法,我们在App.xaml.cs里重写他,代码如下,并在解决方案下的程序集右键=》属性=》左侧列表选择调试=》命令行参数这里添加对应的调试参数,我们这里设置用空格分割一句话,这样我们就可以调试了,F5启动。

using System.Text;
using System.Windows;

namespace ApplicationLifeCycle
{
  /// <summary>
  /// App.xaml 的交互逻辑
  /// </summary>
  public partial class App : Application
  { 

    protected override void OnStartup(StartupEventArgs e)
    {
      base.OnStartup(e);
      StringBuilder sb = new StringBuilder();
      foreach (var item in e.Args)
      {
        sb.Append(item);
      }
      MessageBox.Show($"args length as {e.Args.Length},args content as {sb.ToString()}");

    }
  }
}

我们看到了参数是4行,内容是-hello duwenong Mastery C#。这样我们通过重写OnStartup就可以实现参数对不同的参数做不同的处理。

2)用户注销,但是程序正在处理关键任务,通过重写OnSessionEnding()来提示当前工作尚未结束。
我们通过重写OnSessionEnding()可以在重要工作没做完但是,用户选择关机、重启或注销电脑时提示用户我们有任务尚未结束。

private bool _unsavedData = false;
    public bool UnsavedData
    {
      get { return _unsavedData; }
      set
      {
        _unsavedData = value;
      }
    }

    protected override void OnSessionEnding(SessionEndingCancelEventArgs e)
    {
      base.OnSessionEnding(e);
      //假设某些线程未完成保存,把UnsaveData设置为True
      UnsavedData = true;
      if (UnsavedData)
      {
        e.Cancel = true;
        MessageBox.Show($"我们的数据尚未保存完毕,{e.ReasonSessionEnding} 将丢失数据。");
      }
    }

3)默认启动那个Window窗体。我们使用StartupUri设置可以修改默认启动的Window窗体。

这样启动的就是我们新创建的Window1.

4)通过ShutdownMode修改程序默认的关闭方式。

1.OnExplicitShutdown 这个方法比较特殊,他是除非通过代码调用了Application.Shutdown()方法,否则即使所有窗口都关闭了,程序仍然驻留再后台。
2.OnLastWindowClose 这个是默认的值,只要至少有一个窗口存在,应用程序就保持运行状态,但是注意如果关闭了主窗口,MainWindow扔就指向当时的窗体,需要代码切换MainWindow到其他窗体
3.OnMainWindowClose 这个是只要主窗体还处于打开状态,应用程序就保持运行,如果主窗体关闭进程就退出。

5)使用Application.Current访问当前Application的实例

private void GetCurrentWindowListButton_Click(object sender, RoutedEventArgs e)
    {
      Window mainWindow = Application.Current.MainWindow;
      foreach (var item in Application.Current.Windows)
      {
        var title = ((Window)item).Title;
      }

    }

我们使用代码获取当前打开的所有window的标题。

Application的属性和方法目前就写这么多,其他的大家可以自己F12看一下并尝试写一下代码,资源和资源的查找虽然也是Application下的。但是我觉得这点要要出来单独讲,所以就不写在这里啦。

以上就是通过App.xaml理解wpf中的Application类的详细内容,更多关于理解wpf中的Application类的资料请关注我们其它相关文章!

(0)

相关推荐

  • c# wpf使用GMap.NET类库,实现地图轨迹回放

    前言 实现轨迹回放,GMap.NET有对应的类GMapRoute.这个类函数很少,功能有限,只能实现简单的轨迹回放.要实现更复杂的轨迹回放,就需要自己动手了. 本文介绍一种方法,可以实现复杂的轨迹回放.有句话"功夫在诗外",GMap.NET给你提供了基本地图处理功能:但是不要让CMap.NET束缚了手脚.你需要有深刻理解地图实现原理,深入理解WPF动画的原理,才能到达随心所欲.最终的效果如下: GMap.NET 显示原理 地图就是由许多方格"瓦片"组合而来.当你移动

  • c# 基于GMap.NET实现电子围栏功能(WPF版)

    前言 GMap.NET是一个强大.免费.跨平台.开源的.NET控件.分为WPF和winform版.GMap.NET的基本知识不做过多介绍,本文主要介绍如何使用该控件实现电子围栏功能. 电子围栏主要有两个功能模块:界面展示围栏区域,判断人员出入围栏的逻辑.GMap.NET的WPF版本功能并不强大,实现一些复杂的功能就只能发掘WPF的潜力了.GMap.NET给我们提供了一个基本的平台,必须熟练掌握WPF才能开发出复杂gis产品. 围栏区域界面显示 1 认识 GMapMarker GMapContro

  • 详解WPF中的对象资源

    在WPF中,所有继承自FrameworkElement的元素都包含一个Resources属性,这个属性就是我们这篇要讲的资源. 这一篇讲解的资源是不是上一篇的程序集资源(那个是在编译过程中打包到程序集中),这个是资源是我们想在公共的地方写一个对象让其他元素重复使用. 先贴个例子: <Window x:Class="NETResource.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/pre

  • c# wpf如何更好的使用Application程序集资源

    这一篇单独拿出来分析这个程序集资源,为的就是不想让大家把程序集资源和exe程序强关联,因为程序集资源实际上是二进制资源,后续编译过程中会被嵌入到程序集中,而为了更方便的使用资源,我们要好好梳理一下程序集资源相关的知识.(例如多语言资源,多工程.多项目使用的公共资源文件). 1)在程序集中添加资源 我们通过向项目添加文件并尝试修改资源文件属性看有什么不同的结果. 在工程上右键=>添加=>新建文件夹=>改名为Images=>回车=>在Images文件夹上右键=>添加=>

  • C# WPF如何反射加载Geometry几何图形数据图标

    相信大家在阅读WPF相关GitHub开源项目源码时都会看见一串串这种数据 这种Geometry数据就是几何图形数据 为什么要用Geometry数据做图标? 有一种做法是使用ttf字体文件代替,不过使用ttf字体文件会出现下面几个缺点: 1.团队协作不便于管理 2.需要依赖特定平台 3.无法灵活使用 而使用Geometry的话,我们可以将这些几何图形数据存入资源字典ResourceDictionary 通过反射进行灵活使用,团队开发可共同维护 怎么获取Geometry数据? 我们进入https:/

  • 详解WPF中的隧道路由和冒泡路由事件

    WPF中使用路由事件升级了传统应用开发中的事件,在WPF中使用路由事件能更好的处理事件相关的逻辑,我们从这篇开始整理事件的用法和什么是直接路由,什么是冒泡路由,以及什么是隧道路由. 事件最基本的用法 在基于事件驱动的开发中,把代码放在响应注册的事件的处理函数内,比如Click事件.MouseDown事件.MouseUp事件等等.每个控件响应自己的注册事件,有很多如果在事件上有相互关联和影响的事件,就要在一个业务逻辑里写比较多的代码.而路由事件主要的优势就是路由事件可以在元素树上进行传递,并且沿着

  • c# wpf如何附加依赖项属性

    附加依赖项属性是一个属性本来不属于对象自己,但是某些特定场景其他的对象要使用该对象在这种场景下的值.这个值只在这个场景下使用.基于这个需求设计出来的属性.这里主要涉及到一个解耦问题.最大的优势是在特定场景下使用的属性,可以在特定场景下定义.这样业务上不会导致代码全部混在某个模块里.提升代码可维护性. 我们举例一段代码.假设有个类Person.包含了身份ID(IdentityID),姓名(Name),出生年月(Birth date),性别(gender),民族(Nation). 有一个School

  • c# wpf如何使用Blend工具绘制Control样式

    本文通过设计一个RadioButton,分享下使用Blend绘制Path的方法.待绘制的RadioButton样式如下文所示,如有更好的方法实现该样式,欢迎交流. 实现效果 将要实现的RadioButton样式如下图,可以看出按钮的笔尖和笔身的填充色,以及选中时右上方圆形的填充色一致,代表笔的颜色. 实现方式 笔身使用矩形,填充色绑定按钮背景色:笔头部分使用闭合的Path,其中笔尖的颜色同样绑定按钮背景色:右上方的圆形使用Ellipse,填充色同样绑定按钮背景色. 实现步骤 1.打开Blend,

  • C# WPF实现的语音播放自定义控件

    原理很简单,利用Path画一个图,然后用动画进行播放,播放时间由依赖属性输入赋值与控件内部维护的一个计时器进行控制. 控件基本是玩具,无法作为真实项目使用. 因为没有设置播放源,所以编写异步播放源或者实际播放时候要将事件引发,是否播放等属性,事件移到真实播放事件 非专业UI,即使知道怎么画图也是画的不如意,到底是眼睛会了,手不行啊. 主界面xaml <local:VoiceAnimeButton Height="40" Width="200" IconMarg

  • 详解WPF的InkCanvas选择模式

    InkCanvas是WPF中进行墨迹绘制的控件,本文介绍下InkCanvas控件是如何进行选择操作的.文中有误的地方希望大家进行批评指正. InkCanvas的选择效果 使用WPF可以轻松实现白板功能,只需要添加一个InkCanvas控件.修改InkCanvas的EditingMode属性可以控制InkCanvas的操作模式,如书写.选择.擦除等模式. 如下demo在窗口中添加一个InkCanvas,然后添加一个Button实现书写与选择模式的切换. // xaml <Grid> <In

  • c# WPF中的TreeView使用详解

    在wpf中实现treeview的功能,可能看到很多分享的都是简单的绑定,仅此记录自己完成的功能. 前台 <TreeView x:Name="chapterTree" Grid.Column="0" SelectedItemChanged="chapterTree_SelectedItemChanged" PreviewMouseRightButtonDown="chapterTree_PreviewMouseRightButton

随机推荐