2020-09-16 20:14:35 +00:00
|
|
|
// SPDX-License-Identifier: MIT
|
2020-06-28 16:39:18 +00:00
|
|
|
//
|
2020-09-16 20:14:35 +00:00
|
|
|
// EmulationStation Desktop Edition
|
2020-06-28 16:39:18 +00:00
|
|
|
// ImageComponent.h
|
|
|
|
//
|
|
|
|
// Handles images: loading, resizing, cropping, color shifting etc.
|
|
|
|
//
|
|
|
|
|
2017-10-31 17:12:50 +00:00
|
|
|
#ifndef ES_CORE_COMPONENTS_IMAGE_COMPONENT_H
|
|
|
|
#define ES_CORE_COMPONENTS_IMAGE_COMPONENT_H
|
2012-08-02 01:43:55 +00:00
|
|
|
|
2017-11-01 22:21:10 +00:00
|
|
|
#include "math/Vector2i.h"
|
2020-11-08 21:58:06 +00:00
|
|
|
#include "renderers/Renderer.h"
|
2017-11-01 22:21:10 +00:00
|
|
|
#include "GuiComponent.h"
|
2013-05-13 19:53:28 +00:00
|
|
|
|
2017-11-01 22:21:10 +00:00
|
|
|
class TextureResource;
|
2012-08-02 01:43:55 +00:00
|
|
|
|
2013-06-02 15:08:32 +00:00
|
|
|
class ImageComponent : public GuiComponent
|
2012-08-02 01:43:55 +00:00
|
|
|
{
|
|
|
|
public:
|
2020-06-28 16:39:18 +00:00
|
|
|
ImageComponent(Window* window, bool forceLoad = false, bool dynamic = true);
|
|
|
|
virtual ~ImageComponent();
|
|
|
|
|
|
|
|
void setDefaultImage(std::string path);
|
2012-08-02 01:43:55 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
// Loads the image at the given filepath. Will tile if tile is true (retrieves texture
|
|
|
|
// as tiling, creates vertices accordingly).
|
|
|
|
void setImage(std::string path, bool tile = false);
|
|
|
|
// Loads an image from memory.
|
2020-09-04 17:05:48 +00:00
|
|
|
void setImage(const char* data, size_t length, bool tile = false);
|
2020-06-28 16:39:18 +00:00
|
|
|
// Use an already existing texture.
|
|
|
|
void setImage(const std::shared_ptr<TextureResource>& texture);
|
2017-10-01 03:17:58 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
void onSizeChanged() override;
|
2014-01-24 22:21:10 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
// Resize the image to fit this size. If one axis is zero, scale that axis to maintain
|
|
|
|
// aspect ratio. If both are non-zero, potentially break the aspect ratio. If both are
|
|
|
|
// zero, don't do any resizing.
|
|
|
|
// Can be set before or after an image is loaded.
|
|
|
|
// setMaxSize() and setResize() are mutually exclusive.
|
2020-12-17 19:49:20 +00:00
|
|
|
void setResize(float width, float height) override;
|
2020-06-28 16:39:18 +00:00
|
|
|
inline void setResize(const Vector2f& size) { setResize(size.x(), size.y()); }
|
2014-04-12 01:48:13 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
// Resize the image to be as large as possible but fit within a box of this size.
|
|
|
|
// Can be set before or after an image is loaded.
|
|
|
|
// Never breaks the aspect ratio. setMaxSize() and setResize() are mutually exclusive.
|
|
|
|
void setMaxSize(float width, float height);
|
|
|
|
inline void setMaxSize(const Vector2f& size) { setMaxSize(size.x(), size.y()); }
|
2014-01-24 22:21:10 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
void setMinSize(float width, float height);
|
|
|
|
inline void setMinSize(const Vector2f& size) { setMinSize(size.x(), size.y()); }
|
2014-01-24 22:21:10 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
Vector2f getRotationSize() const override;
|
2018-04-12 09:00:47 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
// Applied AFTER image positioning and sizing.
|
|
|
|
// cropTop(0.2) will crop 20% of the top of the image.
|
|
|
|
void cropLeft(float percent);
|
|
|
|
void cropTop(float percent);
|
|
|
|
void cropRight(float percent);
|
|
|
|
void cropBot(float percent);
|
|
|
|
void crop(float left, float top, float right, float bot);
|
|
|
|
void uncrop();
|
2018-01-23 00:34:30 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
// Multiply all pixels in the image by this color when rendering.
|
|
|
|
void setColorShift(unsigned int color) override;
|
|
|
|
void setColorShiftEnd(unsigned int color);
|
|
|
|
void setColorGradientHorizontal(bool horizontal);
|
2018-04-12 09:00:47 +00:00
|
|
|
|
2020-11-08 12:23:50 +00:00
|
|
|
unsigned int getColorShift() const override { return mColorShift; };
|
|
|
|
|
2020-08-30 20:19:37 +00:00
|
|
|
void setOpacity(unsigned char opacity) override;
|
|
|
|
void setSaturation(float saturation) override;
|
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
void setFlipX(bool flip); // Mirror on the X axis.
|
|
|
|
void setFlipY(bool flip); // Mirror on the Y axis.
|
2012-08-02 01:43:55 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
// Flag indicating if rotation should be based on target size vs. actual size.
|
|
|
|
void setRotateByTargetSize(bool rotate);
|
2012-10-07 22:25:51 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
// Returns the size of the current texture, or (0, 0) if none is loaded.
|
|
|
|
// May be different than drawn size (use getSize() for that).
|
|
|
|
Vector2i getTextureSize() const;
|
2018-01-23 00:34:30 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
Vector2f getSize() const override;
|
2013-06-02 22:33:49 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
bool hasImage();
|
2018-04-12 09:00:47 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
void render(const Transform4x4f& parentTrans) override;
|
2012-10-10 13:51:48 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
virtual void applyTheme(const std::shared_ptr<ThemeData>& theme, const std::string& view,
|
|
|
|
const std::string& element, unsigned int properties) override;
|
2013-06-02 19:34:50 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
virtual std::vector<HelpPrompt> getHelpPrompts() override;
|
2014-01-01 05:39:22 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
std::shared_ptr<TextureResource> getTexture() { return mTexture; };
|
2019-07-06 14:50:50 +00:00
|
|
|
|
2012-08-02 01:43:55 +00:00
|
|
|
private:
|
2020-06-28 16:39:18 +00:00
|
|
|
Vector2f mTargetSize;
|
2013-06-02 21:05:29 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
bool mFlipX, mFlipY, mTargetIsMax, mTargetIsMin;
|
2012-08-09 21:19:07 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
// Calculates the correct mSize from our resizing information (set by setResize/setMaxSize).
|
|
|
|
// Used internally whenever the resizing parameters or texture change.
|
|
|
|
void resize();
|
2014-01-24 22:21:10 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
Renderer::Vertex mVertices[4];
|
2014-04-12 01:48:13 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
void updateVertices();
|
|
|
|
void updateColors();
|
|
|
|
void fadeIn(bool textureLoaded);
|
2012-08-10 02:17:48 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
unsigned int mColorShift;
|
|
|
|
unsigned int mColorShiftEnd;
|
|
|
|
bool mColorGradientHorizontal;
|
2013-08-07 22:40:27 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
std::string mDefaultPath;
|
2017-10-01 03:17:58 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
std::shared_ptr<TextureResource> mTexture;
|
|
|
|
unsigned char mFadeOpacity;
|
|
|
|
bool mFading;
|
|
|
|
bool mForceLoad;
|
|
|
|
bool mDynamic;
|
|
|
|
bool mRotateByTargetSize;
|
2018-04-12 09:00:47 +00:00
|
|
|
|
2020-06-28 16:39:18 +00:00
|
|
|
Vector2f mTopLeftCrop;
|
|
|
|
Vector2f mBottomRightCrop;
|
2012-08-02 01:43:55 +00:00
|
|
|
};
|
|
|
|
|
2017-10-31 17:12:50 +00:00
|
|
|
#endif // ES_CORE_COMPONENTS_IMAGE_COMPONENT_H
|