ConstraintLayout

public class ConstraintLayout

Known direct subclasses
MotionLayout

A subclass of ConstraintLayout that supports animating between various states Added in 2.0


A {@code ConstraintLayout} is a android.view.ViewGroup which allows you to position and size widgets in a flexible way.

Note:{@code ConstraintLayout} is available as a support library that you can use on Android systems starting with API level 9 (Gingerbread). As such, we are planning on enriching its API and capabilities over time. This documentation will reflect those changes.

There are currently various types of constraints that you can use:

Note that you cannot have a circular dependency in constraints.

Also see ConstraintLayout.LayoutParams for layout attributes

This tells the system that we want the left side of button B to be constrained to the right side of button A. Such a position constraint means that the system will try to have both sides share the same location. Using bias, you can craft User Interfaces that will better adapt to screen sizes changes. Those minimum and maximum dimensions will be used by when its dimensions are set to . The first two works in a similar fashion as other layouts. The last one will resize the widget in such a way as matching the constraints that are set (see Fig. 8, (a) is wrap_content, (b) is 0dp). If margins are set, they will be taken in account in the computation (Fig. 8, (c) with 0dp). The value indicated for min and max can be either a dimension in Dp, or "wrap", which will use the same value as what would do. To use percent, you need to set the following: will set the height of the button to be the same as its width. will set the height of the button following a 16:9 ratio, while the width of the button will match the constraints to its parent.

Summary

Nested types

ConstraintLayout.LayoutParams

This class contains the different attributes specifying how a view want to be laid out inside a ConstraintLayout.

Constants

static final @NonNull int
static final @NonNull String

Public constructors

ConstraintLayout(
    @NonNull Context context,
    @Nullable AttributeSet attrs,
    @NonNull int defStyleAttr
)
ConstraintLayout(
    @NonNull Context context,
    @Nullable AttributeSet attrs,
    @NonNull int defStyleAttr,
    @NonNull int defStyleRes
)

Public methods

@NonNull void
@Override @NonNull void
@Override @NonNull ConstraintLayout.LayoutParams
@NonNull Object
@NonNull int

The maximum height of this view.

@NonNull int
@NonNull int

The minimum height of this view.

@NonNull int

The minimum width of this view.

@NonNull int

Return the current optimization level for the layout resolution

static @NonNull SharedValues

Returns the SharedValues instance, creating it if it doesn't exist.

@NonNull View
final @NonNull ConstraintWidget
@NonNull void
loadLayoutDescription(@NonNull int layoutDescription)

Load a layout description file from the resources.

@Override @NonNull void
@Override @NonNull void
@Override @NonNull void
@NonNull void

Sets a ConstraintSet object to manage constraints.

@NonNull void
setDesignInformation(
    @NonNull int type,
    @NonNull Object value1,
    @NonNull Object value2
)
@Override @NonNull void
setId(@NonNull int id)
@NonNull void
setMaxHeight(@NonNull int value)

Set the max height for this view

@NonNull void
setMaxWidth(@NonNull int value)

Set the max width for this view

@NonNull void
setMinHeight(@NonNull int value)

Set the min height for this view

@NonNull void
setMinWidth(@NonNull int value)

Set the min width for this view

@NonNull void
setOnConstraintsChanged(
    @NonNull ConstraintsChangedListener constraintsChangedListener
)
@NonNull void

Set the optimization for the layout resolution.

@NonNull void
setState(@NonNull int id, @NonNull int screenWidth, @NonNull int screenHeight)

Set the State of the ConstraintLayout, causing it to load a particular ConstraintSet.

@Override @NonNull boolean

Inherited methods

From class View
@NonNull void
@NonNull void
@NonNull void
@NonNull ViewPropertyAnimator
@NonNull void
@NonNull void
@NonNull void
@NonNull void

This method is deprecated.

@NonNull void
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
canScrollVertically(@NonNull int direction)
final @NonNull void
@NonNull void
final @NonNull void
@NonNull boolean
@NonNull void
static @NonNull int
combineMeasuredStates(@NonNull int curState, @NonNull int newState)
@NonNull void
@NonNull WindowInsets
computeSystemWindowInsets(
    @NonNull WindowInsets in,
    @NonNull Rect outLocalInsets
)
@NonNull AccessibilityNodeInfo
@NonNull void
@NonNull void

This method is deprecated.

@NonNull boolean
@NonNull boolean
dispatchNestedFling(
    @NonNull float velocityX,
    @NonNull float velocityY,
    @NonNull boolean consumed
)
@NonNull boolean
dispatchNestedPreFling(@NonNull float velocityX, @NonNull float velocityY)
@NonNull boolean
dispatchNestedPrePerformAccessibilityAction(
    @NonNull int action,
    @NonNull Bundle arguments
)
@NonNull boolean
dispatchNestedPreScroll(
    @NonNull int dx,
    @NonNull int dy,
    @NonNull Array<@NonNull int> consumed,
    @NonNull Array<@NonNull int> offsetInWindow
)
@NonNull boolean
dispatchNestedScroll(
    @NonNull int dxConsumed,
    @NonNull int dyConsumed,
    @NonNull int dxUnconsumed,
    @NonNull int dyUnconsumed,
    @NonNull Array<@NonNull int> offsetInWindow
)
@NonNull boolean
@NonNull void
draw(@NonNull Canvas canvas)
@NonNull void
drawableHotspotChanged(@NonNull float x, @NonNull float y)
final @NonNull T
<T extends View> findViewById(@NonNull int id)
final @NonNull T
<T extends View> findViewWithTag(@NonNull Object tag)
@NonNull void
forceHasOverlappingRendering(@NonNull boolean hasOverlappingRendering)
static @NonNull int
@NonNull View.AccessibilityDelegate
@NonNull int
@NonNull AccessibilityNodeProvider
@NonNull CharSequence
@NonNull int
@NonNull int
@NonNull float
@NonNull Animation
@NonNull Matrix
@NonNull IBinder
@NonNull Array<@NonNull int>
@NonNull Map<@NonNull Integer, @NonNull Integer>
@NonNull Array<@NonNull String>
final @NonNull AutofillId
@NonNull int
@NonNull AutofillValue
@NonNull Drawable
@NonNull BlendMode
@NonNull ColorStateList
@NonNull PorterDuff.Mode
@NonNull int
final @NonNull int
@NonNull float
@NonNull Rect
@NonNull boolean
final @NonNull boolean
final @NonNull ContentCaptureSession
@NonNull CharSequence
final @NonNull Context
final @NonNull boolean
static @NonNull int
getDefaultSize(@NonNull int size, @NonNull int measureSpec)
@NonNull Display
final @NonNull Array<@NonNull int>
@NonNull Bitmap

This method is deprecated.

@NonNull int

This method is deprecated.

@NonNull int

This method is deprecated.

@NonNull void
@NonNull long
@NonNull float
@NonNull int
@NonNull boolean
@NonNull boolean
@NonNull int
@NonNull ArrayList<@NonNull View>
getFocusables(@NonNull int direction)
@NonNull void
@NonNull Drawable
@NonNull int
@NonNull BlendMode
@NonNull ColorStateList
@NonNull PorterDuff.Mode
@NonNull boolean
@NonNull Handler
final @NonNull boolean
final @NonNull int
@NonNull void
@NonNull int
@NonNull Drawable
@NonNull Drawable
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull boolean
@NonNull KeyEvent.DispatcherState
@NonNull int
@NonNull int
@NonNull int
@NonNull ViewGroup.LayoutParams
final @NonNull int
final @NonNull boolean
@NonNull void
@NonNull void
@NonNull void
@NonNull Matrix
final @NonNull int
final @NonNull int
final @NonNull int
final @NonNull int
final @NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull View.OnFocusChangeListener
@NonNull int
@NonNull ViewOutlineProvider
@NonNull int
@NonNull int
@NonNull ViewOverlay
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull int
final @NonNull ViewParent
@NonNull ViewParent
@NonNull float
@NonNull float
@NonNull PointerIcon
@NonNull Resources
final @NonNull boolean
final @NonNull int
@NonNull View
@NonNull WindowInsets
@NonNull float
@NonNull float
@NonNull float
@NonNull float
@NonNull float
@NonNull int
@NonNull int
@NonNull int
@NonNull int
@NonNull int
final @NonNull int
final @NonNull int
@NonNull int
@NonNull int
final @NonNull CharSequence
@NonNull StateListAnimator
@NonNull List<@NonNull Rect>
@NonNull int

This method is deprecated.

@NonNull Object
@NonNull int
@NonNull int
@NonNull CharSequence
final @NonNull int
@NonNull TouchDelegate
@NonNull ArrayList<@NonNull View>
@NonNull float
@NonNull String
@NonNull float
@NonNull float
@NonNull float
@NonNull long
@NonNull int
@NonNull int
@NonNull Drawable
@NonNull Drawable
@NonNull int
@NonNull ViewTreeObserver
@NonNull int
final @NonNull int
@NonNull WindowId
@NonNull WindowInsetsController
@NonNull int

This method is deprecated.

@NonNull IBinder
@NonNull int
@NonNull void
@NonNull float
@NonNull float
@NonNull float
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
static @NonNull View
inflate(
    @NonNull Context context,
    @NonNull int resource,
    @NonNull ViewGroup root
)
@NonNull void

This method is deprecated.

@NonNull void
@NonNull void
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean

This method is deprecated.

@NonNull boolean
@NonNull boolean
final @NonNull boolean
final @NonNull boolean
@NonNull boolean
final @NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
final @NonNull boolean
final @NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
final @NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
final @NonNull boolean
@NonNull boolean
@NonNull boolean
final @NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull View
keyboardNavigationClusterSearch(
    @NonNull View currentCluster,
    @NonNull int direction
)
final @NonNull void
measure(@NonNull int widthMeasureSpec, @NonNull int heightMeasureSpec)
@NonNull void
@NonNull void
@NonNull WindowInsets
@NonNull void
@NonNull boolean
@NonNull boolean
@NonNull InputConnection
@NonNull boolean
@NonNull void
@NonNull boolean
@NonNull void
@NonNull boolean
@NonNull void
onHoverChanged(@NonNull boolean hovered)
@NonNull boolean
@NonNull void
@NonNull void
@NonNull boolean
onKeyDown(@NonNull int keyCode, @NonNull KeyEvent event)
@NonNull boolean
onKeyLongPress(@NonNull int keyCode, @NonNull KeyEvent event)
@NonNull boolean
onKeyMultiple(
    @NonNull int keyCode,
    @NonNull int repeatCount,
    @NonNull KeyEvent event
)
@NonNull boolean
onKeyPreIme(@NonNull int keyCode, @NonNull KeyEvent event)
@NonNull boolean
onKeyShortcut(@NonNull int keyCode, @NonNull KeyEvent event)
@NonNull boolean
onKeyUp(@NonNull int keyCode, @NonNull KeyEvent event)
@NonNull void
onPointerCaptureChange(@NonNull boolean hasCapture)
@NonNull void
@NonNull void
onProvideAutofillStructure(
    @NonNull ViewStructure structure,
    @NonNull int flags
)
@NonNull void
onProvideAutofillVirtualStructure(
    @NonNull ViewStructure structure,
    @NonNull int flags
)
@NonNull void
onProvideContentCaptureStructure(
    @NonNull ViewStructure structure,
    @NonNull int flags
)
@NonNull void
@NonNull void
@NonNull void
onRtlPropertiesChanged(@NonNull int layoutDirection)
@NonNull void
onScreenStateChanged(@NonNull int screenState)
@NonNull void
@NonNull boolean
@NonNull boolean
@NonNull void
onVisibilityAggregated(@NonNull boolean isVisible)
@NonNull void
onWindowFocusChanged(@NonNull boolean hasWindowFocus)
@NonNull void

This method is deprecated.

@NonNull boolean
performAccessibilityAction(@NonNull int action, @NonNull Bundle arguments)
@NonNull boolean
@NonNull boolean
performContextClick(@NonNull float x, @NonNull float y)
@NonNull boolean
performHapticFeedback(@NonNull int feedbackConstant)
@NonNull boolean
@NonNull void
playSoundEffect(@NonNull int soundConstant)
@NonNull boolean
@NonNull boolean
postDelayed(@NonNull Runnable action, @NonNull long delayMillis)
@NonNull void
@NonNull void
postInvalidateDelayed(@NonNull long delayMilliseconds)
@NonNull void
@NonNull void
@NonNull void
postOnAnimationDelayed(@NonNull Runnable action, @NonNull long delayMillis)
@NonNull void
@NonNull void
@NonNull boolean
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void

This method is deprecated.

final @NonNull boolean
@NonNull void
@NonNull boolean
final @NonNull void
final @NonNull T
<T extends View> requireViewById(@NonNull int id)
@NonNull void
static @NonNull int
resolveSize(@NonNull int size, @NonNull int measureSpec)
static @NonNull int
resolveSizeAndState(
    @NonNull int size,
    @NonNull int measureSpec,
    @NonNull int childMeasuredState
)
@NonNull void
final @NonNull void
saveAttributeDataForStyleable(
    @NonNull Context context,
    @NonNull Array<@NonNull int> styleable,
    @NonNull AttributeSet attrs,
    @NonNull TypedArray t,
    @NonNull int defStyleAttr,
    @NonNull int defStyleRes
)
@NonNull void
@NonNull void
scheduleDrawable(
    @NonNull Drawable who,
    @NonNull Runnable what,
    @NonNull long when
)
@NonNull void
scrollBy(@NonNull int x, @NonNull int y)
@NonNull void
scrollTo(@NonNull int x, @NonNull int y)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setAccessibilityHeading(@NonNull boolean isHeading)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setActivated(@NonNull boolean activated)
@NonNull void
setAlpha(@NonNull float alpha)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void

This method is deprecated.

@NonNull void
@NonNull void
@NonNull void
@NonNull void
final @NonNull void
setBottom(@NonNull int bottom)
@NonNull void
setCameraDistance(@NonNull float distance)
@NonNull void
setClickable(@NonNull boolean clickable)
@NonNull void
setClipBounds(@NonNull Rect clipBounds)
@NonNull void
setClipToOutline(@NonNull boolean clipToOutline)
@NonNull void
setContentCaptureSession(
    @NonNull ContentCaptureSession contentCaptureSession
)
@NonNull void
@NonNull void
setContextClickable(@NonNull boolean contextClickable)
@NonNull void
setDefaultFocusHighlightEnabled(
    @NonNull boolean defaultFocusHighlightEnabled
)
@NonNull void

This method is deprecated.

@NonNull void
setDrawingCacheEnabled(@NonNull boolean enabled)

This method is deprecated.

@NonNull void

This method is deprecated.

@NonNull void
@NonNull void
setElevation(@NonNull float elevation)
@NonNull void
setEnabled(@NonNull boolean enabled)
@NonNull void
@NonNull void
@NonNull void
setFitsSystemWindows(@NonNull boolean fitSystemWindows)
@NonNull void
setFocusable(@NonNull boolean focusable)
@NonNull void
setFocusableInTouchMode(@NonNull boolean focusableInTouchMode)
@NonNull void
setFocusedByDefault(@NonNull boolean isFocusedByDefault)
@NonNull void
setForceDarkAllowed(@NonNull boolean allow)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setHapticFeedbackEnabled(@NonNull boolean hapticFeedbackEnabled)
@NonNull void
setHasTransientState(@NonNull boolean hasTransientState)
@NonNull void
setHorizontalFadingEdgeEnabled(
    @NonNull boolean horizontalFadingEdgeEnabled
)
@NonNull void
setHorizontalScrollBarEnabled(
    @NonNull boolean horizontalScrollBarEnabled
)
@NonNull void
@NonNull void
@NonNull void
setHovered(@NonNull boolean hovered)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setKeepScreenOn(@NonNull boolean keepScreenOn)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setLayerType(@NonNull int layerType, @NonNull Paint paint)
@NonNull void
setLayoutDirection(@NonNull int layoutDirection)
@NonNull void
final @NonNull void
setLeft(@NonNull int left)
final @NonNull void
setLeftTopRightBottom(
    @NonNull int left,
    @NonNull int top,
    @NonNull int right,
    @NonNull int bottom
)
@NonNull void
setLongClickable(@NonNull boolean longClickable)
@NonNull void
setMinimumHeight(@NonNull int minHeight)
@NonNull void
setMinimumWidth(@NonNull int minWidth)
@NonNull void
@NonNull void
setNextClusterForwardId(@NonNull int nextClusterForwardId)
@NonNull void
setNextFocusDownId(@NonNull int nextFocusDownId)
@NonNull void
setNextFocusForwardId(@NonNull int nextFocusForwardId)
@NonNull void
setNextFocusLeftId(@NonNull int nextFocusLeftId)
@NonNull void
setNextFocusRightId(@NonNull int nextFocusRightId)
@NonNull void
setNextFocusUpId(@NonNull int nextFocusUpId)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void

This method is deprecated.

@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setOverScrollMode(@NonNull int overScrollMode)
@NonNull void
setPadding(
    @NonNull int left,
    @NonNull int top,
    @NonNull int right,
    @NonNull int bottom
)
@NonNull void
setPaddingRelative(
    @NonNull int start,
    @NonNull int top,
    @NonNull int end,
    @NonNull int bottom
)
@NonNull void
setPivotX(@NonNull float pivotX)
@NonNull void
setPivotY(@NonNull float pivotY)
@NonNull void
@NonNull void
setPressed(@NonNull boolean pressed)
final @NonNull void
setRevealOnFocusHint(@NonNull boolean revealOnFocus)
final @NonNull void
setRight(@NonNull int right)
@NonNull void
setRotation(@NonNull float rotation)
@NonNull void
setRotationX(@NonNull float rotationX)
@NonNull void
setRotationY(@NonNull float rotationY)
@NonNull void
setSaveEnabled(@NonNull boolean enabled)
@NonNull void
@NonNull void
setScaleX(@NonNull float scaleX)
@NonNull void
setScaleY(@NonNull float scaleY)
@NonNull void
setScreenReaderFocusable(@NonNull boolean screenReaderFocusable)
@NonNull void
setScrollBarDefaultDelayBeforeFade(
    @NonNull int scrollBarDefaultDelayBeforeFade
)
@NonNull void
setScrollBarFadeDuration(@NonNull int scrollBarFadeDuration)
@NonNull void
setScrollBarSize(@NonNull int scrollBarSize)
@NonNull void
@NonNull void
setScrollContainer(@NonNull boolean isScrollContainer)
@NonNull void
setScrollIndicators(@NonNull int indicators)
@NonNull void
setScrollX(@NonNull int value)
@NonNull void
setScrollY(@NonNull int value)
@NonNull void
setScrollbarFadingEnabled(@NonNull boolean fadeScrollbars)
@NonNull void
setSelected(@NonNull boolean selected)
@NonNull void
setSoundEffectsEnabled(@NonNull boolean soundEffectsEnabled)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setSystemUiVisibility(@NonNull int visibility)

This method is deprecated.

@NonNull void
@NonNull void
setTextAlignment(@NonNull int textAlignment)
@NonNull void
setTextDirection(@NonNull int textDirection)
@NonNull void
final @NonNull void
setTop(@NonNull int top)
@NonNull void
@NonNull void
final @NonNull void
setTransitionName(@NonNull String transitionName)
@NonNull void
@NonNull void
setTranslationX(@NonNull float translationX)
@NonNull void
setTranslationY(@NonNull float translationY)
@NonNull void
setTranslationZ(@NonNull float translationZ)
@NonNull void
setVerticalFadingEdgeEnabled(@NonNull boolean verticalFadingEdgeEnabled)
@NonNull void
setVerticalScrollBarEnabled(@NonNull boolean verticalScrollBarEnabled)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setVisibility(@NonNull int visibility)
@NonNull void
setWillNotCacheDrawing(@NonNull boolean willNotCacheDrawing)

This method is deprecated.

@NonNull void
setWillNotDraw(@NonNull boolean willNotDraw)
@NonNull void
setX(@NonNull float x)
@NonNull void
setY(@NonNull float y)
@NonNull void
setZ(@NonNull float z)
@NonNull boolean
@NonNull ActionMode
@NonNull void
final @NonNull boolean
startDrag(
    @NonNull ClipData data,
    @NonNull View.DragShadowBuilder shadowBuilder,
    @NonNull Object myLocalState,
    @NonNull int flags
)

This method is deprecated.

final @NonNull boolean
startDragAndDrop(
    @NonNull ClipData data,
    @NonNull View.DragShadowBuilder shadowBuilder,
    @NonNull Object myLocalState,
    @NonNull int flags
)
@NonNull boolean
@NonNull void
@NonNull String
@NonNull void
@NonNull void
@NonNull void
final @NonNull void
@NonNull boolean

This method is deprecated.

@NonNull boolean
From class ViewGroup
@NonNull void
@NonNull void
addExtraDataToAccessibilityNodeInfo(
    @NonNull AccessibilityNodeInfo info,
    @NonNull String extraDataKey,
    @NonNull Bundle arguments
)
@NonNull void
addFocusables(
    @NonNull ArrayList<@NonNull View> views,
    @NonNull int direction,
    @NonNull int focusableMode
)
@NonNull void
addKeyboardNavigationClusters(
    @NonNull Collection<@NonNull View> views,
    @NonNull int direction
)
@NonNull boolean
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
childHasTransientStateChanged(
    @NonNull View child,
    @NonNull boolean childHasTransientState
)
@NonNull void
@NonNull void
@NonNull void
@NonNull WindowInsets
@NonNull boolean
@NonNull void
@NonNull void
@NonNull boolean
@NonNull void
@NonNull void
@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull void
@NonNull void
dispatchProvideAutofillStructure(
    @NonNull ViewStructure structure,
    @NonNull int flags
)
@NonNull void
@NonNull void
dispatchSetActivated(@NonNull boolean activated)
@NonNull void
dispatchSetSelected(@NonNull boolean selected)
@NonNull void
@NonNull void

This method is deprecated.

@NonNull boolean
@NonNull boolean
@NonNull boolean
dispatchUnhandledMove(@NonNull View focused, @NonNull int direction)
@NonNull void
@NonNull void
@NonNull void
@NonNull WindowInsets
@NonNull WindowInsetsAnimation.Bounds
@NonNull void

This method is deprecated.

@NonNull void
@NonNull void
@NonNull View
@NonNull void
findViewsWithText(
    @NonNull ArrayList<@NonNull View> outViews,
    @NonNull CharSequence text,
    @NonNull int flags
)
@NonNull View
focusSearch(@NonNull View focused, @NonNull int direction)
@NonNull void
@NonNull boolean
@NonNull CharSequence
@NonNull View
getChildAt(@NonNull int index)
@NonNull int
static @NonNull int
getChildMeasureSpec(
    @NonNull int spec,
    @NonNull int padding,
    @NonNull int childDimension
)
@NonNull boolean
getChildVisibleRect(
    @NonNull View child,
    @NonNull Rect r,
    @NonNull Point offset
)
@NonNull boolean
@NonNull boolean
@NonNull int
@NonNull View
@NonNull LayoutAnimationController
@NonNull Animation.AnimationListener
@NonNull int
@NonNull LayoutTransition
@NonNull int
@NonNull ViewGroupOverlay
@NonNull int

This method is deprecated.

@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull int
final @NonNull void

This method is deprecated.

@NonNull ViewParent
invalidateChildInParent(
    @NonNull Array<@NonNull int> location,
    @NonNull Rect dirty
)

This method is deprecated.

@NonNull boolean

This method is deprecated.

@NonNull boolean

This method is deprecated.

@NonNull boolean
@NonNull boolean
@NonNull boolean
@NonNull void
final @NonNull void
layout(@NonNull int l, @NonNull int t, @NonNull int r, @NonNull int b)
@NonNull void
notifySubtreeAccessibilityStateChanged(
    @NonNull View child,
    @NonNull View source,
    @NonNull int changeType
)
final @NonNull void
offsetDescendantRectToMyCoords(
    @NonNull View descendant,
    @NonNull Rect rect
)
final @NonNull void
offsetRectIntoDescendantCoords(
    @NonNull View descendant,
    @NonNull Rect rect
)
@NonNull void
@NonNull boolean
@NonNull boolean
@NonNull boolean
onNestedFling(
    @NonNull View target,
    @NonNull float velocityX,
    @NonNull float velocityY,
    @NonNull boolean consumed
)
@NonNull boolean
onNestedPreFling(
    @NonNull View target,
    @NonNull float velocityX,
    @NonNull float velocityY
)
@NonNull boolean
onNestedPrePerformAccessibilityAction(
    @NonNull View target,
    @NonNull int action,
    @NonNull Bundle args
)
@NonNull void
onNestedPreScroll(
    @NonNull View target,
    @NonNull int dx,
    @NonNull int dy,
    @NonNull Array<@NonNull int> consumed
)
@NonNull void
onNestedScroll(
    @NonNull View target,
    @NonNull int dxConsumed,
    @NonNull int dyConsumed,
    @NonNull int dxUnconsumed,
    @NonNull int dyUnconsumed
)
@NonNull void
onNestedScrollAccepted(
    @NonNull View child,
    @NonNull View target,
    @NonNull int axes
)
@NonNull boolean
@NonNull PointerIcon
onResolvePointerIcon(@NonNull MotionEvent event, @NonNull int pointerIndex)
@NonNull boolean
onStartNestedScroll(
    @NonNull View child,
    @NonNull View target,
    @NonNull int nestedScrollAxes
)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
@NonNull void
removeViewAt(@NonNull int index)
@NonNull void
@NonNull void
removeViews(@NonNull int start, @NonNull int count)
@NonNull void
removeViewsInLayout(@NonNull int start, @NonNull int count)
@NonNull void
@NonNull boolean
requestChildRectangleOnScreen(
    @NonNull View child,
    @NonNull Rect rectangle,
    @NonNull boolean immediate
)
@NonNull void
requestDisallowInterceptTouchEvent(@NonNull boolean disallowIntercept)
@NonNull boolean
requestFocus(@NonNull int direction, @NonNull Rect previouslyFocusedRect)
@NonNull boolean
@NonNull void
@NonNull boolean
@NonNull void
@NonNull void
setAddStatesFromChildren(@NonNull boolean addsStates)
@NonNull void

This method is deprecated.

@NonNull void

This method is deprecated.

@NonNull void
setClipChildren(@NonNull boolean clipChildren)
@NonNull void
setClipToPadding(@NonNull boolean clipToPadding)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setLayoutMode(@NonNull int layoutMode)
@NonNull void
@NonNull void
@NonNull void
@NonNull void
setPersistentDrawingCache(@NonNull int drawingCacheToKeep)

This method is deprecated.

@NonNull void
setTouchscreenBlocksFocus(@NonNull boolean touchscreenBlocksFocus)
@NonNull void
setTransitionGroup(@NonNull boolean isTransitionGroup)
@NonNull void
@NonNull boolean
@NonNull ActionMode
startActionModeForChild(
    @NonNull View originalView,
    @NonNull ActionMode.Callback callback
)
@NonNull void
@NonNull void
@NonNull void
suppressLayout(@NonNull boolean suppress)
@NonNull void

Constants

DESIGN_INFO_ID

@NonNull
public static final @NonNull int DESIGN_INFO_ID

VERSION

@NonNull
public static final @NonNull String VERSION

Public constructors

ConstraintLayout

public ConstraintLayout(@NonNull Context context)

ConstraintLayout

public ConstraintLayout(@NonNull Context context, @Nullable AttributeSet attrs)

ConstraintLayout

public ConstraintLayout(
    @NonNull Context context,
    @Nullable AttributeSet attrs,
    @NonNull int defStyleAttr
)

ConstraintLayout

@TargetApi(value = Build.VERSION_CODES.LOLLIPOP)
public ConstraintLayout(
    @NonNull Context context,
    @Nullable AttributeSet attrs,
    @NonNull int defStyleAttr,
    @NonNull int defStyleRes
)

Public methods

fillMetrics

@NonNull
public void fillMetrics(@NonNull Metrics metrics)
Parameters
@NonNull Metrics metrics

forceLayout

@Override
@NonNull
public @Override void forceLayout()

getDesignInformation

@NonNull
public Object getDesignInformation(@NonNull int type, @NonNull Object value)

getMaxHeight

@NonNull
public int getMaxHeight()

The maximum height of this view.

Returns
int

The maximum height of this view

See also
setMaxHeight

#setMaxHeight(int)

getMaxWidth

@NonNull
public int getMaxWidth()

getMinHeight

@NonNull
public int getMinHeight()

The minimum height of this view.

Returns
int

The minimum height of this view

See also
setMinHeight

#setMinHeight(int)

getMinWidth

@NonNull
public int getMinWidth()

The minimum width of this view.

Returns
int

The minimum width of this view

See also
setMinWidth

#setMinWidth(int)

getOptimizationLevel

@NonNull
public int getOptimizationLevel()

Return the current optimization level for the layout resolution

Returns
int

the current level

getSharedValues

@NonNull
public static SharedValues getSharedValues()

Returns the SharedValues instance, creating it if it doesn't exist.

Returns
SharedValues

the SharedValues instance

getViewById

@NonNull
public View getViewById(@NonNull int id)
Parameters
@NonNull int id

the view id

Returns
View

the child view, can return null

getViewWidget

@NonNull
public final ConstraintWidget getViewWidget(@NonNull View view)
Parameters
@NonNull View view

loadLayoutDescription

@NonNull
public void loadLayoutDescription(@NonNull int layoutDescription)

Load a layout description file from the resources.

Parameters
@NonNull int layoutDescription

The resource id, or 0 to reset the layout description.

onViewAdded

@Override
@NonNull
public @Override void onViewAdded(@NonNull View view)

onViewRemoved

@Override
@NonNull
public @Override void onViewRemoved(@NonNull View view)

requestLayout

@Override
@NonNull
public @Override void requestLayout()

setConstraintSet

@NonNull
public void setConstraintSet(@NonNull ConstraintSet set)

Sets a ConstraintSet object to manage constraints. The ConstraintSet overrides LayoutParams of child views.

Parameters
@NonNull ConstraintSet set

Layout children using ConstraintSet

setDesignInformation

@NonNull
public void setDesignInformation(
    @NonNull int type,
    @NonNull Object value1,
    @NonNull Object value2
)

setId

@Override
@NonNull
public @Override void setId(@NonNull int id)

setMaxHeight

@NonNull
public void setMaxHeight(@NonNull int value)

Set the max height for this view

Parameters
@NonNull int value

setMaxWidth

@NonNull
public void setMaxWidth(@NonNull int value)

Set the max width for this view

Parameters
@NonNull int value

setMinHeight

@NonNull
public void setMinHeight(@NonNull int value)

Set the min height for this view

Parameters
@NonNull int value

setMinWidth

@NonNull
public void setMinWidth(@NonNull int value)

Set the min width for this view

Parameters
@NonNull int value

setOnConstraintsChanged

@NonNull
public void setOnConstraintsChanged(
    @NonNull ConstraintsChangedListener constraintsChangedListener
)

setOptimizationLevel

@NonNull
public void setOptimizationLevel(@NonNull int level)

Set the optimization for the layout resolution.

The optimization can be any of the following:

  • Optimizer.OPTIMIZATION_NONE
  • Optimizer.OPTIMIZATION_STANDARD
  • a mask composed of specific optimizations
The mask can be composed of any combination of the following:
  • Optimizer.OPTIMIZATION_DIRECT
  • Optimizer.OPTIMIZATION_BARRIER
  • Optimizer.OPTIMIZATION_CHAIN (experimental)
  • Optimizer.OPTIMIZATION_DIMENSIONS (experimental)
Note that the current implementation of Optimizer.OPTIMIZATION_STANDARD is as a mask of DIRECT and BARRIER.
Parameters
@NonNull int level

optimization level

setState

@NonNull
public void setState(@NonNull int id, @NonNull int screenWidth, @NonNull int screenHeight)

Set the State of the ConstraintLayout, causing it to load a particular ConstraintSet. For states with variants the variant with matching width and height constraintSet will be chosen

Parameters
@NonNull int id

the constraint set state

@NonNull int screenWidth

the width of the screen in pixels

@NonNull int screenHeight

the height of the screen in pixels

shouldDelayChildPressedState

@Override
@NonNull
public @Override boolean shouldDelayChildPressedState()
Returns
@Override boolean