* feat(platform-common): 添加WASM加载器和环境检测API * feat(rapier2d): 新增Rapier2D WASM绑定包 * feat(physics-rapier2d): 添加跨平台WASM加载器 * feat(asset-system): 添加运行时资产目录和bundle格式 * feat(asset-system-editor): 新增编辑器资产管理包 * feat(editor-core): 添加构建系统和模块管理 * feat(editor-app): 重构浏览器预览使用import maps * feat(platform-web): 添加BrowserRuntime和资产读取 * feat(engine): 添加材质系统和着色器管理 * feat(material): 新增材质系统和着色器编辑器 * feat(tilemap): 增强tilemap编辑器和动画系统 * feat(modules): 添加module.json配置 * feat(core): 添加module.json和类型定义更新 * chore: 更新依赖和构建配置 * refactor(plugins): 更新插件模板使用ModuleManifest * chore: 添加第三方依赖库 * chore: 移除BehaviourTree-ai和ecs-astar子模块 * docs: 更新README和文档主题样式 * fix: 修复Rust文档测试和添加rapier2d WASM绑定 * fix(tilemap-editor): 修复画布高DPI屏幕分辨率适配问题 * feat(ui): 添加UI屏幕适配系统(CanvasScaler/SafeArea) * fix(ecs-engine-bindgen): 添加缺失的ecs-framework-math依赖 * fix: 添加缺失的包依赖修复CI构建 * fix: 修复CodeQL检测到的代码问题 * fix: 修复构建错误和缺失依赖 * fix: 修复类型检查错误 * fix(material-system): 修复tsconfig配置支持TypeScript项目引用 * fix(editor-core): 修复Rollup构建配置添加tauri external * fix: 修复CodeQL检测到的代码问题 * fix: 修复CodeQL检测到的代码问题
166 lines
5.0 KiB
Rust
166 lines
5.0 KiB
Rust
//! 2D transform implementation.
|
||
//! 2D变换实现。
|
||
|
||
use super::Vec2;
|
||
use glam::Mat3;
|
||
|
||
/// 2D transformation combining position, rotation, and scale.
|
||
/// 组合位置、旋转和缩放的2D变换。
|
||
///
|
||
/// # Examples | 示例
|
||
/// ```rust
|
||
/// use es_engine::math::{Transform2D, Vec2};
|
||
/// let mut transform = Transform2D::new();
|
||
/// transform.position = Vec2::new(100.0, 200.0);
|
||
/// transform.rotation = std::f32::consts::PI / 4.0; // 45 degrees
|
||
/// transform.scale = Vec2::new(2.0, 2.0);
|
||
///
|
||
/// let matrix = transform.to_matrix();
|
||
/// ```
|
||
#[derive(Debug, Clone, Copy, PartialEq)]
|
||
pub struct Transform2D {
|
||
/// Position in world space.
|
||
/// 世界空间中的位置。
|
||
pub position: Vec2,
|
||
|
||
/// Rotation in radians.
|
||
/// 旋转角度(弧度)。
|
||
pub rotation: f32,
|
||
|
||
/// Scale factor.
|
||
/// 缩放因子。
|
||
pub scale: Vec2,
|
||
|
||
/// Origin point for rotation and scaling (0-1 range, relative to size).
|
||
/// 旋转和缩放的原点(0-1范围,相对于尺寸)。
|
||
pub origin: Vec2,
|
||
}
|
||
|
||
impl Default for Transform2D {
|
||
fn default() -> Self {
|
||
Self {
|
||
position: Vec2::ZERO,
|
||
rotation: 0.0,
|
||
scale: Vec2::new(1.0, 1.0),
|
||
origin: Vec2::new(0.5, 0.5), // Center by default | 默认居中
|
||
}
|
||
}
|
||
}
|
||
|
||
impl Transform2D {
|
||
/// Create a new transform with default values.
|
||
/// 使用默认值创建新变换。
|
||
#[inline]
|
||
pub fn new() -> Self {
|
||
Self::default()
|
||
}
|
||
|
||
/// Create a transform with specified position.
|
||
/// 使用指定位置创建变换。
|
||
#[inline]
|
||
pub fn from_position(x: f32, y: f32) -> Self {
|
||
Self {
|
||
position: Vec2::new(x, y),
|
||
..Default::default()
|
||
}
|
||
}
|
||
|
||
/// Create a transform with position, rotation, and scale.
|
||
/// 使用位置、旋转和缩放创建变换。
|
||
#[inline]
|
||
pub fn from_pos_rot_scale(position: Vec2, rotation: f32, scale: Vec2) -> Self {
|
||
Self {
|
||
position,
|
||
rotation,
|
||
scale,
|
||
..Default::default()
|
||
}
|
||
}
|
||
|
||
/// Convert to a 3x3 transformation matrix.
|
||
/// 转换为3x3变换矩阵。
|
||
///
|
||
/// The matrix is constructed as: T * R * S (translate, rotate, scale).
|
||
/// 矩阵构造顺序为:T * R * S(平移、旋转、缩放)。
|
||
pub fn to_matrix(&self) -> Mat3 {
|
||
let cos = self.rotation.cos();
|
||
let sin = self.rotation.sin();
|
||
|
||
// Construct TRS matrix directly for performance
|
||
// 直接构造TRS矩阵以提高性能
|
||
Mat3::from_cols(
|
||
glam::Vec3::new(cos * self.scale.x, sin * self.scale.x, 0.0),
|
||
glam::Vec3::new(-sin * self.scale.y, cos * self.scale.y, 0.0),
|
||
glam::Vec3::new(self.position.x, self.position.y, 1.0),
|
||
)
|
||
}
|
||
|
||
/// Convert to a 3x3 matrix with origin offset applied.
|
||
/// 转换为应用原点偏移的3x3矩阵。
|
||
///
|
||
/// # Arguments | 参数
|
||
/// * `width` - Sprite width | 精灵宽度
|
||
/// * `height` - Sprite height | 精灵高度
|
||
pub fn to_matrix_with_origin(&self, width: f32, height: f32) -> Mat3 {
|
||
let ox = -self.origin.x * width * self.scale.x;
|
||
let oy = -self.origin.y * height * self.scale.y;
|
||
|
||
let cos = self.rotation.cos();
|
||
let sin = self.rotation.sin();
|
||
|
||
// Apply origin offset after rotation
|
||
// 在旋转后应用原点偏移
|
||
let tx = self.position.x + ox * cos - oy * sin;
|
||
let ty = self.position.y + ox * sin + oy * cos;
|
||
|
||
Mat3::from_cols(
|
||
glam::Vec3::new(cos * self.scale.x, sin * self.scale.x, 0.0),
|
||
glam::Vec3::new(-sin * self.scale.y, cos * self.scale.y, 0.0),
|
||
glam::Vec3::new(tx, ty, 1.0),
|
||
)
|
||
}
|
||
|
||
/// Transform a local point to world space.
|
||
/// 将局部点变换到世界空间。
|
||
#[inline]
|
||
pub fn transform_point(&self, point: Vec2) -> Vec2 {
|
||
let rotated = point.rotate(self.rotation);
|
||
Vec2::new(
|
||
rotated.x * self.scale.x + self.position.x,
|
||
rotated.y * self.scale.y + self.position.y,
|
||
)
|
||
}
|
||
|
||
/// Inverse transform a world point to local space.
|
||
/// 将世界点反变换到局部空间。
|
||
#[inline]
|
||
pub fn inverse_transform_point(&self, point: Vec2) -> Vec2 {
|
||
let local = Vec2::new(
|
||
(point.x - self.position.x) / self.scale.x,
|
||
(point.y - self.position.y) / self.scale.y,
|
||
);
|
||
local.rotate(-self.rotation)
|
||
}
|
||
|
||
/// Translate the transform by a delta.
|
||
/// 按增量平移变换。
|
||
#[inline]
|
||
pub fn translate(&mut self, delta: Vec2) {
|
||
self.position = self.position + delta;
|
||
}
|
||
|
||
/// Rotate the transform by an angle (in radians).
|
||
/// 按角度旋转变换(弧度)。
|
||
#[inline]
|
||
pub fn rotate(&mut self, angle: f32) {
|
||
self.rotation += angle;
|
||
}
|
||
|
||
/// Scale the transform by a factor.
|
||
/// 按因子缩放变换。
|
||
#[inline]
|
||
pub fn scale_by(&mut self, factor: Vec2) {
|
||
self.scale = Vec2::new(self.scale.x * factor.x, self.scale.y * factor.y);
|
||
}
|
||
}
|