The `object_to_world` and `world_to_object` matrices are set during depsgraph evaluation, calculated from the object's animated location, rotation, scale, parenting, and constraints. It's confusing and unnecessary to store them with the original data in DNA. This commit moves them to `ObjectRuntime` and moves the matrices to use the C++ `float4x4` type, giving the potential for simplified code using the C++ abstractions. The matrices are accessible with functions on `Object` directly since they are used so commonly. Though for write access, directly using the runtime struct is necessary. The inverse `world_to_object` matrix is often calculated before it's used, even though it's calculated as part of depsgraph evaluation. Long term we might not want to store this in `ObjectRuntime` at all, and just calculate it on demand. Or at least we should remove the redundant calculations. That should be done separately though. Pull Request: https://projects.blender.org/blender/blender/pulls/118210
57 lines
1.5 KiB
C
57 lines
1.5 KiB
C
/* SPDX-FileCopyrightText: 2023 Blender Authors
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
#pragma once
|
|
|
|
/** \file
|
|
* \ingroup bli
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
struct Object;
|
|
struct ProjCameraInfo;
|
|
|
|
/**
|
|
* Create UV info from the camera, needs to be freed.
|
|
*
|
|
* \param rotmat: can be `obedit->object_to_world().ptr()` when uv project is used.
|
|
* \param winx, winy: can be from `scene->r.xsch / ysch`.
|
|
*/
|
|
struct ProjCameraInfo *BLI_uvproject_camera_info(struct Object *ob,
|
|
const float rotmat[4][4],
|
|
float winx,
|
|
float winy);
|
|
|
|
/**
|
|
* Apply UV from #ProjCameraInfo (camera).
|
|
*/
|
|
void BLI_uvproject_from_camera(float target[2], float source[3], struct ProjCameraInfo *uci);
|
|
|
|
/**
|
|
* Apply uv from perspective matrix.
|
|
* \param persmat: Can be `rv3d->persmat`.
|
|
*/
|
|
void BLI_uvproject_from_view(float target[2],
|
|
float source[3],
|
|
float persmat[4][4],
|
|
float rotmat[4][4],
|
|
float winx,
|
|
float winy);
|
|
|
|
/**
|
|
* Apply orthographic UVs.
|
|
*/
|
|
void BLI_uvproject_from_view_ortho(float target[2], float source[3], const float rotmat[4][4]);
|
|
|
|
/**
|
|
* So we can adjust scale with keeping the struct private.
|
|
*/
|
|
void BLI_uvproject_camera_info_scale(struct ProjCameraInfo *uci, float scale_x, float scale_y);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|