Dearpygui入门指南

DearPyGui是一个简单易用但功能强大的Python GUI框架,它提供了传统保留模式GUI的包装,使用GPU渲染。文章介绍了DearPyGui的安装、基本运行、创建和使用控件的方法,展示了如何构建窗口、按钮、输入框等元素,并提供了代码示例。此外,还提到了DearPyGui与其他Python GUI库的独特之处,如内置异步函数支持、完全主题和样式控制等。
摘要由CSDN通过智能技术生成

Getting Started

What is Dear PyGui

Dear PyGui is a simple to use (but powerful) Python GUI framework. Dear PyGui provides a wrapping of Dear ImGui that simulates a traditional retained mode GUI, as opposed to Dear ImGui’s immediate mode paradigm.

Under the hood, Dear PyGui uses the immediate mode paradigm allowing for extremely dynamic interfaces. Similar to PyQt, Dear PyGui does not use native widgets but instead draws the widgets using your computer’s graphics card (using Directx11, Metal, and Vulkan rendering APIs).

In the same manner Dear ImGui provides a simple way to create tools for game developers, Dear PyGui provides a simple way for python developers to create quick and powerful GUIs for scripts.

Why use Dear PyGui

When compared with other Python GUI libraries Dear PyGui is unique with:

  • GPU Rendering
  • Simple built-in Asynchronous function support
  • Complete theme and style control
  • Simple built-in logging window
  • 70+ widgets with hundreds of widget combinations
  • Detailed documentation, examples and unparalleled support

Installing

Ensure you have at least Python 3.6 (64 bit) installed.

pip install dearpygui

First Run

A variety of examples demonstrating usage can be found in the Examples folder on github. Documentation can be found here and also from within the library by using the show_documentation() command.

Using Dear PyGui is a simple as creating a python script like the one below

The main script must always conclude with start_dearpygui().

Code:

import dearpygui.dearpygui as dpg

def save_callback():
    print("Save Clicked")

with dpg.window(label="Example Window"):
    dpg.add_text("Hello, world")
    dpg.add_button(label="Save", callback=save_callback)
    dpg.add_input_text(label="string", default_value="Quick brown fox")
    dpg.add_slider_float(label="float", default_value=0.273, max_value=1)
dpg.start_dearpygui()

Result:
在这里插入图片描述

Basic

Creating Widgets

DPG items can be broken down into :

  • regular items (i.e. inputs, buttons)
  • container items (i.e. window, popup, tooltip, child)
  • layout items (i.e. group, next_column)
  • Items are added with their respective add_*** commands or context
    managers.

New widget are created by calling the various add_xxxx commands or using context managers for container widgets. These commands all return a unique identifier than can be used to refer to the widget at a later time. Below is a simple example for creating a window with a few simple widgets:

import dearpygui.dearpygui as dpg

with dpg.window(label="Tutorial"):

    dpg.add_button(label="Apply")
    dpg.add_same_line(spacing=10)
    dpg.add_button(label="Apply")
    dpg.add_same_line(spacing=10)
    dpg.add_button(label="Apply")
    dpg.add_spacing(count=5)

    # printing the widgets unique id
    id=dpg.add_button(label="Press me")
    print(id)

dpg.start_dearpygui() 

Result:
在这里插入图片描述

Using Widgets

Every input widget has a value which can be set using the default_value keyword when being created or at runtime by the command set_value.
To access the value of a widget we can use the command get_value.

import dearpygui.dearpygui as dpg

with dpg.window(label="Tutorial"):

    cb = dpg.add_checkbox(label="Radio Button", default_value=False)
    print("First value of the Radio Button is: ", dpg.get_value(cb))

    dpg.set_value(cb, True)
    print("Value after setting the Radio Button is: ", dpg.get_value(cb))

dpg.start_dearpygui()

如何插入一段漂亮的代码片

博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片.

// An highlighted block
var foo = 'bar';

生成一个适合你的列表

  • 项目
    • 项目
      • 项目
  1. 项目1
  2. 项目2
  3. 项目3
  • 计划任务
  • 完成任务

创建一个表格

一个简单的表格是这么创建的:

项目Value
电脑$1600
手机$12
导管$1

设定内容居中、居左、居右

使用:---------:居中
使用:----------居左
使用----------:居右

第一列第二列第三列
第一列文本居中第二列文本居右第三列文本居左

SmartyPants

SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:

TYPEASCIIHTML
Single backticks'Isn't this fun?'‘Isn’t this fun?’
Quotes"Isn't this fun?"“Isn’t this fun?”
Dashes-- is en-dash, --- is em-dash– is en-dash, — is em-dash

创建一个自定义列表

Markdown
Text-to- HTML conversion tool
Authors
John
Luke

如何创建一个注脚

一个具有注脚的文本。1

注释也是必不可少的

Markdown将文本转换为 HTML

KaTeX数学公式

您可以使用渲染LaTeX数学表达式 KaTeX:

Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n1)!nN 是通过欧拉积分

Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t   . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=0tz1etdt.

你可以找到更多关于的信息 LaTeX 数学表达式here.

新的甘特图功能,丰富你的文章

Mon 06 Mon 13 Mon 20 已完成 进行中 计划一 计划二 现有任务 Adding GANTT diagram functionality to mermaid
  • 关于 甘特图 语法,参考 这儿,

UML 图表

可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图:

张三 李四 王五 你好!李四, 最近怎么样? 你最近怎么样,王五? 我很好,谢谢! 我很好,谢谢! 李四想了很长时间, 文字太长了 不适合放在一行. 打量着王五... 很好... 王五, 你怎么样? 张三 李四 王五

这将产生一个流程图。:

链接
长方形
圆角长方形
菱形
  • 关于 Mermaid 语法,参考 这儿,

FLowchart流程图

我们依旧会支持flowchart的流程图:

Created with Raphaël 2.3.0 开始 我的操作 确认? 结束 yes no
  • 关于 Flowchart流程图 语法,参考 这儿.

导出与导入

导出

如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。

导入

如果你想加载一篇你写过的.md文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。


  1. 注脚的解释 ↩︎

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值