/* * Copyright 2010 Inalogic® Inc. * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License, as * published by the Free Software Foundation; either version 2.1 or 3.0 * of the License. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranties of * MERCHANTABILITY, SATISFACTORY QUALITY or FITNESS FOR A PARTICULAR * PURPOSE. See the applicable version of the GNU Lesser General Public * License for more details. * * You should have received a copy of both the GNU Lesser General Public * License along with this program. If not, see * * Authored by: Jay Taoko * */ #ifndef GRIDHLAYOUT_H #define GRIDHLAYOUT_H #include "Layout.h" namespace nux { //! An horizontal grid layout. /*! Fills the grid from left to right and going down. */ class GridHLayout: public Layout { // The grid layout goes through the child elements and assign them a size and position. // 0 1 2 3 4 5 // 6 7 8 9 10 11 // 12 13 .. .. .. .. // This is a left to right fill, going down. NUX_DECLARE_OBJECT_TYPE(GridHLayout, Layout); public: enum FillingOrder { FILL_HORIZONTAL, FILL_VERTICAL }; GridHLayout(NUX_FILE_LINE_PROTO); ~GridHLayout(); virtual void GetCompositeList(std::list *ViewList); //! Control the visibility of elements on the bottom edge. /*! Controls how the layout places the elements at its bottom edge. @param partial_visibility If True, the layout will position elements at its bottom edge even if they are partially visible. */ void EnablePartialVisibility(bool partial_visibility); //! Set the size of the grid element. /*! Set the size of the grid element. @param width Width of elements. @param height Height of elements. */ void SetChildrenSize(int width, int height); //! Get the size of the grid element. /*! @return Size of the grid elements. */ Size GetChildrenSize() const; //! Force the grid elements size. /*! Force the grid elements size to be the one provided by SetChildrenSize. */ void ForceChildrenSize(bool force); //! Get the number of columns in the grid. int GetNumColumn() const; //! Get the number of rows in the grid. int GetNumRow() const; //! Make the grid width match the size of its content. /*! @param match_content If True, force the height of the layout to match the height of the content. This can also be achieve if the stretch factor of this layout is set to 0; */ void MatchContentSize(bool match_content); //! Return True if the grid width match the size of its content. bool IsMatchingContentSize() const; //! Draw Element /*! Draw all elements inside the layout. If force_draw is true then the system requests that all objects redraw themselves completely. @param force_draw @param TraverseInfo @param ProcessEventInfo @return The state of the Process Event. */ virtual void ProcessDraw(GraphicsEngine &graphics_engine, bool force_draw); void SetSpaceBetweenChildren(int horizontal_space, int vertical_space); void SetFillingOrder(FillingOrder order); FillingOrder GetFillingOrder() const; protected: long ComputeLayoutRowOrder(); long ComputeLayoutColumnOrder(); virtual long ComputeContentSize(); int GetChildPos(Area *child); Area* GetChildAtPosition(int pos); Area* KeyNavIterationRowOrder(KeyNavDirection direction); Area* KeyNavIterationColumnOrder(KeyNavDirection direction); virtual Area* KeyNavIteration(KeyNavDirection direction); FillingOrder filling_order_; int m_v_in_margin; int m_h_in_margin; private: Size _children_size; bool _dynamic_column; bool _force_children_size; bool _partial_visibility; bool match_content_size_; //!< If True, for the height of the layout to match the height of the content. int _num_row; int _num_column; // //! Compute the how elements are spread inside the layout // /*! // @param remaining_width Size that remains after subtracting elements width, inner and outer margins from the content width. // @param offset_space The space at the left of all elements. // @param element_margin The margin between elements. // */ // void ComputeStacking(int remaining_width, int &offset_space, int &element_margin); }; } #endif // GRIDHLAYOUT_H