File: Alignment.h

package info (click to toggle)
lsp-plugins 1.2.21-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 120,408 kB
  • sloc: cpp: 589,849; xml: 74,078; makefile: 13,396; php: 1,268; sh: 185
file content (141 lines) | stat: -rw-r--r-- 6,322 bytes parent folder | download
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
/*
 * 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: 1 июн. 2021 г.
 *
 * 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_ALIGNMENT_H_
#define LSP_PLUG_IN_TK_PROP_MULTI_ALIGNMENT_H_

#ifndef LSP_PLUG_IN_TK_IMPL
    #error "use <lsp-plug.in/tk/tk.h>"
#endif

namespace lsp
{
    namespace tk
    {
        /**
         * Alignment property.
         * Allows to align element within parent container
         * from the most left/top (-1) position to the
         * most right/bottom (1) position in one direction
         *
         * Additionally, it allows to control the scaling of
         * the space relative to the rest empty space if possible
         */
        class Alignment: public MultiProperty
        {
            protected:
                enum property_t
                {
                    P_VALUE,
                    P_ALIGN,
                    P_SCALE,

                    P_COUNT
                };

            protected:
                static const prop::desc_t   DESC[];

            protected:
                atom_t              vAtoms[P_COUNT];    // Atom bindings
                float               nAlign;             // Alignment
                float               nScale;             // Scaling

            protected:
                virtual void        push() override;
                virtual void        commit(atom_t property) override;

                void                parse(const LSPString *s);

            protected:
                explicit Alignment(prop::Listener *listener = NULL);
                Alignment(const Alignment &) = delete;
                Alignment(Alignment &&) = delete;
                virtual ~Alignment() override;

                Alignment & operator = (const Alignment &) = delete;
                Alignment & operator = (Alignment &&) = delete;

            public:
                inline float        align() const               { return nAlign;    }
                inline float        scale() const               { return nScale;    }

                float               set_align(float v);
                float               set_scale(float v);

                void                set(float halign, float valign);

                inline void         set_default()               { MultiProperty::set_default(vAtoms, DESC); }

            public:
                void                happly(ws::rectangle_t *dst, const ws::rectangle_t *src, const ws::size_limit_t *req);
                void                happly(ws::rectangle_t *dst, const ws::rectangle_t *src, ssize_t avail);
                void                vapply(ws::rectangle_t *dst, const ws::rectangle_t *src, const ws::size_limit_t *req);
                void                vapply(ws::rectangle_t *dst, const ws::rectangle_t *src, ssize_t avail);
                void                apply(ws::rectangle_t *dst, const ws::rectangle_t *src, const ws::size_limit_t *req, orientation_t orientation);
                void                apply(ws::rectangle_t *dst, const ws::rectangle_t *src, ssize_t avail, orientation_t orientation);

                inline void         happly(ws::rectangle_t *dst, const ws::size_limit_t *req) { return happly(dst, dst, req); }
                inline void         happly(ws::rectangle_t *dst, ssize_t avail) { return happly(dst, dst, avail); }
                inline void         vapply(ws::rectangle_t *dst, const ws::size_limit_t *req) { return vapply(dst, dst, req); }
                inline void         vapply(ws::rectangle_t *dst, ssize_t avail) { return vapply(dst, dst, avail); }
                void                apply(ws::rectangle_t *dst, const ws::size_limit_t *req, orientation_t orientation);
                void                apply(ws::rectangle_t *dst, ssize_t avail, orientation_t orientation);

        };

        namespace prop
        {
            /**
             * Alignment property implementation
             */
            class Alignment: public tk::Alignment
            {
                public:
                    explicit Alignment(prop::Listener *listener = NULL): tk::Alignment(listener) {};
                    Alignment(const Alignment &) = delete;
                    Alignment(Alignment &&) = delete;
                    Alignment & operator = (const Alignment &) = delete;
                    Alignment & operator = (Alignment &&) = delete;

                public:
                    /**
                     * Bind property with specified name to the style of linked widget
                     */
                    inline status_t     bind(atom_t property, Style *style)             { return tk::Alignment::bind(property, style, vAtoms, DESC, &sListener); }
                    inline status_t     bind(const char *property, Style *style)        { return tk::Alignment::bind(property, style, vAtoms, DESC, &sListener); }
                    inline status_t     bind(const LSPString *property, Style *style)   { return tk::Alignment::bind(property, style, vAtoms, DESC, &sListener); }

                    /**
                     * Unbind property
                     */
                    inline status_t     unbind()                                        { return tk::Alignment::unbind(vAtoms, DESC, &sListener); };

                    inline void         listener(prop::Listener *listener)              { pListener = listener;                     }
            };

        } /* namespace prop */
    } /* namespace tk */
} /* namespace lsp */



#endif /* INCLUDE_LSP_PLUG_IN_TK_PROP_MULTI_ALIGNMENT_H_ */