csproj技巧,以及使用其他类库冲突,以及引入第三方UI方式
1、在项目中我们经常写
string? Message{get;set;}
明明是引用类型,它底下还是会出现波浪线,我们可以打开csproj
找到Nullable将它改为disable,或者删除,它默认是disable
<Nullable>disable</Nullable>
2、我们的WPF中可能会使用到Winform的类库,添加UseWindowsForms,一定要写在UseWPF下面
<UseWPF>true</UseWPF>
<UseWindowsForms>true</UseWindowsForms>
3、定制语言,防止其他语言注入
<SatelliteResourceLanguages>en</SatelliteResourceLanguages>
在 C# 中,.csproj 文件是一个 XML 格式的文件,用于描述项目的结构和元数据,包括了代码文件、依赖项、编译选项、输出文件等。而 MSBuild 是一个通用的构建引擎,用于构建和部署 .NET 应用程序和其他类型的项目。MSBuild 可以通过执行指定的 .targets 和 .props 文件来执行构建操作,这些文件定义了一些属性和任务,用于控制构建过程中的行为和流程。
在 Visual Studio 中,.csproj 文件是由 MSBuild 来处理的。当您在 Visual Studio 中打开一个项目时,MSBuild 将会读取 .csproj 文件,并根据其中的内容生成一个项目对象模型(Project Object Model,POM)。POM 是一个内存中的表示项目的结构和元数据的对象,它包含了所有的配置信息、元素和属性。在 Visual Studio 中,您可以通过 Solution Explorer 或 Property Pages 窗口来查看和修改 POM。
在构建过程中,MSBuild 将会使用 POM 中的信息来执行构建操作。MSBuild 首先会执行 .props 文件中定义的属性,然后执行 .targets 文件中定义的任务,最后将生成的输出文件保存到指定的目录中。通过扩展 .props 和 .targets 文件,您可以自定义构建过程中的行为并添加自己的任务和属性。
总之,.csproj 文件和 MSBuild 引擎是密切相关的,.csproj 文件描述了项目的结构和元数据,而 MSBuild 引擎则负责执行构建操作并生成输出文件
但是程序运行后,我们会发现bin目录下的dll,json,exe,pdb文件杂乱无章
我们需要将dll分门别类,用到nulastudio.NetBeauty库
按照下面的方式写
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>WinExe</OutputType>
<TargetFramework>net6.0-windows</TargetFramework>
<Nullable>enable</Nullable>
<UseWPF>true</UseWPF>
</PropertyGroup>
<PropertyGroup>
<BeautySharedRuntimeMode>False</BeautySharedRuntimeMode>
<!-- beauty into sub-directory, default is libs, quote with "" if contains space -->
<BeautyLibsDir Condition="$(BeautySharedRuntimeMode) == 'True'">../libraries</BeautyLibsDir>
<BeautyLibsDir Condition="$(BeautySharedRuntimeMode) != 'True'">./libraries</BeautyLibsDir>
<!-- dlls that you don't want to be moved or can not be moved -->
<!-- <BeautyExcludes>dll1.dll;lib*;...</BeautyExcludes> -->
<!-- dlls that end users never needed, so hide them -->
<!-- <BeautyHiddens>hostfxr;hostpolicy;*.deps.json;*.runtimeconfig*.json</BeautyHiddens> -->
<!-- set to True if you want to disable -->
<DisableBeauty>False</DisableBeauty>
<!-- set to False if you want to beauty on build -->
<BeautyOnPublishOnly>False</BeautyOnPublishOnly>
<!-- DO NOT TOUCH THIS OPTION -->
<BeautyNoRuntimeInfo>False</BeautyNoRuntimeInfo>
<!-- set to True if you want to allow 3rd debuggers(like dnSpy) debugs the app -->
<BeautyEnableDebugging>False</BeautyEnableDebugging>
<!-- the patch can reduce the file count -->
<!-- set to False if you want to disable -->
<!-- SCD Mode Feature Only -->
<BeautyUsePatch>True</BeautyUsePatch>
<!-- App Entry Dll = BeautyDir + BeautyAppHostDir + BeautyAppHostEntry -->
<!-- see https://github.com/nulastudio/NetBeauty2#customize-apphost for more details -->
<!-- relative path based on AppHostDir -->
<!-- .NET Core Non Single-File Only -->
<!-- <BeautyAppHostEntry>bin/MyApp.dll</BeautyAppHostEntry> -->
<!-- relative path based on BeautyDir -->
<!-- .NET Core Non Single-File Only -->
<!-- <BeautyAppHostDir>..</BeautyAppHostDir> -->
<!-- <BeautyAfterTasks></BeautyAfterTasks> -->
<!-- valid values: Error|Detail|Info -->
<BeautyLogLevel>Info</BeautyLogLevel>
<!-- set to a repo mirror if you have troble in connecting github -->
<!-- <BeautyGitCDN>https://gitee.com/liesauer/HostFXRPatcher</BeautyGitCDN> -->
<!-- <BeautyGitTree>master</BeautyGitTree> -->
</PropertyGroup>
<ItemGroup>
<PackageReference Include="nulastudio.NetBeauty" Version="2.1.4.4" />
</ItemGroup>
<ItemGroup>
<PackageReference Include="HandyControl" Version="3.5.1" />
<PackageReference Include="Newtonsoft.Json" Version="13.0.3" />
<PackageReference Include="Prism.Wpf" Version="9.0.401-pre" />
<PackageReference Include="Prism.DryIoc" Version="9.0.401-pre" />
</ItemGroup>
</Project>
注意,需要我们新建VS自带的,个别模板会和NetBeauty冲突,例如Prism
他虽然会编译成功,但是会启动失败,这个时候我们要删除App.xaml和App.xaml.cs
启动改为下面形式
/// <summary>
/// 使用Prism自带的模板启动失败,删除App.xaml和App.xaml.cs
/// 改为Main方法启动
/// </summary>
public class Program
{
[STAThread]
public static void Main()
{
Application application = new Application();
MainWindow win=new MainWindow();
application.Run(win);
}
}
说到这了,我顺便说下删除App后的几种启动方式
[STAThread]
static void Main() {
Application app = new Application();
MainWindow win = new MainWindow();
app.MainWindow = win;
win.Show(); // 显示窗体
app.Run(); // 调用无参数的Run()方法
}
[STAThread]
static void Main() {
Application app = new Application();
app.StartupUri = new Uri("MainWindow.xaml",UriKind.Relative);
app.Run();
}
说到这里,再顺便说一句,我们如果把App.xaml删除了,那么我们使用第三方UI的时候怎么办呢
这是我使用Furiom框架写的WPF程序的启动,我是删除了App.xaml的,改用了
public class Program
{
[STAThread]
public static void Main(string[] args)
{
// Serve.RunGeneric();
Serve.RunNative(GetComponent());
var app = new Application();
app.Startup += (sender, e) =>
{
//程序启动加载上一次关闭时SetData的数据状态
// 加载类库中的主题资源
var themeResourceDictionary = ResourceExtension.LoadTheme();
Application.Current.Resources.MergedDictionaries.Add(themeResourceDictionary);
//WPF全局异常捕获
ThreadExceptionHandler handler = new ThreadExceptionHandler();
//UI线程抛出异常
// Application.Current.DispatcherUnhandledException += handler.Current_DispatcherUnhandledException;
//非UI线程抛出异常
// AppDomain.CurrentDomain.UnhandledException += handler.CurrentDomain_UnhandledException;
//Task线程抛出异常
// TaskScheduler.UnobservedTaskException += handler.TaskScheduler_UnobservedTaskException;
//扫描全局的json文件
// JsonExtension.GetDefaultJsonLevel();
};
if (Native.CreateInstance<LoginView>().ShowDialog() == true)
{
//关闭登录窗体
Native.CreateInstance<LoginView>().Close();
}
}
ResourceExtension是我自己定义的静态类
在这里我写两种方式供大家参考
/// <summary>
/// 加载资源字典的两种方式
/// </summary>
public static class ResourceExtension
{
public static ResourceDictionary Read()
{
var dictionaryXaml = @"
<ResourceDictionary xmlns=""http://schemas.microsoft.com/winfx/2006/xaml/presentation""
xmlns:x=""http://schemas.microsoft.com/winfx/2006/xaml"">
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source=""pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Light.xaml"" />
<ResourceDictionary Source=""pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Defaults.xaml"" />
<ResourceDictionary Source=""pack://application:,,,/MaterialDesignColors;component/Themes/Recommended/Primary/MaterialDesignColor.Blue.xaml"" />
<ResourceDictionary Source=""pack://application:,,,/MaterialDesignColors;component/Themes/Recommended/Accent/MaterialDesignColor.Indigo.xaml"" />
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>";
return (ResourceDictionary)System.Windows.Markup.XamlReader.Parse(dictionaryXaml);
}
public static ResourceDictionary LoadTheme()
{
// 加载资源字典
var resourceDictionary = new ResourceDictionary();
resourceDictionary.Source = new Uri("/System.MES.Theme;component/Properties/ApplicationResource.xaml", UriKind.RelativeOrAbsolute);
return resourceDictionary;
}
}
csproj技巧,以及使用其他类库冲突,以及引入第三方UI方式的更多相关文章
- Atitit 类库冲突解决方案 httpclient-4.5.2.jar
Atitit 类库冲突解决方案 httpclient-4.5.2.jar 错误提示如下1 版本如下(client and selenium)2 解决流程2 挂载源码 (SSLConnectionSo ...
- Atitit 类库冲突 解决方案
Atitit 类库冲突 解决方案 表现情况,找到不某些方法 类等,一个情况是真的找不到,一个情况是加载了错误的jar,导致正确的jar无法加载.. 1.1. 查找现在ide正在使用的jar1 1.2. ...
- xcode引入第三方静态类库 duplicate symbol _OBJC_XXX 重复编译错误
xcode引入第三方静态类库 duplicate symbol _OBJC_XXX 重复编译错误 一:场景 xcode 同时引入了 libA.a, libB.a 两个静态类库,如果 这两个静态类库之中 ...
- laravel5.3引入第三方类库的方法
laravel版本:5.3 今天做的是引入第三方的phpquery类库,方法: 在laravel的app目录下自定义一个文件夹,我用的名字是:Libs 然后直接将phpquery类库扔进这个目录 在c ...
- Laravel Controller中引入第三方类库
Laravel 引入第三方类库 在Controller中引入自定义的php文件,先在app目录下创建一个新的文件夹,命名Tools(可自定义),接着创建一个MyTest.php: <?php c ...
- 走进webpack(2)--第三方框架(类库)的引入及抽离
在当代的前端开发中,很少会用原生JS来开发页面,最基本的都会使用jQuery来节省我们开发的时间和效率,而angular,vue,react的出现更是为前端开发者带来了福音.那么这篇文章就说说如何用w ...
- TP3.2之引入第三方类库文件和普通.php文件
1.引入第三方类库 .class.php文件 1.1 类库有写namespace命名空间 namespace Org\Util; class Auth { } 保存到ThinkPHP/Library/ ...
- 180710-MySql插入唯一键冲突的三种可选方式
MySql插入时唯一键冲突的几种处理方式 MySql插入一条记录,结果提示主键冲突,怎么办? 批量插入数据时,发现插入的这批数据中,有某些记录存在唯一键冲突,一个一个跳出来就比较麻烦了,有什么好的办法 ...
- angular4(2-1)angular脚手架引入第三方类库(jquery)
欢迎加入前端交流群交流知识&&获取视频资料:749539640 如何在angular4脚手架中引入第三方类库呢比如jquery.swiper.bootstrap...... 例如引入j ...
- Laravel 引入第三方类库及自定义函数
1.新建一个目录放第三方类库 2.找到composer.json文件打开,在里面autoload 下classmap下面加入类库路径 3根目录下运行composer dumpautoload 4.使用 ...
随机推荐
- Linux Shell 字符串截取方法
Linux 的字符串截取很有用.有八种方法. 假设有变量 var=http://www.aaa.com/123.htm. 1. # 号截取,删除左边字符,保留右边字符. 代码如下: echo ${va ...
- NC24048 [USACO 2017 Jan P]Promotion Counting
题目链接 题目 题目描述 The cows have once again tried to form a startup company, failing to remember from past ...
- linux 测试网络速率
1. ethtool ethtool是很强大的查询网卡(嵌入式称为phy芯片)配置的工具,几乎phy芯片芯片手册寄存器能配置的选项,ethtool都能查询到:嵌入式调试phy芯片的时候经常用到该命令: ...
- STM32F401的外部中断EXTI
stm32f401 EXTI EXTI就是External interrupt/event controller, 外部事件和中断控制器, 包含21条边沿检测线. 每条线可以独立设置触发事件(上升沿, ...
- 使用JS快速读取TXT文件
1 前言 最近有个需求,需要使用JS快速读取外部大数据文件(60w条记录的表).笔者尝试过使用JS读取Excel文件,但是跑了十几分钟仍未出结果,后来笔者尝试将原数据保存为TXT文件,再从TXT文件中 ...
- 【Unity3D】Tank大战
1 需求实现 项目代码见→坦克大战1.1.0 1)人机交互 玩家通过 ↑ ↓ ← → 键(或 W.S.A.D)键控制己方坦克平移: 玩家通过滑动鼠标右键控制己方坦克左右旋转: 玩家通过鼠标左键 ...
- 对yuv存储格式中的yuv420p和yuv420sp的理解
一.对yuv的认识 yuv是一种颜色编码系统,它将图像的亮度和色度分离开来.y表示亮度,即黑白信息:uv表示色度,即颜色信息.yuv常用于视频压缩和传输中,因为它可以更有效地表示人眼对亮度和色度的敏感 ...
- Redis原理再学习03:数据结构-链表 list
链表list介绍 1. 链表list简介 链表(linked list)是一种基础数据结构,是一种线性表,但是不会按照线性表的顺序存储数据,而是在每一个节点里存到下一个节点的指针. 链表插入节点时是 ...
- ProtoBuf 基本使用
一.是什么 Protocol Buffers,是Google公司开发的一种数据描述语言,是一种平台无关.语言无关.可扩展且类似于XML能够将结构化数据序列化,可用于数据存储.通信协议等方面. 二.为什 ...
- macOS Monterey 与以下电脑兼容下载操作流程解析
有时在开发iOS应用时我们时常遇到各种情况,比如手机升级了Xcode不支持这时候需要安装xcode但是xcode需要依奈相应系统本人小编整理了这种情况无法解决问题. 首相打开苹果标志进入到下面界面 进 ...