首页
学习
活动
专区
圈层
工具
发布

WindowsXamlHost:在 WPF 中使用 UWP 控件库中的控件

本文将介绍如何在 WPF 项目中引用 UWP 的控件库。 创建一个 UWP 控件库 建议专门为你复杂的 UWP 控件创建一个 UWP 控件库。在这个控件库中的开发就像普通 UWP 应用一样。...现在,右击卸载项目,再右击编辑项目文件: image.png ▲ 编辑项目文件 找到 Import targets 的哪一行,你需要在那一行前面的任意位置添加以下特别标注为新增的几行: ++...image.png ▲ 生成的文件已复制到 WPF 目录下 在 WPF 项目中间接引用 UWP 控件库 现在,在 WPF 项目中开启所有文件夹的显示,然后将 UWP 项目中生成的文件添加到 WPF...项目中: image.png ▲ 在 WPF 的项目中添加 UWP 的控件库 为了能够在每次编译 WPF 项目的时候确保 UWP 项目先编译,需要为 WPF 项目设置项目依赖。...在依赖对话框中将 UWP 项目设为依赖。

7.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    WPF DataGrid 如何将被选中行带到视野中

    WPF DataGrid 如何将被选中行带到视野中 目录 前言 准备工作 方法一 方法二 总结 独立观察员 2021 年 12 月 11 日 前言 在 WPF 开发中,显示表格一般使用 DataGrid...使用的还是之前用过的 DataGrid 的 Demo 程序(在《WPF DataGrid 通过自定义表头模拟首行固定》和《WPF 触屏事件后触发鼠标事件的问题及 DataGrid 误触问题》中用过),加了一个可以填写要选中的行号的文本框...,以及一个执行选中操作的按钮: 下面来演示一下没有自动将选中行带到视野中的情况。...方法一 这个方法是参考《【翻译】WPF 中附加行为的介绍 Introduction to Attached Behaviors in WPF》文章中的将 TreeViewItem(树状列表项)带到视野中的方法...先给 DataGrid 命个名(如 x:Name="Dg" )方便后台使用,然后在 ViewModel 中添加一个选中项改变事件 SelectedItemChanged,并在选中项改变时调用(参数为选中行的索引

    2.8K10

    WPF 手绘对称图形控件

    本文来安利大家一个我刚做的控件,这个控件支持触摸下多指进行笔迹绘制,绘制过程中将会对称显示出水平和垂直翻转的笔迹。可以用来绘制对称图形。...我将这个控件在GitHub上完全开源,代码放在 https://github.com/lindexi/uwp 虽然这是放在 UWP 仓库的控件,但现在只支持 WPF 框架 下面来告诉大家如何使用这个控件...在 WPF 中如何让控件进行水平和垂直的翻转?...了解了这两个问题,就可以很简单制作这个控件 我有一篇博客,告诉大家如何在 WPF 中使用简单的代码制作一个支持多指笔迹的控件,请看 WPF 最简逻辑实现多指顺滑的笔迹书写 在 WPF 中实现翻转特别简单...,只需要让缩放作为负数就可以了,如下面代码 WPF 博客" Padding="5"

    1.2K20

    .NET Core.NET5.NET6 开源项目汇总11:WPF组件库1

    微软提供的WPF控件的功能很强大,但是样式不漂亮,需要专业的美工设计样式或皮肤。圈子里总有无私奉献的大牛们分享既漂亮又好用的WPF组件库,下面收集了几款非常优秀的WPF开源组件。...开源项目是众多组织与个人分享的组件或项目,作者付出的心血我们是无法体会的,所以首先大家要心存感激、尊重。请严格遵守每个项目的开源协议后再使用。尊重知识产权,共建和谐开源社区。...通过XAML工具箱中的设计,可以使用现代流行的设计语言轻松地将漂亮的桌面应用程序带到生活中。...3、按钮 多种形状的交互按钮,如圆形按钮、图标按钮、按钮进度、按钮文字提示等等,Web中常见的效果WPF中也可以简单地使用。 ?...更多功能请参考官网与开源项目。

    3.7K30

    WPF 使用 Microsoft.Toolkit.Wpf.UI.Controls 的 InkCanvas 时加上背景色和按钮方法

    本文来告诉大家如何在 WPF 应用 HOST 了 UWP 的 InkCanvas 控件时,给 InkCanvas 控件设置背景色,加上按钮等业务功能的实现方法 在上一篇博客有告诉大家如何在 WPF 里面使用上...UWP 的项目,其中一个是 UWP 的空白应用项目,另一个是 UWP 的控件项目。...让 UWP 的控件项目作为实际的 UWP 自定义控件编写的项目,咱将在 UWP 的控件项目里面完成所有的自定义逻辑 如何创建项目和如何组织,还请参阅 官方文档 本文这里就不多说了 回到如何给 UWP 的...InkCanvas 控件添加背景色的方法上,在新建的 UWP 控件项目里面,添加一个自定义的控件,如 CustomInkControl.xaml 控件 在这个控件里面的 XAML 添加如下代码 <UserControl...InkCanvas.InkPresenter.InputDeviceTypes = CoreInputDeviceTypes.Mouse| CoreInputDeviceTypes.Touch; } 接着如

    3.3K20

    dotnet 读 WPF 源代码笔记 WriteableBitmap 的渲染和更新是如何实现

    如何在 WriteableBitmap 写文字 WPF 使用不安全代码快速从数组转 WriteableBitmap 在 WriteableBitmap 进行绘制时,有一个重要的功能是设置 DirtyRect...两个缓存,前面的缓存是用在实际显示的对象,后面的缓存是用的是一个数组用于给 WPF 上层使用访问 在 WPF 的渲染过程中,按照 DirectX 应用的渲染步骤,第一步就是收集过程,在收集过程中收集绘制信息...收集过程中将会调用到 CSwDoubleBufferedBitmap 的 CopyForwardDirtyRects 方法,这个方法的作用就是根据脏区从后面的缓存将像素复制到前面的缓存。...也就是说通过 DirtyRect 能优化的性能也只是更新前面的缓存用到的拷贝的性能,我没有在官方文档里面找到 CopyPixels 里面还会记录 DirtyRect 的功能,同时也没有在 WPF 自定义渲染管线里面找到只刷新图片某个范围的逻辑...,因此可以认为使用 WriteableBitmap 的更新,设置 DirtyRect 只影响第二次复制数据的性能,而不会影响渲染性能,依然是整个图片进行渲染 在拷贝到前面的缓存之后,在 WPF 中是在自定义渲染管线里面将前面的缓存作为纹理绘制到形状上

    1.2K20

    WPF 像素着色器入门:使用 Shazzam Shader Editor 编写 HLSL 像素着色器代码

    将像素着色器放到 WPF 项目中 将像素着色器放到 WPF 项目中需要经过两个步骤: 找到生成的像素着色器文件,并放入 WPF 工程中; 修改像素着色器的生成方式。...将特效放入到你的 WPF 项目中 我们需要将两个文件加入到你的 WPF 程序中: 一个 .ps 文件,即刚刚的 .fx 文件编译后的像素着色器文件; 一份用于驱动此像素着色器的 C# 代码。...如果你使用的是旧的项目格式,则右键此 .ps 文件的时候选择属性,你可以在 Visual Studio 的属性窗格的生成操作中将其设置为 Resource。...当然,需要在前面引入 XAML 命名空间。...尝试将一个示例像素着色器编译完并放入到你的 WPF 项目中。 尝试将特效应用到你的一个 WPF 控件中查看其效果。

    2K20

    Grid 布局算法!自己动手实现一个 Grid

    目前用在个人项目中还是不错的,不过还需要大家在开源社区中多多支持。 我为它写了一个全新的 Grid 布局算法,此算法是 WPF 在通常情况下的性能的两倍。本文将分享我在此项目中实现的算法的原理。...比如: 可以定义行和列 可以分别为每一行和列指定宽高 宽高的值可选 Auto, * 和数值 Auto 表示 Grid 将按照元素的实际所需尺寸进行布局 * 表示行列在布局中的比例,* 前面的数值表示比例值...如果想了解 WPF/UWP 的布局单位,可以阅读我之前的一篇文字将 UWP 的有效像素(Effective Pixels)引入 WPF - 吕毅。 然而,事实上 Grid 的布局行为才没有那么简单呢!...)) 满足约束的忽略,不满足的约束需要计算约束大出行列的尺寸值,将此值设定为此 Auto 的待选长度 当所有的约束检查完毕,在所有的待选长度中取最大值,设定为 Auto 的尺寸,排除此行列,然后从总长中将其减掉...全部设置为 0 进行循环 计算单位星长(单位星长 = 剩余总长 / 星数) 找出第一个不满足 max 要求的 *,置其长度为 max,排除此行列,然后从总长中将其减掉

    2.1K20

    在WPF中使用矢量图标的几种方法

    使用SVG/Path WPF支持绘图,在WPF中定义了一些基本图形,如Line、Rectangle、Ellipse、Path等 其中Path支持使用路径来进行绘图,所以大部分的图标可以通过Path来进行绘制...SVG中采用的路径语法和WPF中是一致的,所以我们可以直接拿来用。 如何在WPF中使用SVG图标 这里我们以阿里巴巴矢量图标库为例。...,复制图标的Unicode 5、还是使用前面定义的ImageButton控件,使用Icon Font时,将文本设置为 &#fxxxx; 即可,xxxx为Unicode代码  运行效果: 使用开源的矢量图标库 这里以MahApps.Metro.IconPacks为例  项目地址...4、增加一个按钮,还是以前面的ImageButton为例,按钮的内容设置为图标内容,如下: <controls:ImageButton Grid.Row="1" Width="256" Height=

    82200

    WPF 引用 UWP 控件 不打包为 MSIX 分发的方法

    按照微软的官方文档,大部分的文档都会说如果用了 XAML Islands 等技术的时候,需要新建一个打包项目,将 WPF 应用打包为 msix 等才可以进行分发和使用。...可以通过判断系统版本决定功能是否开放,如是 Win10 版本,那么开放 UWP 控件部分的使用 如果新建一个空的 .NET Core 3.1 的 WPF 项目,然后只是安装了必要的 NuGet 包之后,...就在 XAML 界面里面添加了 UWP 的控件,如笔迹控件。...第二个方法是在原有的 WPF 项目中添加应用清单,在应用清单设置可以在 Win10 使用 右击项目添加应用清单 App.manifest 文件,在此文件添加 <supportedOS Id="{8e0f7a12...选择加入此设置的 Windows 窗体应用程序(目标设定为 .NET Framework 4.6 )还应 在其 app.config 中将 "EnableWindowsFormsHighDpiAutoResizing

    1.1K50

    C# WPF布局控件LayoutControl介绍

    Dev学习地址 文档地址 :https://docs.devexpress.com/ wpf:https://docs.devexpress.com/WPF/7875/wpf-controls winform...与前面的视觉样式一样,项目根据LayoutGroup排列在一列或一行中。方向属性。 -. LayoutGroupView.Tabs: 该组呈现为选项卡式组,其中直接子级表示为选项卡。...有关详细信息,请参阅布局项目和组。 Items排布 在LayoutControl中将LayoutGroups用作子级可以实现复合布局。...第四组垂直排列两个项目。 选项卡组包含两个选项卡(选项卡1和选项卡2)。每个选项卡都包含特定的项。例如,由布局组表示的选项卡1垂直排列项目5和项目6。 第五组水平排列三个项目。...最后声明 本文翻译自:https://docs.devexpress.com/WPF/8147/controls-and-libraries/layout-management/tile-and-layout

    4.9K10

    使用 .NET 构建 UI 界面的各种方式

    微软搞出了很多构建 UI 程序的框架,如 WinForms WPF WinUI MAUI,他们之间的简单对比可以看如下这篇官方文档 Overview of framework options - Windows...applications | Microsoft Learn UWP 随 Win8 推出,从名称(通用 Windows 平台)可以看出,目标是写一套代码开发的 APP,可以在多个 Windows 平台上运行,如...不确定是否真的会有正式项目会这么做) 6 Windows App SDK microsoft/WindowsAppSDK: The Windows App SDK empowers all Windows...8 Uno Platform Uno Platform 是实现跨平台 UI 的另一个方案,基于 WinUI3,把 WinUI3 带到其它平台,甚至是通过 WebAssembly,可以构建 Web UI。...壳 - CoolShell 其它 .NET 内的框架 除了 UI 相关的框架,.NET 中比较出名的还有服务端的 asp.net,对应 .NET Core 的版本就是 asp.net core,对应新项目而言

    2.3K00
    领券