【Iced】core库下angle.rs文件分析

rust 复制代码
use crate::{Point, Rectangle, Vector};

use std::f32::consts::{FRAC_PI_2, PI};
use std::fmt::Display;
use std::ops::{Add, AddAssign, Div, Mul, RangeInclusive, Rem, Sub, SubAssign};

这段代码定义了两个用于表示角度的新类型包装结构体Degrees(度)和 Radians(弧度)。下面详细解释每个部分:

📦 导入部分

  • PointRectangleVector - 可能来自其他模块的几何图元
  • FRAC_PI_2(π/2)和 PI - 来自 std::f32::consts 的数学常数
  • 各种运算符 trait(AddMul 等)- 用于重载运算符
  • RangeInclusive - 用于定义范围
  • Display - 用于字符串格式化

📐 Degrees 结构体

一个元组结构体 ,包装了一个 f32 来表示以度为单位的角度

✨ 主要特性:

  • 常量RANGE 定义了有效的度数值范围(0 到 360)
  • 转换 :可以从/转换为 f32u8f64num_traits::FromPrimitive
  • 比较 :实现了与 Degrees 和原始 f32 的部分相等和排序比较
  • 运算 :实现了与 f32 的乘法(角度缩放)

📐 Radians 结构体

一个元组结构体 ,包装了一个 f32 来表示以弧度为单位的角度

✨ 主要特性:

  • 常量
    • RANGE:0 到 2π(整个圆)
    • PI:π 弧度(180 度)

🔍 几何方法:

rust 复制代码
fn to_distance(&self, bounds: &Rectangle) -> (Point, Point)
  • 计算从矩形中心出发、按此角度延伸到矩形边界的直线
  • 用于绘制从中心到边缘、特定角度的射线/直线
  • 使用带有正弦/余弦的向量数学来找到交点

🔄 转换:

  • DegreesRadians(乘以 π/180)
  • 从/到 f32u8f64num_traits::FromPrimitive 的转换

➕ 运算符重载(针对 Radians):

  • AddAddAssignSubSubAssign - 基本算术运算
  • Mul - 可以乘以两个弧度,或者弧度乘以 f32
  • Div - 除法运算
  • Rem - 余数/取模运算
  • Degrees 的混合运算(可以将度加到弧度上)

⚖️ 类型比较:

  • 实现了与 Radians 和原始 f32 的部分相等和排序比较

📝 显示:

  • 格式化为 "X rad" 的字符串输出

🎯 设计模式

这使用了新类型模式,目的是:

  1. 类型安全 - 防止意外混淆度和弧度
  2. 领域特定方法 - 添加角度相关的实用方法
  3. 控制运算 - 只允许有意义的数学运算
  4. 定制行为 - 实现与基础类型不同的行为

这段代码很可能是图形或几何库的一部分,在这些库中,精确的角度处理对于旋转、射线投射或形状操作等计算非常重要。

相关推荐
鸿乃江边鸟3 小时前
Rust 的 mod(模块) 说明
开发语言·后端·rust
小杍随笔4 小时前
【Rust `lib.rs` 使用方法:模块组织、API导出与最佳实践】
服务器·开发语言·rust
用户881586910914 小时前
为什么说 Rust 是 C++...
rust
Mem0rin5 小时前
[Rust]模块关键词和哈希表
开发语言·rust
古城小栈5 小时前
Rust 开发 WebAssembly 一眼案例
开发语言·rust·wasm
小杍随笔6 小时前
【Rust中所有符号的作用及使用场景详解】
java·算法·rust
古城小栈15 小时前
Rust 1.94.0 闪亮登台
开发语言·后端·rust
Source.Liu15 小时前
【Iced】Iced:一种构建图形用户界面的新思维
rust·iced