AdonisUI - 用于 WPF 应用程序的轻量级 UI 工具包,提供经典但增强的 Windows 视觉效果...

介绍

用于 WPF 应用程序的轻量级 UI 工具包,提供经典和增强的 Windows 视觉效果

b2c5c04942c5e73c5c9b196422ac3eef.gif

  • 几乎所有 WPF 控件的默认样式和模板

  • 可根据需要使用的其他样式以方便使用

  • 两种配色方案(浅色和深色)也可用于自定义样式

  • 支持在运行时更改配色方案

  • 支持其他自定义配色方案

  • 内置控件的扩展,提供水印等功能

  • 常见用例的自定义控件很少

设计原则

  1. 保持接近 WPF 的原始外观

  2. 不需要任何配置,但为想要控制全局和个人行为的人提供选项

  3. 支持 WPF 对创建新控件的内置控件的扩展,以便成为现有应用程序的直接替代品

图层

在 UI 设计中,容器将属于一起的项目分组是很常见的。例如,在 WPF 中,这可以使用 GroupBoxes 轻松实现。如果容器分配了不同的背景颜色以更好地区分分组项目及其周围环境,则颜色对比可能会成为问题。灰色按钮最初在白色应用程序背景上可能看起来不错,但是当它们被移动到也具有灰色背景的 GroupBox 中时,它们可能会失去可见性。

这就是为什么 Adonis UI 引入了一个简单的分层系统,它可以根据 UI 控件所属的层自动调整 UI 控件的颜色。默认情况下,所有样式的 Adonis UI 都会自动适应系统,但也可以禁用它。

b328062415297ce5c10f971e9b1e06a9.png

这些图像显示了一个由 Buttons 和 GroupBoxes 组成的简单布局。所有控件都使用它们的默认样式,除了它们的内容之外没有设置任何属性。分层系统负责稍微调整每层按钮的颜色和 GroupBoxes 的背景。它确保容器的背景和容器中控件的背景始终存在差异。如果没有系统,所有按钮都将具有完全相同的背景颜色。

该系统是完全可定制的。当然,它适用于所有控件,而不仅仅是按钮。每个控件都可以配置为为其子级增加层,但默认情况下已经为某些控件(如 GroupBoxes)启用它。控件也可以强制驻留在特定层上。

数据验证支持

WPF 的数据验证机制提供了验证属性值并在它们无效时分配错误消息的能力。在 Adonis UI 中,如果控件绑定到无效属性,则错误会在控件模板中由红色边框和错误图标指示。当控件获得键盘焦点或用户将鼠标悬停在图标上时,错误消息将显示为弹出窗口。要设置验证错误,可以使用接口IDataErrorInfo或WPF。

f93e80a1f103ab70cbf74d87815040e6.png

WPFWindows Presentation Foundation)是一种用于创建Windows应用程序UI框架,而Stylet是一个轻量级的MVVM(Model-View-ViewModel)框架,提供了一种组织和管理应用程序代码的方式。SQLite是一种嵌入式数据库引擎,可以用于存储和管理数据。 在基于Stylet框架的WPF应用程序中使用SQLite进行增删改查操作,可以按照以下步骤进行: 1. 添加SQLite NuGet包:在Visual Studio中,右击项目名称,选择"管理NuGet程序包"。在NuGet包管理器中搜索并安装SQLite包。 2. 创建SQLite数据库连接:在代码中使用SQLiteConnection对象创建与数据库的连接。可以指定数据库文件的路径,如果数据库不存在,会自动创建。 3. 定义表结构和数据模型:使用SQLite提供的SQL语句在数据库中创建表,并定义与之对应的数据模型类。可以使用类属性来映射表的字段。 4. 实现增删改查功能:在ViewModel中,使用SQLiteConnection对象进行增删改查操作。可以编写SQL语句,也可以使用SQLite提供的ORM工具(如Dapper)进行操作。 示例代码如下: ```csharp using Stylet; using Dapper; using System.Collections.Generic; using System.Data.SQLite; using System.Linq; namespace MyNamespace { public class MyViewModel : Screen { private SQLiteConnection connection; // 构造函数中初始化SQLite连接 public MyViewModel() { string databasePath = "path_to_your_database_file"; connection = new SQLiteConnection($"Data Source={databasePath};Version=3;"); } // 查询操作 public IEnumerable<MyDataModel> GetMyData() { string sql = "SELECT * FROM MyTable"; return connection.Query<MyDataModel>(sql); } // 插入操作 public void InsertData(MyDataModel data) { string sql = "INSERT INTO MyTable (Name, Age) VALUES (@Name, @Age)"; connection.Execute(sql, data); } // 更新操作 public void UpdateData(MyDataModel data) { string sql = "UPDATE MyTable SET Name = @Name, Age = @Age WHERE Id = @Id"; connection.Execute(sql, data); } // 删除操作 public void DeleteData(int id) { string sql = "DELETE FROM MyTable WHERE Id = @Id"; connection.Execute(sql, new { Id = id }); } } public class MyDataModel { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } } } ``` 以上是基于Stylet框架的WPF应用程序使用SQLite进行增删改查操作的简单示例。根据实际需求,可以根据这个示例进行扩展和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值