Class GridLayout

All Implemented Interfaces:
Drawable.Callback, ViewManager, ViewParent

public class GridLayout extends ViewGroup
A layout that places its children in a rectangular grid.

The grid is composed of a set of infinitely thin lines that separate the viewing area into cells. Throughout the API, grid lines are referenced by grid indices. A grid with N columns has N + 1 grid indices that run from 0 through N inclusive. Regardless of how GridLayout is configured, grid index 0 is fixed to the leading edge of the container and grid index N is fixed to its trailing edge (after padding is taken into account).

Row and Column Specs

Children occupy one or more contiguous cells, as defined by their rowSpec and columnSpec layout parameters. Each spec defines the set of rows or columns that are to be occupied; and how children should be aligned within the resulting group of cells. Although cells do not normally overlap in a GridLayout, GridLayout does not prevent children being defined to occupy the same cell or group of cells. In this case however, there is no guarantee that children will not themselves overlap after the layout operation completes.

Default Cell Assignment

If a child does not specify the row and column indices of the cell it wishes to occupy, GridLayout assigns cell locations automatically using its: orientation, rowCount and columnCount properties.

Space

Space between children may be specified either by using instances of the dedicated

invalid reference
Space
view or by setting the

leftMargin, topMargin, rightMargin and bottomMargin

layout parameters. When the useDefaultMargins property is set, default margins around children are automatically allocated based on the prevailing UI style guide for the platform. Each of the margins so defined may be independently overridden by an assignment to the appropriate layout parameter. Default values will generally produce a reasonable spacing between components but values may change between different releases of the platform.

Excess Space Distribution

GridLayout's distribution of excess space accommodates the principle of weight. In the event that no weights are specified, the previous conventions are respected and columns and rows are taken as flexible if their views specify some form of alignment within their groups.

The flexibility of a view is therefore influenced by its alignment which is, in turn, typically defined by setting the gravity property of the child's layout parameters. If either a weight or alignment were defined along a given axis then the component is taken as flexible in that direction. If no weight or alignment was set, the component is instead assumed to be inflexible.

Multiple components in the same row or column group are considered to act in parallel. Such a group is flexible only if all of the components within it are flexible. Row and column groups that sit either side of a common boundary are instead considered to act in series. The composite group made of these two elements is flexible if one of its elements is flexible.

To make a column stretch, make sure all of the components inside it define a weight or a gravity. To prevent a column from stretching, ensure that one of the components in the column does not define a weight or a gravity.

When the principle of flexibility does not provide complete disambiguation, GridLayout's algorithms favour rows and columns that are closer to its right and bottom edges. To be more precise, GridLayout treats each of its layout parameters as a constraint in the a set of variables that define the grid-lines along a given axis. During layout, GridLayout solves the constraints so as to return the unique solution to those constraints for which all variables are less-than-or-equal-to the corresponding value in any other valid solution.

Interpretation of GONE

For layout purposes, GridLayout treats views whose visibility status is GONE, as having zero width and height. This is subtly different from the policy of ignoring views that are marked as GONE outright. If, for example, a gone-marked view was alone in a column, that column would itself collapse to zero width if and only if no gravity was defined on the view. If gravity was defined, then the gone-marked view has no effect on the layout and the container should be laid out as if the view had never been added to it. GONE views are taken to have zero weight during excess space distribution.

These statements apply equally to rows as well as columns, and to groups of rows or columns.

See GridLayout.LayoutParams for a full description of the layout parameters used by GridLayout.

  • Field Details

    • HORIZONTAL

      public static final int HORIZONTAL
      The horizontal orientation.
      See Also:
    • VERTICAL

      public static final int VERTICAL
      The vertical orientation.
      See Also:
    • UNDEFINED

      public static final int UNDEFINED
      The constant used to indicate that a value is undefined. Fields can use this value to indicate that their values have not yet been set. Similarly, methods can return this value to indicate that there is no suitable value that the implementation can return. The value used for the constant (currently Integer.MIN_VALUE) is intended to avoid confusion between valid values whose sign may not be known.
      See Also:
    • ALIGN_BOUNDS

      public static final int ALIGN_BOUNDS
      This constant is an alignmentMode. When the alignmentMode is set to ALIGN_BOUNDS, alignment is made between the edges of each component's raw view boundary: i.e. the area delimited by the component's: top, left, bottom and right properties.

      For example, when GridLayout is in ALIGN_BOUNDS mode, children that belong to a row group that uses TOP alignment will all return the same value when their View.getTop() method is called.

      See Also:
    • ALIGN_MARGINS

      public static final int ALIGN_MARGINS
      This constant is an alignmentMode. When the alignmentMode is set to ALIGN_MARGINS, the bounds of each view are extended outwards, according to their margins, before the edges of the resulting rectangle are aligned.

      For example, when GridLayout is in ALIGN_MARGINS mode, the quantity top - layoutParams.topMargin is the same for all children that belong to a row group that uses TOP alignment.

      See Also:
    • TOP

      public static final GridLayout.Alignment TOP
      Indicates that a view should be aligned with the top edges of the other views in its cell group.
    • BOTTOM

      public static final GridLayout.Alignment BOTTOM
      Indicates that a view should be aligned with the bottom edges of the other views in its cell group.
    • START

      public static final GridLayout.Alignment START
      Indicates that a view should be aligned with the start edges of the other views in its cell group.
    • END

      public static final GridLayout.Alignment END
      Indicates that a view should be aligned with the end edges of the other views in its cell group.
    • LEFT

      public static final GridLayout.Alignment LEFT
      Indicates that a view should be aligned with the left edges of the other views in its cell group.
    • CENTER

      public static final GridLayout.Alignment CENTER
      Indicates that a view should be centered with the other views in its cell group. This constant may be used in both rowSpecs and columnSpecs.
    • BASELINE

      public static final GridLayout.Alignment BASELINE
      Indicates that a view should be aligned with the baselines of the other views in its cell group. This constant may only be used as an alignment in rowSpecs.
      See Also:
    • FILL

      public static final GridLayout.Alignment FILL
      Indicates that a view should expanded to fit the boundaries of its cell group. This constant may be used in both rowSpecs and columnSpecs.
  • Constructor Details

    • GridLayout

      public GridLayout(Context context)
  • Method Details

    • getOrientation

      public int getOrientation()
      Returns the current orientation.
      Returns:
      either HORIZONTAL or VERTICAL
      See Also:
    • setOrientation

      public void setOrientation(int orientation)
      GridLayout uses the orientation property for two purposes:
      • To control the 'direction' in which default row/column indices are generated when they are not specified in a component's layout parameters.
      • To control which axis should be processed first during the layout operation: when orientation is HORIZONTAL the horizontal axis is laid out first.

      The order in which axes are laid out is important if, for example, the height of one of GridLayout's children is dependent on its width - and its width is, in turn, dependent on the widths of other components.

      If your layout contains a TextView (or derivative: Button, EditText, CheckBox, etc.) which is in multi-line mode (the default) it is normally best to leave GridLayout's orientation as HORIZONTAL - because TextView is capable of deriving its height for a given width, but not the other way around.

      Other than the effects above, orientation does not affect the actual layout operation of GridLayout, so it's fine to leave GridLayout in HORIZONTAL mode even if the height of the intended layout greatly exceeds its width.

      The default value of this property is HORIZONTAL.

      Parameters:
      orientation - either HORIZONTAL or VERTICAL
      See Also:
    • getRowCount

      public int getRowCount()
      Returns the current number of rows. This is either the last value that was set with setRowCount(int) or, if no such value was set, the maximum value of each the upper bounds defined in GridLayout.LayoutParams.rowSpec.
      Returns:
      the current number of rows
      See Also:
    • setRowCount

      public void setRowCount(int rowCount)
      RowCount is used only to generate default row/column indices when they are not specified by a component's layout parameters.
      Parameters:
      rowCount - the number of rows
      See Also:
    • getColumnCount

      public int getColumnCount()
      Returns the current number of columns. This is either the last value that was set with setColumnCount(int) or, if no such value was set, the maximum value of each the upper bounds defined in GridLayout.LayoutParams.columnSpec.
      Returns:
      the current number of columns
      See Also:
    • setColumnCount

      public void setColumnCount(int columnCount)
      ColumnCount is used only to generate default column/column indices when they are not specified by a component's layout parameters.
      Parameters:
      columnCount - the number of columns.
      See Also:
    • getUseDefaultMargins

      public boolean getUseDefaultMargins()
      Returns whether or not this GridLayout will allocate default margins when no corresponding layout parameters are defined.
      Returns:
      true if default margins should be allocated
      See Also:
    • setUseDefaultMargins

      public void setUseDefaultMargins(boolean useDefaultMargins)
      When true, GridLayout allocates default margins around children based on the child's visual characteristics. Each of the margins so defined may be independently overridden by an assignment to the appropriate layout parameter.

      When false, the default value of all margins is zero.

      When setting to true, consider setting the value of the alignmentMode property to ALIGN_BOUNDS.

      The default value of this property is false.

      Parameters:
      useDefaultMargins - use true to make GridLayout allocate default margins
      See Also:
    • getAlignmentMode

      public int getAlignmentMode()
      Returns the alignment mode.
      Returns:
      the alignment mode; either ALIGN_BOUNDS or ALIGN_MARGINS
      See Also:
    • setAlignmentMode

      public void setAlignmentMode(int alignmentMode)
      Sets the alignment mode to be used for all of the alignments between the children of this container.

      The default value of this property is ALIGN_MARGINS.

      Parameters:
      alignmentMode - either ALIGN_BOUNDS or ALIGN_MARGINS
      See Also:
    • isRowOrderPreserved

      public boolean isRowOrderPreserved()
      Returns whether or not row boundaries are ordered by their grid indices.
      Returns:
      true if row boundaries must appear in the order of their indices, false otherwise
      See Also:
    • setRowOrderPreserved

      public void setRowOrderPreserved(boolean rowOrderPreserved)
      When this property is true, GridLayout is forced to place the row boundaries so that their associated grid indices are in ascending order in the view.

      When this property is false GridLayout is at liberty to place the vertical row boundaries in whatever order best fits the given constraints.

      The default value of this property is true.

      Parameters:
      rowOrderPreserved - true to force GridLayout to respect the order of row boundaries
      See Also:
    • isColumnOrderPreserved

      public boolean isColumnOrderPreserved()
      Returns whether or not column boundaries are ordered by their grid indices.
      Returns:
      true if column boundaries must appear in the order of their indices, false otherwise
      See Also:
    • setColumnOrderPreserved

      public void setColumnOrderPreserved(boolean columnOrderPreserved)
      When this property is true, GridLayout is forced to place the column boundaries so that their associated grid indices are in ascending order in the view.

      When this property is false GridLayout is at liberty to place the horizontal column boundaries in whatever order best fits the given constraints.

      The default value of this property is true.

      Parameters:
      columnOrderPreserved - use true to force GridLayout to respect the order of column boundaries.
      See Also:
    • onSetLayoutParams

      @Internal protected void onSetLayoutParams(View child, ViewGroup.LayoutParams layoutParams)
      Overrides:
      onSetLayoutParams in class ViewGroup
    • checkLayoutParams

      protected boolean checkLayoutParams(ViewGroup.LayoutParams p)
      Description copied from class: ViewGroup
      Check whether given params fit to this view group.

      See also ViewGroup.generateLayoutParams(LayoutParams) See also ViewGroup.generateDefaultLayoutParams()

      Overrides:
      checkLayoutParams in class ViewGroup
      Parameters:
      p - layout params to check
      Returns:
      if params matched to this view group
    • generateDefaultLayoutParams

      @NonNull protected GridLayout.LayoutParams generateDefaultLayoutParams()
      Description copied from class: ViewGroup
      Returns a set of default layout parameters. These parameters are requested when the View passed to ViewGroup.addView(View) has no layout parameters already set. If null is returned, an exception is thrown from addView.
      Overrides:
      generateDefaultLayoutParams in class ViewGroup
      Returns:
      a set of default layout parameters
    • generateLayoutParams

      @NonNull protected GridLayout.LayoutParams generateLayoutParams(@NonNull ViewGroup.LayoutParams lp)
      Description copied from class: ViewGroup
      Returns a safe set of layout parameters based on the supplied layout params. When a ViewGroup is passed a View whose layout params do not pass the test of ViewGroup.checkLayoutParams(LayoutParams), this method is invoked. This method should return a new set of layout params suitable for this ViewGroup, possibly by copying the appropriate attributes from the specified set of layout params.
      Overrides:
      generateLayoutParams in class ViewGroup
      Parameters:
      lp - The layout parameters to convert into a suitable set of layout parameters for this ViewGroup.
      Returns:
      an instance of ViewGroup.LayoutParams or one of its descendants
    • onViewAdded

      public void onViewAdded(View child)
      Description copied from class: ViewGroup
      Called when a new child is added to this ViewGroup. Overrides should always call super.onViewAdded.
      Overrides:
      onViewAdded in class ViewGroup
      Parameters:
      child - the added child view
    • onViewRemoved

      public void onViewRemoved(View child)
      Description copied from class: ViewGroup
      Called when a child view is removed from this ViewGroup. Overrides should always call super.onViewRemoved.
      Overrides:
      onViewRemoved in class ViewGroup
      Parameters:
      child - the removed child view
    • onChildVisibilityChanged

      @Internal protected void onChildVisibilityChanged(View child, int oldVisibility, int newVisibility)
      We need to call invalidateStructure() when a child's GONE flag changes state. This implementation is a catch-all, invalidating on any change in the visibility flags.
      Overrides:
      onChildVisibilityChanged in class ViewGroup
      Parameters:
      child - The view whose visibility has changed
      oldVisibility - The previous visibility value (GONE, INVISIBLE, or VISIBLE).
      newVisibility - The new visibility value (GONE, INVISIBLE, or VISIBLE).
    • onMeasure

      protected void onMeasure(int widthSpec, int heightSpec)
      Description copied from class: View
      Measure the view and its content to determine the measured width and the measured height. This method is invoked by View.measure(int, int) and should be overridden by subclasses to provide accurate and efficient measurement of their contents.

      CONTRACT: When overriding this method, you must call View.setMeasuredDimension(int, int) to store the measured width and height of this view. Failure to do so will trigger an IllegalStateException, thrown by View.measure(int, int). Calling super.onMeasure() is a valid use.

      The base class implementation of measure defaults to the background size, unless a larger size is allowed by the MeasureSpec. Subclasses should override the base one to provide better measurements of their content.

      Overrides:
      onMeasure in class View
      Parameters:
      widthSpec - width measure specification imposed by the parent MeasureSpec
      heightSpec - height measure specification imposed by the parent MeasureSpec
    • requestLayout

      public void requestLayout()
      Description copied from class: View
      Call this when something has changed which has invalidated the layout of this view. This will schedule a layout pass of the view tree. This should not be called while the view hierarchy is currently in a layout pass (View.isInLayout(). If layout is happening, the request may be honored at the end of the current layout pass (and then layout will run again) or after the current frame is drawn and the next layout occurs.

      Subclasses which override this method should call the superclass method to handle possible request-during-layout errors correctly.

      Specified by:
      requestLayout in interface ViewParent
      Overrides:
      requestLayout in class View
    • onLayout

      protected void onLayout(boolean changed, int left, int top, int right, int bottom)
      Called from View.layout(int, int, int, int) when this view should assign a size and position to each of its children.

      Derived classes with children should override this method and call layout on each of their children.

      Specified by:
      onLayout in class ViewGroup
      Parameters:
      changed - This is a new size or position for this view
      left - Left position, relative to parent
      top - Top position, relative to parent
      right - Right position, relative to parent
      bottom - Bottom position, relative to parent
    • spec

      public static GridLayout.Spec spec(int start, int size, GridLayout.Alignment alignment, float weight)
      Return a Spec, spec, where:
      • spec.span = [start, start + size]
      • spec.alignment = alignment
      • spec.weight = weight

      To leave the start index undefined, use the value UNDEFINED.

      Parameters:
      start - the start
      size - the size
      alignment - the alignment
      weight - the weight
    • spec

      public static GridLayout.Spec spec(int start, GridLayout.Alignment alignment, float weight)
      Equivalent to: spec(start, 1, alignment, weight).
      Parameters:
      start - the start
      alignment - the alignment
      weight - the weight
    • spec

      public static GridLayout.Spec spec(int start, int size, float weight)
      Equivalent to: spec(start, 1, default_alignment, weight) - where default_alignment is specified in GridLayout.LayoutParams.
      Parameters:
      start - the start
      size - the size
      weight - the weight
    • spec

      public static GridLayout.Spec spec(int start, float weight)
      Equivalent to: spec(start, 1, weight).
      Parameters:
      start - the start
      weight - the weight
    • spec

      public static GridLayout.Spec spec(int start, int size, GridLayout.Alignment alignment)
      Equivalent to: spec(start, size, alignment, 0f).
      Parameters:
      start - the start
      size - the size
      alignment - the alignment
    • spec

      public static GridLayout.Spec spec(int start, GridLayout.Alignment alignment)
      Return a Spec, spec, where:
      • spec.span = [start, start + 1]
      • spec.alignment = alignment

      To leave the start index undefined, use the value UNDEFINED.

      Parameters:
      start - the start index
      alignment - the alignment
      See Also:
    • spec

      public static GridLayout.Spec spec(int start, int size)
      Return a Spec, spec, where:
      • spec.span = [start, start + size]

      To leave the start index undefined, use the value UNDEFINED.

      Parameters:
      start - the start
      size - the size
      See Also:
    • spec

      public static GridLayout.Spec spec(int start)
      Return a Spec, spec, where:
      • spec.span = [start, start + 1]

      To leave the start index undefined, use the value UNDEFINED.

      Parameters:
      start - the start index
      See Also: