X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Ftext%2Ftext-controller-relayouter.h;h=c0ab806a13883e8fb8a595d05da3114ab649cff3;hb=41e93476dff5dd7dd826f43e99aa3ef7e3ee2906;hp=cfb7e83526b4ce0de2b7d2e6c3dbd874ee24ea9b;hpb=28e96ebc81b38645d8b46ca923fa6aaa0517d2cd;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/internal/text/text-controller-relayouter.h b/dali-toolkit/internal/text/text-controller-relayouter.h index cfb7e83..c0ab806 100644 --- a/dali-toolkit/internal/text/text-controller-relayouter.h +++ b/dali-toolkit/internal/text/text-controller-relayouter.h @@ -2,7 +2,7 @@ #define DALI_TOOLKIT_TEXT_CONTROLLER_RELAYOUTER_H /* - * Copyright (c) 2020 Samsung Electronics Co., Ltd. + * Copyright (c) 2021 Samsung Electronics Co., Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -28,13 +28,10 @@ namespace Dali { - namespace Toolkit { - namespace Text { - /** * Contains all the relayouting related methods for Text::Controller */ @@ -59,6 +56,14 @@ struct Controller::Relayouter static bool CheckForTextFit(Controller& controller, float pointSize, const Size& layoutSize); /** + * @brief Calculates the point size for text for given layout() + * + * @param[in] controller A reference to the controller class + * @param[in] layoutSize The layout size + */ + static void FitPointSizeforLayout(Controller& controller, const Size& layoutSize); + + /** * @brief Called by the Controller to get the height for a particular width. * * @param[in] controller A reference to the controller class @@ -80,13 +85,14 @@ struct Controller::Relayouter /** * @brief Called by the Controller to do certain operations when relayouting. * - * @param[in] controller A reference to the controller class + * @param[in] impl A reference to the controller impl class * @param[in] size The size to set * @param[in] operationsRequired The operations we need to do * @param[in/out] layoutSize The Layout size which can be updated depending on the result of the performed operations * @return */ - static bool DoRelayout(Controller& controller, const Size& size, OperationsMask operationsRequired, Size& layoutSize ); + + static bool DoRelayout(Controller::Impl& impl, const Size& size, OperationsMask operationsRequired, Size& layoutSize); /** * @brief Called by the Controller to calculate the veritcal offset give the control size. @@ -95,6 +101,31 @@ struct Controller::Relayouter * @param[in] controlSize The control size */ static void CalculateVerticalOffset(Controller& controller, const Size& controlSize); + + /** + * @brief Calculates the layout size of control according to @p requestedControllerSize and @p requestedOperationsMask + * + * GetNaturalSize() and GetHeightForWidth() calls this method. + * + * @param[in] controller The controller to calcualte size on it. + * @param[in] requestedControllerSize The requested size of controller to calcualte layout size on it. + * @param[in] requestedOperationsMask The requested operations-mask to calcualte layout size according to it. + * + * @return The calculated layout-size. + */ + static Size CalculateLayoutSizeOnRequiredControllerSize(Controller& controller, const Size& requestedControllerSize, const OperationsMask& requestedOperationsMask); + +private: + /** + * @brief Called by the DoRelayout to do HorizontalAlignment operation when relayouting. + * + * @param[in] impl A reference to the controller impl class + * @param[in] size The size to set + * @param[in] startIndex The start index for relayouting + * @param[in] requestedNumberOfCharacters The number Of characters for relayouting + */ + + static void DoRelayoutHorizontalAlignment(Controller::Impl& impl, const Size& size, const CharacterIndex startIndex, const Length requestedNumberOfCharacters); }; } // namespace Text