2019-08-15 11:22:51 +08:00
|
|
|
|
// Copyright (c) 2016-2018 Kiwano - Nomango
|
2020-01-21 10:09:55 +08:00
|
|
|
|
//
|
2019-08-15 11:22:51 +08:00
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
|
|
// of this software and associated documentation files (the "Software"), to deal
|
|
|
|
|
|
// in the Software without restriction, including without limitation the rights
|
|
|
|
|
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
|
|
// copies of the Software, and to permit persons to whom the Software is
|
|
|
|
|
|
// furnished to do so, subject to the following conditions:
|
2020-01-21 10:09:55 +08:00
|
|
|
|
//
|
2019-08-15 11:22:51 +08:00
|
|
|
|
// The above copyright notice and this permission notice shall be included in
|
|
|
|
|
|
// all copies or substantial portions of the Software.
|
2020-01-21 10:09:55 +08:00
|
|
|
|
//
|
2019-08-15 11:22:51 +08:00
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
|
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
|
|
// THE SOFTWARE.
|
|
|
|
|
|
|
|
|
|
|
|
#pragma once
|
2020-02-06 16:54:47 +08:00
|
|
|
|
#include <kiwano/math/Math.h>
|
2020-02-16 20:14:01 +08:00
|
|
|
|
#include <kiwano/render/NativeObject.h>
|
2020-08-03 21:55:27 +08:00
|
|
|
|
#include <kiwano/render/TextStyle.h>
|
2019-08-15 11:22:51 +08:00
|
|
|
|
|
|
|
|
|
|
namespace kiwano
|
|
|
|
|
|
{
|
|
|
|
|
|
|
2020-02-16 12:53:18 +08:00
|
|
|
|
KGE_DECLARE_SMART_PTR(TextLayout);
|
|
|
|
|
|
|
2020-01-21 10:09:55 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* \addtogroup Render
|
|
|
|
|
|
* @{
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20>ı<EFBFBD><C4B1><EFBFBD><EFBFBD><EFBFBD>
|
2020-02-16 20:14:01 +08:00
|
|
|
|
class KGE_API TextLayout : public NativeObject
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
|
|
|
|
|
public:
|
2020-07-22 21:08:48 +08:00
|
|
|
|
TextLayout();
|
2020-02-16 12:53:18 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>ı<EFBFBD><C4B1><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
/// @param content <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
/// @param style <20>ı<EFBFBD><C4B1><EFBFBD>ʽ
|
2020-07-22 21:08:48 +08:00
|
|
|
|
TextLayout(const String& content, const TextStyle& style);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20>ı<EFBFBD><C4B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƿ<EFBFBD><C7B7>¾<EFBFBD>
|
2020-01-21 10:09:55 +08:00
|
|
|
|
bool IsDirty() const;
|
|
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>ı<EFBFBD><C4B1><EFBFBD><EFBFBD><EFBFBD>
|
2020-02-16 12:53:18 +08:00
|
|
|
|
void Clear();
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>ı<EFBFBD><C4B1><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
/// @param content <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
/// @param style <20>ı<EFBFBD><C4B1><EFBFBD>ʽ
|
2020-02-16 12:53:18 +08:00
|
|
|
|
void Reset(const String& content, const TextStyle& style);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><>ȡ<EFBFBD>ı<EFBFBD><C4B1><EFBFBD><EFBFBD>ִ<EFBFBD>С
|
2020-02-17 12:06:29 +08:00
|
|
|
|
Size GetSize() const;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><>ȡ<EFBFBD>ı<EFBFBD><C4B1><EFBFBD><EFBFBD><EFBFBD>
|
2020-02-17 12:06:29 +08:00
|
|
|
|
uint32_t GetLineCount() const;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><>ȡĬ<C8A1><C4AC><EFBFBD><EFBFBD><EFBFBD>仭ˢ
|
2020-08-04 16:31:20 +08:00
|
|
|
|
BrushPtr GetFillBrush() const;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><>ȡĬ<C8A1><C4AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ˢ
|
2020-08-04 16:31:20 +08:00
|
|
|
|
BrushPtr GetOutlineBrush() const;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><>ȡĬ<C8A1><C4AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
|
2020-08-04 16:31:20 +08:00
|
|
|
|
StrokeStylePtr GetOutlineStrokeStyle() const;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
/// @param font <20><><EFBFBD><EFBFBD>
|
2020-08-04 16:31:20 +08:00
|
|
|
|
void SetFont(FontPtr font);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>»<EFBFBD><C2BB><EFBFBD>
|
|
|
|
|
|
/// @param enable <20>Ƿ<EFBFBD><C7B7><EFBFBD>ʾ<EFBFBD>»<EFBFBD><C2BB><EFBFBD>
|
2020-08-04 16:31:20 +08:00
|
|
|
|
void SetUnderline(bool enable);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD>ɾ<EFBFBD><C9BE><EFBFBD><EFBFBD>
|
|
|
|
|
|
/// @param enable <20>Ƿ<EFBFBD><C7B7><EFBFBD>ʾɾ<CABE><C9BE><EFBFBD><EFBFBD>
|
2020-08-04 16:31:20 +08:00
|
|
|
|
void SetStrikethrough(bool enable);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>仭ˢ<E4BBAD><CBA2><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ˢ<EFBFBD><CBA2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>߿<EFBFBD>
|
|
|
|
|
|
/// @param brush <20><>ˢ
|
2020-08-04 16:31:20 +08:00
|
|
|
|
void SetFillBrush(BrushPtr brush);
|
2020-02-16 12:53:18 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ˢ
|
|
|
|
|
|
/// @param brush <20><>ˢ
|
2020-08-04 16:31:20 +08:00
|
|
|
|
void SetOutlineBrush(BrushPtr brush);
|
2020-02-16 12:53:18 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
|
|
|
|
|
|
/// @param stroke <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
|
2020-08-04 16:31:20 +08:00
|
|
|
|
void SetOutlineStrokeStyle(StrokeStylePtr stroke);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD>ö<EFBFBD><C3B6>뷽ʽ
|
|
|
|
|
|
/// @param align <20><><EFBFBD>뷽ʽ
|
2020-01-21 10:09:55 +08:00
|
|
|
|
void SetAlignment(TextAlign align);
|
|
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>ı<EFBFBD><C4B1>Զ<EFBFBD><D4B6><EFBFBD><EFBFBD>еĿ<D0B5><C4BF><EFBFBD>
|
2020-02-16 12:53:18 +08:00
|
|
|
|
void SetWrapWidth(float wrap_width);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>м<EFBFBD><D0BC>ࣨĬ<E0A3A8><C4AC>Ϊ 0<><30>
|
2020-02-16 12:53:18 +08:00
|
|
|
|
void SetLineSpacing(float line_spacing);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
|
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20>಼<EFBFBD>ֱ<EFBFBD>־
|
2020-02-16 12:53:18 +08:00
|
|
|
|
enum class DirtyFlag : uint8_t
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
2020-03-19 14:28:50 +08:00
|
|
|
|
Clean = 0, ///< <20>ɾ<EFBFBD><C9BE><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
Dirty = 1 << 0 ///< <20>಼<EFBFBD><E0B2BC>
|
2020-01-21 10:09:55 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
2020-02-17 12:06:29 +08:00
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><>ȡ<EFBFBD>಼<EFBFBD>ֱ<EFBFBD>־
|
2020-02-16 12:53:18 +08:00
|
|
|
|
DirtyFlag GetDirtyFlag() const;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
2020-02-17 12:06:29 +08:00
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>಼<EFBFBD>ֱ<EFBFBD>־
|
2020-02-16 12:53:18 +08:00
|
|
|
|
void SetDirtyFlag(DirtyFlag flag);
|
2020-01-21 10:09:55 +08:00
|
|
|
|
|
2020-02-17 12:06:29 +08:00
|
|
|
|
/// \~chinese
|
2020-03-19 14:28:50 +08:00
|
|
|
|
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>಼<EFBFBD><E0B2BC>
|
|
|
|
|
|
/// @return <20>Ƿ<EFBFBD><C7B7><EFBFBD>Ҫ<EFBFBD><D2AA><EFBFBD><EFBFBD>
|
2020-08-04 16:31:20 +08:00
|
|
|
|
bool UpdateIfDirty();
|
2020-02-17 12:06:29 +08:00
|
|
|
|
|
2020-01-21 10:09:55 +08:00
|
|
|
|
private:
|
2020-02-16 12:53:18 +08:00
|
|
|
|
DirtyFlag dirty_flag_;
|
2020-02-17 12:06:29 +08:00
|
|
|
|
uint32_t line_count_;
|
2020-08-04 16:31:20 +08:00
|
|
|
|
uint32_t content_length_;
|
2020-02-17 12:06:29 +08:00
|
|
|
|
Size size_;
|
2020-08-04 16:31:20 +08:00
|
|
|
|
BrushPtr fill_brush_;
|
|
|
|
|
|
BrushPtr outline_brush_;
|
|
|
|
|
|
StrokeStylePtr outline_stroke_;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
|
|
|
|
inline bool TextLayout::IsDirty() const
|
|
|
|
|
|
{
|
|
|
|
|
|
return dirty_flag_ != DirtyFlag::Clean;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-02-16 12:53:18 +08:00
|
|
|
|
inline void TextLayout::Clear()
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
2020-02-16 20:14:01 +08:00
|
|
|
|
ResetNativePointer();
|
2020-01-21 10:09:55 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2020-02-16 12:53:18 +08:00
|
|
|
|
inline TextLayout::DirtyFlag TextLayout::GetDirtyFlag() const
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
|
|
|
|
|
return dirty_flag_;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-02-16 12:53:18 +08:00
|
|
|
|
inline void TextLayout::SetDirtyFlag(TextLayout::DirtyFlag flag)
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
|
|
|
|
|
dirty_flag_ = flag;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-08-04 16:31:20 +08:00
|
|
|
|
inline BrushPtr TextLayout::GetFillBrush() const
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
2020-08-04 16:31:20 +08:00
|
|
|
|
return fill_brush_;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2020-08-04 16:31:20 +08:00
|
|
|
|
inline BrushPtr TextLayout::GetOutlineBrush() const
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
2020-08-04 16:31:20 +08:00
|
|
|
|
return outline_brush_;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2020-08-04 16:31:20 +08:00
|
|
|
|
inline StrokeStylePtr TextLayout::GetOutlineStrokeStyle() const
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
2020-08-04 16:31:20 +08:00
|
|
|
|
return outline_stroke_;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2020-08-04 16:31:20 +08:00
|
|
|
|
inline void TextLayout::SetFillBrush(BrushPtr brush)
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
2020-08-04 16:31:20 +08:00
|
|
|
|
fill_brush_ = brush;
|
2020-01-21 10:09:55 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2020-08-04 16:31:20 +08:00
|
|
|
|
inline void TextLayout::SetOutlineBrush(BrushPtr brush)
|
2020-01-21 10:09:55 +08:00
|
|
|
|
{
|
2020-08-04 16:31:20 +08:00
|
|
|
|
outline_brush_ = brush;
|
2019-08-15 11:22:51 +08:00
|
|
|
|
}
|
2020-02-07 20:50:27 +08:00
|
|
|
|
|
2020-08-04 16:31:20 +08:00
|
|
|
|
inline void TextLayout::SetOutlineStrokeStyle(StrokeStylePtr stroke)
|
2020-02-07 20:50:27 +08:00
|
|
|
|
{
|
2020-08-04 16:31:20 +08:00
|
|
|
|
outline_stroke_ = stroke;
|
2020-02-07 20:50:27 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2020-01-21 10:09:55 +08:00
|
|
|
|
} // namespace kiwano
|