Since: API Level 1
public interface

ViewParent

android.view.ViewParent
Known Indirect Subclasses

Class Overview

Defines the responsibilities for a class that will be a parent of a View. This is the API that a view sees when it wants to interact with its parent.

Summary

Public Methods
abstract void bringChildToFront(View child)
Change the z order of the child so it's on top of all other children
abstract void childDrawableStateChanged(View child)
This method is called on the parent when a child's drawable state has changed.
abstract void clearChildFocus(View child)
Called when a child of this parent is giving up focus
abstract void createContextMenu(ContextMenu menu)
Have the parent populate the specified context menu if it has anything to add (and then recurse on its parent).
abstract View focusSearch(View v, int direction)
Find the nearest view in the specified direction that wants to take focus
abstract void focusableViewAvailable(View v)
Tells the parent that a new focusable view has become available.
abstract boolean getChildVisibleRect(View child, Rect r, Point offset)
abstract ViewParent getParent()
Returns the parent if it exists, or null.
abstract void invalidateChild(View child, Rect r)
All or part of a child is dirty and needs to be redrawn.
abstract ViewParent invalidateChildInParent(int[] location, Rect r)
All or part of a child is dirty and needs to be redrawn.
abstract boolean isLayoutRequested()
Indicates whether layout was requested on this view parent.
abstract void recomputeViewAttributes(View child)
Tell view hierarchy that the global view attributes need to be re-evaluated.
abstract void requestChildFocus(View child, View focused)
Called when a child of this parent wants focus
abstract boolean requestChildRectangleOnScreen(View child, Rect rectangle, boolean immediate)
Called when a child of this group wants a particular rectangle to be positioned onto the screen.
abstract void requestDisallowInterceptTouchEvent(boolean disallowIntercept)
Called when a child does not want this parent and its ancestors to intercept touch events with onInterceptTouchEvent(MotionEvent).
abstract void requestLayout()
Called when something has changed which has invalidated the layout of a child of this view parent.
abstract void requestTransparentRegion(View child)
Called when a child wants the view hierarchy to gather and report transparent regions to the window compositor.
abstract boolean showContextMenuForChild(View originalView)
Bring up a context menu for the specified view or its ancestors.

Public Methods

public abstract void bringChildToFront (View child)

Since: API Level 1

Change the z order of the child so it's on top of all other children

public abstract void childDrawableStateChanged (View child)

Since: API Level 1

This method is called on the parent when a child's drawable state has changed.

Parameters
child The child whose drawable state has changed.

public abstract void clearChildFocus (View child)

Since: API Level 1

Called when a child of this parent is giving up focus

Parameters
child The view that is giving up focus

public abstract void createContextMenu (ContextMenu menu)

Since: API Level 1

Have the parent populate the specified context menu if it has anything to add (and then recurse on its parent).

Parameters
menu The menu to populate

public abstract View focusSearch (View v, int direction)

Since: API Level 1

Find the nearest view in the specified direction that wants to take focus

Parameters
v The view that currently has focus
direction One of FOCUS_UP, FOCUS_DOWN, FOCUS_LEFT, and FOCUS_RIGHT

public abstract void focusableViewAvailable (View v)

Since: API Level 1

Tells the parent that a new focusable view has become available. This is to handle transitions from the case where there are no focusable views to the case where the first focusable view appears.

Parameters
v The view that has become newly focusable

public abstract boolean getChildVisibleRect (View child, Rect r, Point offset)

Since: API Level 1

public abstract ViewParent getParent ()

Since: API Level 1

Returns the parent if it exists, or null.

Returns
  • a ViewParent or null if this ViewParent does not have a parent

public abstract void invalidateChild (View child, Rect r)

Since: API Level 1

All or part of a child is dirty and needs to be redrawn.

Parameters
child The child which is dirty
r The area within the child that is invalid

public abstract ViewParent invalidateChildInParent (int[] location, Rect r)

Since: API Level 1

All or part of a child is dirty and needs to be redrawn. The location array is an array of two int values which respectively define the left and the top position of the dirty child. This method must return the parent of this ViewParent if the specified rectangle must be invalidated in the parent. If the specified rectangle does not require invalidation in the parent or if the parent does not exist, this method must return null. When this method returns a non-null value, the location array must have been updated with the left and top coordinates of this ViewParent.

Parameters
location An array of 2 ints containing the left and top coordinates of the child to invalidate
r The area within the child that is invalid
Returns
  • the parent of this ViewParent or null

public abstract boolean isLayoutRequested ()

Since: API Level 1

Indicates whether layout was requested on this view parent.

Returns
  • true if layout was requested, false otherwise

public abstract void recomputeViewAttributes (View child)

Since: API Level 1

Tell view hierarchy that the global view attributes need to be re-evaluated.

Parameters
child View whose attributes have changed.

public abstract void requestChildFocus (View child, View focused)

Since: API Level 1

Called when a child of this parent wants focus

Parameters
child The child of this ViewParent that wants focus. This view will contain the focused view. It is not necessarily the view that actually has focus.
focused The view that is a descendant of child that actually has focus

public abstract boolean requestChildRectangleOnScreen (View child, Rect rectangle, boolean immediate)

Since: API Level 3

Called when a child of this group wants a particular rectangle to be positioned onto the screen. ViewGroups overriding this can trust that:

  • child will be a direct child of this group
  • rectangle will be in the child's coordinates

ViewGroups overriding this should uphold the contract:

  • nothing will change if the rectangle is already visible
  • the view port will be scrolled only just enough to make the rectangle visible
Parameters
child The direct child making the request.
rectangle The rectangle in the child's coordinates the child wishes to be on the screen.
immediate True to forbid animated or delayed scrolling, false otherwise
Returns
  • Whether the group scrolled to handle the operation

public abstract void requestDisallowInterceptTouchEvent (boolean disallowIntercept)

Since: API Level 1

Called when a child does not want this parent and its ancestors to intercept touch events with onInterceptTouchEvent(MotionEvent).

This parent should pass this call onto its parents. This parent must obey this request for the duration of the touch (that is, only clear the flag after this parent has received an up or a cancel.

Parameters
disallowIntercept True if the child does not want the parent to intercept touch events.

public abstract void requestLayout ()

Since: API Level 1

Called when something has changed which has invalidated the layout of a child of this view parent. This will schedule a layout pass of the view tree.

public abstract void requestTransparentRegion (View child)

Since: API Level 1

Called when a child wants the view hierarchy to gather and report transparent regions to the window compositor. Views that "punch" holes in the view hierarchy, such as SurfaceView can use this API to improve performance of the system. When no such a view is present in the hierarchy, this optimization in unnecessary and might slightly reduce the view hierarchy performance.

Parameters
child the view requesting the transparent region computation

public abstract boolean showContextMenuForChild (View originalView)

Since: API Level 1

Bring up a context menu for the specified view or its ancestors.

In most cases, a subclass does not need to override this. However, if the subclass is added directly to the window manager (for example, addView(View, android.view.ViewGroup.LayoutParams)) then it should override this and show the context menu.

Parameters
originalView The source view where the context menu was first invoked
Returns
  • true if a context menu was displayed