1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147
|
/*
* Copyright (C) 2025 Linux Studio Plugins Project <https://lsp-plug.in/>
* (C) 2025 Vladimir Sadovnikov <sadko4u@gmail.com>
*
* This file is part of lsp-tk-lib
* Created on: 25 авг. 2020 г.
*
* lsp-tk-lib is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* lsp-tk-lib is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with lsp-tk-lib. If not, see <https://www.gnu.org/licenses/>.
*/
#ifndef LSP_PLUG_IN_TK_PROP_MULTI_VECTOR2D_H_
#define LSP_PLUG_IN_TK_PROP_MULTI_VECTOR2D_H_
#ifndef LSP_PLUG_IN_TK_IMPL
#error "use <lsp-plug.in/tk/tk.h>"
#endif
#include <lsp-plug.in/stdlib/math.h>
namespace lsp
{
namespace tk
{
/**
* Two-dimensional Floating-point Vector property interface
*/
class Vector2D: public MultiProperty
{
protected:
enum property_t
{
P_VALUE,
P_DX,
P_DY,
P_RHO,
P_PHI,
P_RPHI,
P_DPHI,
P_COUNT
};
protected:
static const prop::desc_t DESC[];
protected:
atom_t vAtoms[P_COUNT]; // Atom bindings
float fDX; // X axis projection
float fDY; // Y axis projection
float fRho; // Length
float fPhi; // Angle
protected:
virtual void push() override;
virtual void commit(atom_t property) override;
static void calc_cart (float *dx, float *dy, float rho, float phi);
static void calc_polar (float *rho, float *phi, float dx, float dy);
static bool parse(float *dx, float *dy, float *rho, float *phi, const LSPString *s);
protected:
explicit Vector2D(prop::Listener *listener = NULL);
Vector2D(const Vector2D &) = delete;
Vector2D(Vector2D &&) = delete;
virtual ~Vector2D() override;
Vector2D & operator = (const Vector2D &) = delete;
Vector2D & operator = (Vector2D &&) = delete;
public:
inline float dx() const { return fDX; }
inline float dy() const { return fDY; }
inline float adx() const { return fabs(fDX); }
inline float ady() const { return fabs(fDY); }
inline float rho() const { return fRho; }
inline float phi() const { return fPhi; }
inline float rphi() const { return fPhi; }
inline float dphi() const { return fPhi * (180.0f / M_PI);}
inline float length() const { return rho(); }
inline float rangle() const { return rphi(); }
inline float dangle() const { return dphi(); }
float set_dx(float v);
float set_dy(float v);
float set_rho(float v);
float set_rphi(float v);
float set_dphi(float v);
inline float set_phi(float v) { return set_rphi(v); }
inline float set_length(float v) { return set_rho(v); }
inline float set_angle(float v) { return set_rphi(v); }
inline float set_rangle(float v) { return set_rphi(v); }
inline float set_dangle(float v) { return set_dphi(v); }
void set_cart(float dx, float dy);
void set_rpolar(float rho, float phi);
inline void set_dpolar(float rho, float phi){ set_rpolar(rho, phi * (M_PI / 180.0f)); }
inline void set_polar(float rho, float phi) { set_rpolar(rho, phi); }
void normalize();
};
namespace prop
{
/**
* Vector2D property implementation
*/
class Vector2D: public tk::Vector2D
{
public:
explicit Vector2D(prop::Listener *listener = NULL): tk::Vector2D(listener) {};
Vector2D(const Vector2D &) = delete;
Vector2D(Vector2D &&) = delete;
Vector2D & operator = (const Vector2D &) = delete;
Vector2D & operator = (Vector2D &&) = delete;
public:
/**
* Bind property with specified name to the style of linked widget
*/
inline status_t bind(atom_t property, Style *style) { return tk::Vector2D::bind(property, style, vAtoms, DESC, &sListener); }
inline status_t bind(const char *property, Style *style) { return tk::Vector2D::bind(property, style, vAtoms, DESC, &sListener); }
inline status_t bind(const LSPString *property, Style *style) { return tk::Vector2D::bind(property, style, vAtoms, DESC, &sListener); }
/**
* Unbind property
*/
inline status_t unbind() { return tk::Vector2D::unbind(vAtoms, DESC, &sListener); };
};
} /* namespace prop */
} /* namespace tk */
} /* namespace lsp */
#endif /* LSP_PLUG_IN_TK_PROP_MULTI_VECTOR2D_H_ */
|