RUST 编程语言 绘制随机颜色图片 画圆形 画矩形 画直线

什么是Rust

Rust是一种系统编程语言,旨在提供高性能和安全性。它是由Mozilla和其开发社区创建的开源语言,设计目标是在C++的应用场景中提供一种现代、可靠和高效的选择。Rust的目标是成为一种通用编程语言,能够处理各种计算任务,包括网络编程、并发编程、系统编程、WebAssembly等。

Rust的特点

1. 内存安全和高性能:Rust语言设计时优先考虑了内存安全和高性能。通过其独特的所有权系统和借用检查器,Rust可以确保在编译时捕获所有可能的内存错误,如悬挂指针和双重释放。这使得Rust能够在保持内存安全的同时,提供接近C++的性能。

2. 并发和多线程:Rust提供了一套强大的并发原语,使得编写并行和并发代码变得容易而安全。通过其所有权系统和生命周期系统,Rust可以防止数据竞争和其他并发问题,使得多线程编程更加可靠。

3. 编译型语言:Rust是一种编译型语言,这意味着它需要在编译时检查所有的类型错误和内存问题。这有助于在代码运行之前捕获潜在的错误,从而提高代码的可靠性。

4. 强大的社区支持:Rust拥有一个庞大而活跃的社区,为开发者提供了大量的资源和支持。无论是初学者还是经验丰富的开发者,都可以在社区中找到他们需要的资源和帮助。

5. 广泛的应用场景:Rust适用于各种应用场景,包括网络编程、并发编程、系统编程、WebAssembly等。此外,由于其优异的性能和安全性,Rust也被用于开发一些关键的基础设施项目。

Rust与其他语言的对比优势

1. 与C++相比:尽管C++是一种强大的系统编程语言,但它存在一些内存安全问题,如悬挂指针和双重释放。而Rust通过其所有权系统和借用检查器,可以避免这些内存错误,提供更高的安全性。此外,Rust的性能也非常接近C++,可以作为其可靠和高效的替代选择。

2. 与Go相比:Go是一种现代的并发编程语言,具有简洁的语法和强大的并发原语。然而,Go的并发模型是基于协程的,这使得编写复杂的并发代码变得困难。相比之下,Rust的并发模型更加灵活和强大,可以更好地处理并发问题。

3. 与Python/ target=_blank class=infotextkey>Python相比:Python是一种高级的动态类型语言,易于学习和使用。然而,Python的性能相对较低,且存在一些内存安全问题。对于需要高性能和安全性的应用场景,Rust可以作为一种更好的选择。

4. 与JAVA相比:Java是一种静态类型、面向对象的编程语言,具有强大的并发框架和卓越的性能。然而,Java在内存管理方面存在一些限制,如垃圾回收的停顿时间和对象分配的性能问题。相比之下,Rust提供了更好的内存安全性和性能,可以作为一种更好的选择。

总之,Rust是一种强大、安全和高性能的系统编程语言。通过其独特的所有权系统和并发模型,Rust为开发者提供了一种可靠和高效的解决方案,适用于各种应用场景。与C++、Go、Python和Java等其他语言相比,Rust在内存安全、性能和并发处理方面具有显著的优势。

首先,程序创建了一个事件循环event_loop和一个窗口window。

接着,程序创建了一个图形上下文context和一个绘制表面surface。

在事件循环中,程序通过匹配event来处理不同的事件。

当窗口需要重绘时,程序首先获取窗口的尺寸,并调整绘制表面的尺寸。

然后,程序使用一个循环来填充随机颜色到绘制表面的缓冲区中。

接下来,程序绘制一条直线,将其颜色设置为白色。

程序还绘制了一个圆形和一个矩形,并根据距离圆心或矩形边界的距离设置颜色。

最后,程序将缓冲区呈现到绘制表面。

这段代码是一个简单的图形绘制程序,它展示了如何使用Rust和相关库来创建图形界面应用程序。

需要新在工程目录 Cargo.toml 添加如下代码,配置工程和添加库

[package]
name = "test_draw"
version = "0.1.0"
edition = "2021"

[dependencies]
softbuffer = "0.4.0"
winit = "0.29.7"

主要程序main.rs

use std::num::NonZeroU32;
use std::rc::Rc;
use winit::event::{Event, WindowEvent};
use winit::event_loop::{ControlFlow, EventLoop};
use winit::window::WindowBuilder;
// 主函数,程序的入口点
fn main() {
    // 初始化事件循环
    let event_loop = EventLoop::new().unwrap();
    // 创建窗口
    let window = Rc::new(WindowBuilder::new().build(&event_loop).unwrap());
    // 创建图形上下文
    let context = softbuffer::Context::new(window.clone()).unwrap();
    // 创建绘图表面
    let mut surface = softbuffer::Surface::new(&context, window.clone()).unwrap();

    // 运行事件循环
    event_loop.run(move |event, elwt| {
        // 设置事件循环的控制流为等待状态
        elwt.set_control_flow(ControlFlow::Wait);

        // 处理发生的事件
        match event {
            // 当窗口需要重绘时
            Event::WindowEvent { window_id, event: WindowEvent::RedrawRequested } if window_id == window.id() => {
                // 获取窗口的尺寸
                let (width, height) = {
                    let size = window.inner_size();
                    (size.width, size.height)
                };
                // 调整绘图表面的尺寸
                surface
                    .resize(
                        NonZeroU32::new(width).unwrap(),
                        NonZeroU32::new(height).unwrap(),
                    )
                    .unwrap();
                
                // 随机填充颜色
                // 填充随机颜色

                let mut buffer = surface.buffer_mut().unwrap();
                for index in 0..(width * height/2) {
                    let y = index / width;
                    let x = index % width;
                    let red = x % 255;
                    let green = y % 255;
                    let blue = (x * y) % 255;

                    buffer[index as usize] = blue | (green << 8) | (red << 16);
                }

                // 绘制直线
                // 划线

                for index in (width * height/2)..(width * height/2+width*5) {
                   
                    let red = 169;
                    let green = 123;
                    let blue = 62;
                    if index <= (width * height/2+width*5){
                        buffer[index as usize] = 0 | (255 << 8) | (0 << 16);
                    }
                    else{
                        buffer[index as usize] = blue | (green << 8) | (red << 16);
                    }
                    
                }

                // 绘制圆形
                // 画圆
                
                for index in (width * height/2+width*5)..(width * height) {
                    let y1 = (index / width) as i32;
                    let x1 = (index % width) as i32;                   
                    let x0 = ((width/4)*3) as i32;
                    let y0 = ((height/4)*3) as i32;
                    let red = 169;
                    let green = 123;
                    let blue = 62;

                    if ((y1-y0)*(y1-y0)+(x1-x0)*(x1-x0))<2048*9 {
                        buffer[index as usize] = 0 | (0 << 8) | (255 << 16);
                    }
                    else {
                        buffer[index as usize] = blue | (green << 8) | (red << 16);
                    }
                    
                }
                

                // 绘制矩形
                // 画矩形
                
                for index in (width * height/2+width*5)..(width * height) {
                    let y1 = (index / width) as i32;
                    let x1 = (index % width) as i32;                   
                    let x0 = (width/2 - 180) as i32;
                    let y0 = ((height/2)+80) as i32;

                    let num_x = x1 - x0;//(x1.checked_sub(x0)).and_then(|dx| dx.checked_add(0));
                    let num_y = (y1.checked_sub(y0)).and_then(|dy| dy.checked_add(0));

                    if (num_x.abs()<100 && num_y<100_i32.checked_add(0_i32)) {
                        buffer[index as usize] = 255 | (0 << 8) | (0 << 16);
                    }
                    else{
                        //buffer[index as usize] = blue | (green << 8) | (red << 16);
                    }
                    
                }
                
                // 显示缓冲区内容
                buffer.present().unwrap();
            }
            // 当窗口关闭请求时
            Event::WindowEvent {
                event: WindowEvent::CloseRequested,
                window_id,
            } if window_id == window.id() => {
                // 退出事件循环
                elwt.exit();
            }
            // 忽略其他事件
            _ => {}
        }
    }).unwrap();
}

 效果图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/780428.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

STM32-OC输出比较和PWM

本内容基于江协科技STM32视频内容&#xff0c;整理而得。 文章目录 1. OC输出比较和PWM1.1 OC输出比较1.2 PWM&#xff08;脉冲宽度调制&#xff09;1.3 输出比较通道&#xff08;高级&#xff09;1.4 输出比较通道&#xff08;通用&#xff09;1.5 输出比较模式1.6 PWM基本结…

数据库系统原理 | 查询作业2

整理自博主本科《数据库系统原理》专业课自己完成的实验课查询作业&#xff0c;以便各位学习数据库系统概论的小伙伴们参考、学习。 *文中若存在书写不合理的地方&#xff0c;欢迎各位斧正。 专业课本&#xff1a; ​ ​ ———— 本次实验使用到的图形化工具&#xff1a;Heidi…

ThreadPoolExecutor - 管理线程池的核心类

下面是使用给定的初始参数创建一个新的 ThreadPoolExecutor &#xff08;构造方法&#xff09;。 public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueue<Runnable> workQueue,ThreadFactory threadFactory,…

【SVN的使用-源代码管理工具-SVN介绍-服务器的搭建 Objective-C语言】

一、首先,我们来介绍一下源代码管理工具 1.源代码管理工具的起源 为什么会出现源代码管理工具,是为了解决源代码开发的过程中出现的很多问题: 1)无法后悔:把项目关了,无法Command + Z后悔, 2)版本备份:非空间、费时间、写的名称最后自己都忘了干什么的了, 3)版本…

中英双语介绍加拿大(Canada)

加拿大国家简介 中文版 加拿大简介 加拿大是位于北美洲北部的一个国家&#xff0c;以其广袤的土地、多样的文化和自然美景著称。以下是对加拿大的详细介绍&#xff0c;包括其地理位置、人口、经济、特色、高等教育、著名景点、国家历史和交通条件。 地理位置 加拿大是世界…

LeetCode 189.轮转数组 三段逆置 C写法

LeetCode 189.轮转数组 C写法 三段逆置 思路: 三段逆置方法:先逆置前n-k个 再逆置后k个 最后整体逆置 由示例1得&#xff0c;需要先逆置1,2,3,4 再逆置5,6,7&#xff0c;最后前n-k个与后k个逆置 代码 void reverse(int*num, int left, int right) //逆置函数 { while(left …

【工具】豆瓣自动回贴软件

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你&#xff0c;欢迎[点赞、收藏、关注]哦~ 相比于之前粗糙丑陋的黑命令框版本&#xff0c;这个版本新增了UI界面&#xff0c;从此可以不需要再挨个去翻配置文件了。 另外&#xff0c;升级了隐藏浏…

深入理解并发、线程与等待通知机制

目录 一、基础概念 进程和线程 进程 线程 Java 线程的无处不在 进程间的通信 进程间通信有几种方式&#xff1f; CPU 核心数和线程数的关系 上下文切换&#xff08;Context switch&#xff09; 并行和并发 二、认识 Java 里的线程 Java 程序天生就是多线程的 线程的…

使用Keil将STM32部分程序放在RAM中运行

手动分配RAM区域,新建.sct文件,定义RAM_CODE区域,并指定其正确的起始地址和大小。 ; ************************************************************* ; *** Scatter-Loading Description File generated by uVision *** ; ************************************************…

鸿蒙应用笔记

安装就跳过了&#xff0c;一直点点就可以了 配置跳过&#xff0c;就自动下了点东西。 鸿蒙那个下载要12g个内存&#xff0c;大的有点吓人。 里面跟idea没区别 模拟器或者真机运行 真机要鸿蒙4.0&#xff0c;就可以实机调试 直接在手机里面跑&#xff0c;这个牛逼&#xf…

Centos新手问题——yum无法下载软件

起因&#xff1a;最近在学习centos7&#xff0c;在VM上成功安装后&#xff0c;用Secure进行远程登陆。然后准备下载一个C编译器&#xff0c;看网络上的教程&#xff0c;都是用yum来下载&#xff0c;于是我也输入了命令&#xff1a; yum -y install gcc* 本以为会自动下载&…

算法的空间复杂度(C语言)

1.空间复杂度的定义 算法在临时占用储存空间大小的量度&#xff08;就是完成这个算法所额外开辟的空间&#xff09;&#xff0c;空间复杂度也使用大O渐进表示法来表示 注&#xff1a; 函数在运行时所需要的栈空间(储存参数&#xff0c;局部变量&#xff0c;一些寄存器信息等)…

《C语言》预处理

文章目录 一、预定义符号二、#define定义常量三、#define定义宏四、宏更函数的对比五、#和##1、#运算符2、##运算符 一、预定义符号 C语言设置了一些预定义符号&#xff0c;可以直接使用&#xff0c;在预处理期间进行处理的。 __FILE__//进行编译的源文件 __LINE__//文件当前的…

【Qt】Qt概述

目录 一. 什么是Qt 二. Qt的优势 三. Qt的应用场景 四. Qt行业发展方向 一. 什么是Qt Qt是一个跨平台的C图形用户界面应用程序框架&#xff0c;为应用程序开发者提供了建立艺术级图形界面所需的所有功能。 Qt是完全面向对象的&#xff0c;很容易扩展&#xff0c;同时Qt为开发…

自动控制:前馈控制

自动控制&#xff1a;前馈控制 前馈控制是一种在控制系统中通过预先计算和调整输入来应对已知扰动或变化的方法。相比于反馈控制&#xff0c;前馈控制能够更快速地响应系统的变化&#xff0c;因为它不依赖于系统输出的反馈信号。前馈控制的应用在工业过程中尤为广泛&#xff0…

Visual studio下使用 Wix 打包 C#/WPF 程序的中文安装包

Visual studio下使用 Wix 打包 C#/WPF 程序的中文安装包 1 下载并安装 Wix Toolset1.1 下载WIX Toolset1.2 安装1.3 配置系统环境变量path1.4 找不到 WiX 工具 candle.exe2 安装Visual studio 20202,并安装插件2.1 下载并安装 Visual Studio2.2 步骤二:安装 Wix v3 扩展插件3 …

人脸识别打卡系统一站式开发【基于Pyqt5的C/S架构】

人脸识别打卡系统 1、运用场景 课堂签到,上班打卡,进出门身份验证。 2、功能架构 人脸录入,打卡签到,声音提醒,打卡信息导出: 3、技术栈 python3.8,sqlite3,opencv,face_recognition,PyQt5,csv 第三方库: asgiref==3.8.1 click==8.1.7 colorama==0.4.6 co…

【TB作品】51单片机 Proteus仿真 00001仿真实物PID电机调速系统

实验报告&#xff1a;Proteus 仿真 PID 电机调速系统 一、实验背景 PID&#xff08;比例-积分-微分&#xff09;控制器广泛应用于工业控制系统中&#xff0c;用于调节各种物理变量。本实验的目的是通过 Proteus 仿真软件设计并实现一个 PID 电机调速系统&#xff0c;以控制直…

Flutter-实现悬浮分组列表

在本篇博客中&#xff0c;我们将介绍如何使用 Flutter 实现一个带有分组列表的应用程序。我们将通过 CustomScrollView 和 Sliver 组件来实现该功能。 需求 我们需要实现一个分组列表&#xff0c;分组包含固定的标题和若干个列表项。具体分组如下&#xff1a; 水果动物职业菜…

C++、QT

目录 一、项目介绍 二、项目展示 三、源码获取 一、项目介绍 人事端&#xff1a; 1、【产品中心】产品案列、新闻动态的发布&#xff1b; 2、【员工管理】新增、修改、删除、搜索功能&#xff1b;合同以图片的方式上传 3、【考勤总览】根据日期显示所有员工上班、下班时间…