X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Ftext%2Fmarkup-processor-helper-functions.h;h=d1ecbc8f54af587fc8bc17b47e4bd3e7d635fac1;hp=cf494d22297816a2f45d68bd20649740a4a43b6c;hb=ff0db3ef923086d96dc8c2eb8501607da9c3c21e;hpb=69669144df0027a66725f167fd1b99e12b8860ad diff --git a/dali-toolkit/internal/text/markup-processor-helper-functions.h b/dali-toolkit/internal/text/markup-processor-helper-functions.h index cf494d2..d1ecbc8 100644 --- a/dali-toolkit/internal/text/markup-processor-helper-functions.h +++ b/dali-toolkit/internal/text/markup-processor-helper-functions.h @@ -28,6 +28,9 @@ namespace Dali { +struct Vector2; +struct Vector4; + namespace Toolkit { @@ -76,11 +79,103 @@ bool TokenComparison( const std::string& string1, const char* const stringBuffer /** * @brief Skips any unnecessary white space. * - * @param[in,out] markupStringBuffer The mark-up string buffer. It's a const iterator pointing the current character. - * @param[in] markupStringEndBuffer Pointer to one character after the end of the mark-up string buffer. + * @param[in,out] stringBuffer The string buffer. It's a const iterator pointing the current character. + * @param[in] stringEndBuffer Pointer to one character after the end of the string buffer. + */ +void SkipWhiteSpace( const char*& stringBuffer, + const char* const stringEndBuffer ); + +/** + * @Brief Jumps to the next white space. + * + * @param[in,out] stringBuffer The string buffer. It's a const iterator pointing the current character. + * @param[in] stringEndBuffer Pointer to one character after the end of the string buffer. + */ +void JumpToWhiteSpace( const char*& stringBuffer, + const char* const stringEndBuffer ); + +/** + * @brief Converts a string into an hexadecimal unsigned int. + * + * @param[in] uintStr An hexadecimal unsigned int packed inside a string. + * + * @return The hexadecimal value. + */ +unsigned int StringToHex( const char* const uintStr ); + +/** + * @brief Converts a string into a float value. + * + * @param[in] floatStr A float packed inside a string. + * + * @return The float value. + */ +float StringToFloat( const char* const floatStr ); + +/** + * @brief Converts a float into a string. + * + * @param[in] value The float value. + * @param[out] floatStr The string. + */ +void FloatToString( float value, std::string& floatStr ); + +/** + * @brief Converts an unsigned int into a string. + * + * @param[in] value The unsigned int value. + * @param[out] uIntStr The string. + */ +void UintToString( unsigned int value, std::string& uIntStr ); + +/** + * @brief Converts an ARGB color packed in 4 byte unsigned int into a Vector4 color used in Dali. + * + * @param[in] color An ARGB color packed in an unsigned int. + * @param[out] retColor A Vector4 with the converted color. + */ +void UintColorToVector4( unsigned int color, Vector4& retColor ); + +/** + * @brief Converts a color packed inside a string into an ARGB Vector4 color. + * + * The string color could be in hexadecimal ( 0xFF0000FF ), webcolor ( #0000FF or #00F ) or some constant values: + * black, white, red, green, blue, yellow, magenta, cyan or transparent. + * + * @param[in] colorStr A color packed inside a string. + * @param[in] length The length of the color string. + * @param[out] retColor A color packed inside a Vector4. + */ +void ColorStringToVector4( const char* const colorStr, Length length, Vector4& retColor ); + +/** + * @brief Converts a color packed in a Vector4 into a string. + * + * Constant colors will be converted to the strings black, white, red, green, blue, yellow, magenta, cyan or transparent. + * + * If is not a constant color it will be converted to a string with hexadecimal ARGB content. + * + * @param[in] value The color value. + * @param[out] colorStr The string. + */ +void Vector4ToColorString( const Vector4& value, std::string& vector2Str ); + +/** + * @brief Converts a two dimension vector packed inside a string into a Vector2. + * + * @param[in] vectorStr The two dimension vector packed inside a string. + * @param[in] length The length of the string. + * @param[out] vector2 The Vector2. + */ +void StringToVector2( const char* const vectorStr, Length length, Vector2& vector2 ); + +/** + * @brief Converts a Vector2 into a string. + * + * @param[in] value The vector2 value. + * @param[out] vector2Str The string. */ -void SkipWhiteSpace( const char*& markupStringBuffer, - const char* const markupStringEndBuffer ); +void Vector2ToString( const Vector2& value, std::string& vector2Str ); } // namespace Text