Magic_Game/src/kiwano/render/StrokeStyle.h

237 lines
6.2 KiB
C
Raw Normal View History

// Copyright (c) 2016-2019 Kiwano - Nomango
2020-01-21 10:09:55 +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
//
// 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
//
// 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-16 20:14:01 +08:00
#include <kiwano/render/NativeObject.h>
2019-04-11 14:40:54 +08:00
namespace kiwano
{
2020-01-21 10:09:55 +08:00
2020-02-06 16:54:47 +08:00
KGE_DECLARE_SMART_PTR(StrokeStyle);
2020-01-21 10:09:55 +08:00
/**
* \addtogroup Render
* @{
*/
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><CBB5><EFBFBD>ʽ
/// @details <20><><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><CBB5><EFBFBD>ʽ<EFBFBD><CABD>ʾ<EFBFBD>߶ζ˵㲿<CBB5>ֵ<EFBFBD><D6B5><EFBFBD>״
2020-01-21 10:09:55 +08:00
enum class CapStyle
{
Flat, ///< <20><><EFBFBD>˵<EFBFBD>
Square, ///< <20><><EFBFBD>ζ˵㣬<CBB5><E3A3AC><EFBFBD><EFBFBD>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD><D6B5><EFBFBD><EFBFBD>߶ο<DFB6><CEBF>ȵ<EFBFBD>һ<EFBFBD><D2BB>
Round, ///< Բ<>ζ˵㣬Բֱ<D4B2><D6B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>߶ο<DFB6><CEBF><EFBFBD>
Triangle, ///< <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ<EFBFBD><CABD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD>߳<EFBFBD><DFB3>ȵ<EFBFBD><C8B5><EFBFBD><EFBFBD>߶ο<DFB6><CEBF><EFBFBD>
2020-01-21 10:09:55 +08:00
};
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @details <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ<EFBFBD><CABD>ʾ<EFBFBD><CABE><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><E0BDBB><EFBFBD>ֵ<EFBFBD><D6B5><EFBFBD>״
2020-01-21 10:09:55 +08:00
enum class LineJoinStyle
{
Miter, ///< б<><D0B1><EFBFBD><EFBFBD>ʽ
Bevel, ///< б<><D0B1><EFBFBD><EFBFBD>ʽ
Round ///< Բ<><D4B2><EFBFBD><EFBFBD>ʽ
2020-01-21 10:09:55 +08:00
};
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @details <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ<EFBFBD><CABD>ʾ<EFBFBD>߶εļ<CEB5>϶
2020-01-21 10:09:55 +08:00
enum class DashStyle
{
Solid, ///< <20>޼<EFBFBD><DEBC>ϵ<EFBFBD>ʵ<EFBFBD><CAB5>
Dash, ///< б<><D0B1><EFBFBD><EFBFBD>ʽ
Dot, ///< Բ<><D4B2><EFBFBD><EFBFBD>ʽ
DashDot, ///< Բ<><D4B2><EFBFBD><EFBFBD>ʽ
DashDotDot, ///< Բ<><D4B2><EFBFBD><EFBFBD>ʽ
2020-01-21 10:09:55 +08:00
};
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
2020-02-16 20:14:01 +08:00
class StrokeStyle : public NativeObject
2020-01-21 10:09:55 +08:00
{
public:
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param width <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/// @param cap <20><><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><CBB5><EFBFBD>ʽ
/// @param line_join <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
2020-07-22 21:08:48 +08:00
StrokeStyle(float width, CapStyle cap = CapStyle::Flat, LineJoinStyle line_join = LineJoinStyle::Miter);
2020-02-16 20:14:01 +08:00
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param width <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/// @param cap <20><><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><CBB5><EFBFBD>ʽ
/// @param line_join <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param dash <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param dash_offset <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƫ<EFBFBD><C6AB><EFBFBD><EFBFBD>
2020-07-22 21:08:48 +08:00
StrokeStyle(float width, CapStyle cap, LineJoinStyle line_join, DashStyle dash, float dash_offset = 0.0f);
2020-01-21 10:09:55 +08:00
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param width <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/// @param cap <20><><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><CBB5><EFBFBD>ʽ
/// @param line_join <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param dash_array <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵij<DFB5><C4B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>϶<EFBFBD><CFB6><EFBFBD><EFBFBD>
/// @param dash_size <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>С
/// @param dash_offset <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƫ<EFBFBD><C6AB><EFBFBD><EFBFBD>
2020-07-22 21:08:48 +08:00
StrokeStyle(float width, CapStyle cap, LineJoinStyle line_join, const float* dash_array, size_t dash_size,
float dash_offset = 0.0f);
2020-01-21 10:09:55 +08:00
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @tparam _DashSize <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>С
/// @param width <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/// @param cap <20><><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><CBB5><EFBFBD>ʽ
/// @param line_join <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param dash_array <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵij<DFB5><C4B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>϶<EFBFBD><CFB6><EFBFBD><EFBFBD>
/// @param dash_offset <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƫ<EFBFBD><C6AB><EFBFBD><EFBFBD>
2020-01-21 10:09:55 +08:00
template <size_t _DashSize>
2020-07-22 21:08:48 +08:00
StrokeStyle(float width, CapStyle cap, LineJoinStyle line_join, float (&dash_array)[_DashSize],
float dash_offset = 0.0f)
: StrokeStyle(width, cap, line_join, dash_array, _DashSize, dash_offset)
2020-01-21 10:09:55 +08:00
{
}
2020-02-06 16:54:47 +08:00
StrokeStyle();
/// \~chinese
/// @brief <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/// @param width <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2020-02-16 20:14:01 +08:00
float GetStrokeWidth() const;
2020-02-06 16:54:47 +08:00
2020-02-11 12:09:59 +08:00
/// \~chinese
/// @brief <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><CBB5><EFBFBD>ʽ
2020-02-11 12:09:59 +08:00
CapStyle GetCapStyle() const;
/// \~chinese
/// @brief <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
2020-02-11 12:09:59 +08:00
LineJoinStyle GetLineJoinStyle() const;
/// \~chinese
/// @brief <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵij<DFB5><C4B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>϶<EFBFBD><CFB6><EFBFBD><EFBFBD>
2020-02-11 12:09:59 +08:00
const Vector<float>& GetDashArray() const;
/// \~chinese
/// @brief <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD>ƫ<EFBFBD><C6AB><EFBFBD><EFBFBD>
2020-02-11 12:09:59 +08:00
float GetDashOffset() const;
2020-02-16 20:14:01 +08:00
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/// @param width <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2020-02-16 20:14:01 +08:00
void SetStrokeWidth(float width);
2020-02-11 12:09:59 +08:00
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><CBB5><EFBFBD>ʽ
2020-02-11 12:09:59 +08:00
void SetCapStyle(CapStyle cap);
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
2020-02-11 12:09:59 +08:00
void SetLineJoinStyle(LineJoinStyle line_join);
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param dash_style <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
2020-02-11 12:09:59 +08:00
void SetDashStyle(DashStyle dash_style);
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param dash_array <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵij<DFB5><C4B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>϶<EFBFBD><CFB6><EFBFBD><EFBFBD>
2020-02-11 12:09:59 +08:00
void SetDashStyle(const Vector<float>& dash_array);
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @param dash_array <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵij<DFB5><C4B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>϶<EFBFBD><CFB6><EFBFBD><EFBFBD>
/// @param dash_size <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>С
2020-02-11 12:09:59 +08:00
void SetDashStyle(const float* dash_array, size_t dash_size);
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
/// @tparam _DashSize <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>С
/// @param dash_array <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵij<DFB5><C4B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>϶<EFBFBD><CFB6><EFBFBD><EFBFBD>
2020-02-11 12:09:59 +08:00
template <size_t _DashSize>
inline void SetDashStyle(float (&dash_array)[_DashSize])
{
SetDashStyle(dash_array, _DashSize);
}
/// \~chinese
/// @brief <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƫ<EFBFBD><C6AB><EFBFBD><EFBFBD>
/// @param dash_offset <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƫ<EFBFBD><C6AB><EFBFBD><EFBFBD>
2020-02-11 12:09:59 +08:00
void SetDashOffset(float dash_offset);
private:
CapStyle cap_;
LineJoinStyle line_join_;
2020-02-16 20:14:01 +08:00
float stroke_width_;
2020-02-11 12:09:59 +08:00
float dash_offset_;
Vector<float> dash_array_;
2020-01-21 10:09:55 +08:00
};
/** @} */
2020-02-16 20:14:01 +08:00
inline float StrokeStyle::GetStrokeWidth() const
{
return stroke_width_;
}
2020-02-11 12:09:59 +08:00
inline CapStyle StrokeStyle::GetCapStyle() const
2020-01-21 10:09:55 +08:00
{
2020-02-11 12:09:59 +08:00
return cap_;
}
inline LineJoinStyle StrokeStyle::GetLineJoinStyle() const
{
return line_join_;
}
inline const Vector<float>& StrokeStyle::GetDashArray() const
{
return dash_array_;
}
inline float StrokeStyle::GetDashOffset() const
{
return dash_offset_;
}
2020-02-16 20:14:01 +08:00
inline void StrokeStyle::SetStrokeWidth(float width)
{
stroke_width_ = width;
}
2020-02-11 12:09:59 +08:00
inline void StrokeStyle::SetCapStyle(CapStyle cap)
{
cap_ = cap;
}
inline void StrokeStyle::SetLineJoinStyle(LineJoinStyle line_join)
{
line_join_ = line_join;
}
inline void StrokeStyle::SetDashOffset(float dash_offset)
{
dash_offset_ = dash_offset;
2019-08-16 00:50:54 +08:00
}
2020-02-07 20:50:27 +08:00
2020-01-21 10:09:55 +08:00
} // namespace kiwano