1 | // Aseprite Document Library |
2 | // Copyright (C) 2019-2022 Igara Studio S.A. |
3 | // Copyright (C) 2001-2018 David Capello |
4 | // |
5 | // This file is released under the terms of the MIT license. |
6 | // Read LICENSE.txt for more information. |
7 | |
8 | #ifndef DOC_BRUSH_H_INCLUDED |
9 | #define DOC_BRUSH_H_INCLUDED |
10 | #pragma once |
11 | |
12 | #include "doc/brush_pattern.h" |
13 | #include "doc/brush_type.h" |
14 | #include "doc/color.h" |
15 | #include "doc/image_ref.h" |
16 | #include "gfx/point.h" |
17 | #include "gfx/rect.h" |
18 | |
19 | #include <memory> |
20 | #include <vector> |
21 | |
22 | namespace doc { |
23 | |
24 | class Brush { |
25 | public: |
26 | static const int kMinBrushSize = 1; |
27 | static const int kMaxBrushSize = 64; |
28 | |
29 | enum class ImageColor { MainColor, BackgroundColor }; |
30 | |
31 | Brush(); |
32 | Brush(BrushType type, int size, int angle); |
33 | Brush(const Brush& brush); |
34 | ~Brush(); |
35 | |
36 | BrushType type() const { return m_type; } |
37 | int size() const { return m_size; } |
38 | int angle() const { return m_angle; } |
39 | Image* image() const { return m_image.get(); } |
40 | Image* maskBitmap() const { return m_maskBitmap.get(); } |
41 | int gen() const { return m_gen; } |
42 | |
43 | BrushPattern pattern() const { return m_pattern; } |
44 | gfx::Point patternOrigin() const { return m_patternOrigin; } |
45 | Image* patternImage() const { return m_patternImage.get(); } |
46 | |
47 | const gfx::Rect& bounds() const { return m_bounds; } |
48 | const gfx::Point& center() const { return m_center; } |
49 | |
50 | void setType(BrushType type); |
51 | void setSize(int size); |
52 | void setAngle(int angle); |
53 | void setImage(const Image* image, |
54 | const Image* maskBitmap); |
55 | |
56 | // Special functions to change the colors of the image or restore |
57 | // the colors to the original image used to create the brush. |
58 | void setImageColor(ImageColor imageColor, color_t color); |
59 | void resetImageColors(); |
60 | |
61 | void setPattern(BrushPattern pattern) { |
62 | m_pattern = pattern; |
63 | } |
64 | void setPatternOrigin(const gfx::Point& patternOrigin) { |
65 | m_patternOrigin = patternOrigin; |
66 | } |
67 | void setPatternImage(ImageRef& patternImage) { |
68 | m_patternImage = patternImage; |
69 | } |
70 | void setCenter(const gfx::Point& center); |
71 | |
72 | // Returns the original image used to create the brush before |
73 | // calling any setImageColor() |
74 | Image* originalImage() const { |
75 | if (m_backupImage) |
76 | return m_backupImage.get(); |
77 | else |
78 | return m_image.get(); |
79 | } |
80 | |
81 | private: |
82 | void clean(); |
83 | void regenerate(); |
84 | void resetBounds(); |
85 | |
86 | BrushType m_type; // Type of brush |
87 | int m_size; // Size (diameter) |
88 | int m_angle; // Angle in degrees 0-360 |
89 | ImageRef m_image; // Image of the brush |
90 | ImageRef m_maskBitmap; |
91 | gfx::Rect m_bounds; |
92 | gfx::Point m_center; |
93 | BrushPattern m_pattern; // How the image should be replicated |
94 | gfx::Point m_patternOrigin; // From what position the brush was taken |
95 | ImageRef m_patternImage; |
96 | int m_gen; |
97 | |
98 | // Extra data used for setImageColor() |
99 | ImageRef m_backupImage; // Backup image to avoid losing original brush colors/pattern |
100 | std::unique_ptr<color_t> m_mainColor; // Main image brush color (nullptr if it wasn't specified) |
101 | std::unique_ptr<color_t> m_bgColor; // Background color (nullptr if it wasn't specified) |
102 | }; |
103 | |
104 | typedef std::shared_ptr<Brush> BrushRef; |
105 | |
106 | } // namespace doc |
107 | |
108 | #endif |
109 | |