首页
/ ExDUIR 开源项目教程

ExDUIR 开源项目教程

2024-09-13 15:48:27作者:邬祺芯Juliet

1. 项目介绍

ExDUIR 是一个专为 Windows 平台设计的轻量级 DirectUI 框架。它基于 DirectX 进行硬件加速的 2D 绘制,提供了比 GDI 绘制更高的效率。ExDUIR 支持 Unicode 多语言,并提供 Win32 风格的 API,支持生成 lib 和 dll,生成的 dll 可以被 Python、Go、Java 和 C# 等多种语言调用。

主要特点

  • 硬件加速:使用 DirectX 进行硬件加速的 2D 绘制,比 GDI 绘制效率更高。
  • 多语言支持:支持 Unicode 多语言。
  • 跨语言调用:提供 Win32 风格的 API,支持生成 lib 和 dll,生成的 dll 可以被多种语言调用。
  • 扩展组件:扩展组件自由灵活,引擎处理底层逻辑,用户只需编写绘制代码。

2. 项目快速启动

环境准备

  • Windows 10+ 或 Windows 7(需安装 KB2670838 补丁)
  • Visual Studio 2019 或更高版本

安装步骤

  1. 克隆项目

    git clone https://github.com/williamlzw/ExDUIR.git
    
  2. 打开项目: 使用 Visual Studio 打开项目目录中的 ExDUIR.sln 文件。

  3. 编译项目: 在 Visual Studio 中选择合适的配置(如 Debug 或 Release),然后点击“生成解决方案”。

示例代码

以下是一个简单的 ExDUIR 应用程序示例:

#include "ExDUIR.h"

class MyWindow : public WindowBase {
public:
    MyWindow() {
        // 设置窗口标题
        this->Title = "Hello, ExDUIR";
        // 设置窗口大小和位置
        this->Size = Size(800, 600);
        this->Position = Point(50, 50);

        // 添加一个按钮组件
        Button* button = new Button("Click me", 100, 100);
        button->Click += [](Button* sender, EventArgs* e) {
            MessageBox::Show("You clicked the button!");
        };

        // 将按钮添加到窗口中
        this->Add(button);
    }
};

int main() {
    Application::EnableVisualStyles();
    Application::SetCompatibleTextRenderingDefault(false);
    Application::Run(new MyWindow());
    return 0;
}

3. 应用案例和最佳实践

应用案例

  • 媒体播放器:ExDUIR 支持媒体组件播放 H265 格式的 mp4 文件,适合开发媒体播放器应用。
  • 桌面应用:ExDUIR 提供了丰富的 UI 组件,适合开发各种桌面应用程序,如文件管理器、图像编辑器等。

最佳实践

  • 性能优化:使用 DirectX 进行硬件加速绘制,确保应用程序在高负载下仍能保持流畅。
  • 组件扩展:利用 ExDUIR 的扩展组件功能,根据需求自定义组件,提升开发效率。

4. 典型生态项目

相关项目

  • ExDirectUI:ExDUIR 基于 ExDirectUI 4.1.18 开源版重写,提供了更丰富的功能和更好的性能。
  • CEF3:ExDUIR 支持最新的 CEF3 浏览器,可以嵌入 Web 浏览器功能。

社区资源

  • Gitee 仓库:https://gitee.com/mculover/ExDUIR
  • GitHub 仓库:https://github.com/williamlzw/ExDUIR

通过以上教程,您可以快速上手 ExDUIR 框架,并利用其强大的功能开发出高性能的 Windows 桌面应用程序。

热门项目推荐

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
609
115
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
286
79
mdmd
✍ WeChat Markdown Editor | 一款高度简洁的微信 Markdown 编辑器:支持 Markdown 语法、色盘取色、多图上传、一键下载文档、自定义 CSS 样式、一键重置等特性
Vue
111
25
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
60
48
RuoYi-Cloud-Vue3RuoYi-Cloud-Vue3
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
45
29
go-stockgo-stock
🦄🦄🦄AI赋能股票分析:自选股行情获取,成本盈亏展示,涨跌报警推送,市场整体/个股情绪分析,K线技术指标分析等。数据全部保留在本地。支持DeepSeek,OpenAI, Ollama,LMStudio,AnythingLLM,硅基流动,火山方舟,阿里云百炼等平台或模型。
Go
1
0
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
205
57
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
184
34
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
182
44
frogfrog
这是一个人工生命试验项目,最终目标是创建“有自我意识表现”的模拟生命体。
Java
8
0