11#ifndef JAU_GAMP_GRAPH_UI_SHAPE_HPP_
12#define JAU_GAMP_GRAPH_UI_SHAPE_HPP_
35 using namespace jau::math;
36 using namespace jau::math::util;
37 using namespace jau::math::geom;
39 using namespace gamp::wt;
40 using namespace gamp::wt::event;
42 using namespace gamp::graph;
116 bool iMatIdent =
true;
117 bool iMatDirty =
false;
129 constexpr const float&
zOffset() const noexcept {
return m_zOffset; }
130 constexpr float&
zOffset() noexcept { iMatDirty=
true;
return m_zOffset; }
138 constexpr const Vec3f&
scale() const noexcept {
return m_scale; }
139 constexpr Vec3f&
scale() noexcept { iMatDirty=
true;
return m_scale; }
144 constexpr const Vec4f&
color() const noexcept {
return m_color; }
171 void updateMat() noexcept {
172 bool hasPos = !m_position.
is_zero();
175 bool hasRotPivot =
false;
177 bool sameScaleRotatePivot = hasScale && hasRotate && ( !hasRotPivot || m_rotPivot == ctr );
179 if( sameScaleRotatePivot ) {
187 }
else if( hasRotate || hasScale ) {
205 iMat.translate(
Vec3f(ctr).mul(m_scale));
207 iMat.translate(
Vec3f(-ctr).mul(m_scale));
209 }
else if( hasPos ) {
211 iMat.setToTranslation(m_position);
228 bool m_dragInit =
true;
233 if( m_parent.pmvMatrix().mapObjToWin(ctr, m_parent.viewport(), viewPos) ) {
234 const float winZ = viewPos.
z;
235 return m_parent.pmvMatrix().mapWinToObj((
float)winPos.
x, (
float)winPos.
y, winZ, m_parent.viewport(), viewPos);
241 constexpr float winZ0 = 0.0f;
242 constexpr float winZ1 = 0.3f;
253 if( !mapWinToObjRay(winPos, objRay, shape.
matPMvi()) ) {
261 if( !objBox.
getRayIntersection(objPos, objRay, std::numeric_limits<float>::epsilon(),
true) ) {
262 printf(
"obj getRayIntersection failed\n");
274 if( !mapWinToObj(shape, winPos, objPos) ) {
284 m_parent.pan() += diffPos;
288 const float thetaY = 360.0f * ((float)(winPos.
x - preWinPos.x) / (float)sdim.
x);
289 const float thetaX = 360.0f * ((float)(preWinPos.y - winPos.
y) / (float)sdim.
y);
314 m_picked->picked() =
false;
318 m_picked->picked() =
true;
328 if( !m_parent.dispatchForShape(*m_picked, navigateAction, e, win) ) {
330 m_picked->picked() =
false;
333 printf(
"XXX shape: lost\n");
342 m_parent.pan().z += incr;
345 m_parent.pan().x -= rot.
x;
346 m_parent.pan().y += rot.
y;
351 m_picked->picked() =
false;
352 printf(
"XXX shape: released\n");
jau::function< bool(const PointerEvent &e, const WindowRef &win, GearsObjectES2 &shape)> PointerShapeAction
std::string toString() const noexcept
const jau::math::geom::AABBox3f & objBounds() const noexcept
const jau::math::Mat4f & matPMvi() const noexcept
A Generic shape objects which is defined by a list of Outlines.
const AABBox3f & bounds() const noexcept
Container interface of UI Shapes.
MyPointerListener(GearsES2 &p)
void pointerReleased(PointerEvent &) override
void pointerPressed(PointerEvent &e) override
void pointerWheelMoved(PointerEvent &e) override
Traditional event name originally produced by a PointerType::mouse pointer type.
void pointerDragged(PointerEvent &e) override
constexpr void setColor(const Vec4f &c) noexcept
jau::function< void(ShapeRef &s, const Vec3f &pos, const PointerEvent &e)> PointerEventCallback
Shape pointer listener, e.g.
constexpr const Vec3f & position() const noexcept
jau::function< bool(ShapeRef &s, PMVMat4f &pmv)> Visitor2Func
Visitor2 method.
constexpr Quat4f & rotation() noexcept
constexpr const Quat4f & rotation() const noexcept
constexpr const Vec3f & scale() const noexcept
constexpr Vec3f & rotationPivot() noexcept
constexpr const float & zOffset() const noexcept
virtual Container * asContainer() const noexcept
constexpr const Vec4f & color() const noexcept
jau::function< void(ShapeRef &s, const Vec3f &origin, const Vec3f &dest, const PointerEvent &e)> MoveEventCallback
Shape move listener
jau::function< bool(ShapeRef &s)> Visitor1Func
Visitor1 method.
constexpr const OutlineShape & outlines() const noexcept
constexpr OutlineShape & outlines() noexcept
constexpr Vec3f & scale() noexcept
constexpr Vec3f & position() noexcept
constexpr float & zOffset() noexcept
constexpr const Vec3f & rotationPivot() const noexcept
jau::function< void(ShapeRef &s)> ShapeEventCallback
General Shape listener action.
void applyMatToMv(PMVMat4f &pmvMat) noexcept
Applies the internal Matrix4f to the given modelview matrix, i.e.
Pointer event of type PointerType.
constexpr const jau::math::Vec2i & position(size_t index=0) const noexcept
Returns position of given pointer-index in pixel units.
constexpr size_t pointerCount() const noexcept
See details for multiple-pointer events.
constexpr const jau::math::Vec3f & rotation() const noexcept
Returns a 3-component float array filled with the values of the rotational axis in the following orde...
Listener for PointerEvent.
constexpr const WindowWeakPtr & source() const noexcept
Class template jau::function is a general-purpose static-polymorphic function wrapper.
constexpr Matrix4 & translate(const value_type x, const value_type y, const value_type z) noexcept
Translate this matrix, i.e.
constexpr_cxx26 Matrix4 & rotate(const value_type ang_rad, const value_type x, const value_type y, const value_type z) noexcept
Rotate this matrix about give axis and angle in radians, i.e.
constexpr Matrix4 & scale(const value_type x, const value_type y, const value_type z) noexcept
Scale this matrix, i.e.
static bool mapWinToAnyRay(const value_type winx, const value_type winy, const value_type winz0, const value_type winz1, const Matrix4 &invAny, const Recti &viewport, Ray3 &ray) noexcept
constexpr Matrix4 & setToTranslation(const value_type x, const value_type y, const value_type z) noexcept
Set this matrix to translation.
constexpr bool isIdentity() const noexcept
Returns true if this quaternion has identity.
std::string toString() const noexcept
static constexpr const value_type one
constexpr bool is_zero() const noexcept
std::string toString() const noexcept
Axis Aligned Bounding Box.
constexpr bool intersectsRay(const Ray3f &r) const noexcept
Check if Ray intersects this bounding box.
bool getRayIntersection(Vec3f &result, const Ray3f &ray, const float epsilon, const bool assumeIntersection) const noexcept
Return intersection of a Ray with this bounding box, or false if none exist.
constexpr const Point3f & center() const noexcept
Returns computed center of this aabbox3f of low() and high().
constexpr T adeg_to_rad(const T arc_degree) noexcept
Converts arc-degree to radians.
jau::function< R(A...)> bind_member(C1 *base, R(C0::*mfunc)(A...)) noexcept
Bind given class instance and non-void member function to an anonymous function using func_member_tar...
std::shared_ptr< MyPointerListener > MyPointerListenerRef
std::shared_ptr< Shape > ShapeRef
std::shared_ptr< Window > WindowRef
constexpr jau::math::Vec3f getEulerAngleOrientation(const jau::math::Vec3f &eulerRotation) noexcept
Returns an orientation vector for given eurler X/Y/Z angles in radians.
Quaternion< float > Quat4f
PMVMatrix4< float > PMVMat4f
int printf(const char *format,...)
Operating Systems predefined macros.