commonMain.androidx.constraintlayout.core.state.ConstraintReference.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of compose-constraint-layout-jvm Show documentation
Show all versions of compose-constraint-layout-jvm Show documentation
A copy of Android's ConstraintLayout (v2.1.3 core and v1.0.0 compose) with multiplatform capability.
/*
* Copyright (C) 2019 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package androidx.constraintlayout.core.state
import androidx.constraintlayout.core.motion.utils.TypedValues
import androidx.constraintlayout.core.state.helpers.Facade
import androidx.constraintlayout.core.widgets.ConstraintAnchor
import androidx.constraintlayout.core.widgets.ConstraintWidget
open class ConstraintReference(open val mState: State) : Reference {
override var key: Any? = null
interface ConstraintReferenceFactory {
fun create(state: State?): ConstraintReference?
}
var tag: String? = null
var mFacade: Facade? = null
var horizontalChainStyle = ConstraintWidget.CHAIN_SPREAD
var mVerticalChainStyle = ConstraintWidget.CHAIN_SPREAD
var horizontalChainWeight = ConstraintWidget.UNKNOWN.toFloat()
var verticalChainWeight = ConstraintWidget.UNKNOWN.toFloat()
var mHorizontalBias = 0.5f
var mVerticalBias = 0.5f
protected var mMarginLeft = 0
protected var mMarginRight = 0
protected var mMarginStart = 0
protected var mMarginEnd = 0
var mMarginTop = 0
var mMarginBottom = 0
var mMarginLeftGone = 0
var mMarginRightGone = 0
var mMarginStartGone = 0
var mMarginEndGone = 0
var mMarginTopGone = 0
var mMarginBottomGone = 0
var mMarginBaseline = 0
var mMarginBaselineGone = 0
var pivotX = Float.NaN
var pivotY = Float.NaN
var rotationX = Float.NaN
var rotationY = Float.NaN
var rotationZ = Float.NaN
var translationX = Float.NaN
var translationY = Float.NaN
var translationZ = Float.NaN
var alpha = Float.NaN
var scaleX = Float.NaN
var scaleY = Float.NaN
var mVisibility = ConstraintWidget.VISIBLE
protected var mLeftToLeft: Any? = null
protected var mLeftToRight: Any? = null
protected var mRightToLeft: Any? = null
protected var mRightToRight: Any? = null
protected var mStartToStart: Any? = null
protected var mStartToEnd: Any? = null
protected var mEndToStart: Any? = null
protected var mEndToEnd: Any? = null
protected var mTopToTop: Any? = null
protected var mTopToBottom: Any? = null
protected var mBottomToTop: Any? = null
protected var mBottomToBottom: Any? = null
var mBaselineToBaseline: Any? = null
var mBaselineToTop: Any? = null
var mBaselineToBottom: Any? = null
var mCircularConstraint: Any? = null
private var mCircularAngle = 0f
private var mCircularDistance = 0f
var mLast: State.Constraint? = null
var width = Dimension.Fixed(Dimension.WRAP_DIMENSION)
var height = Dimension.Fixed(Dimension.WRAP_DIMENSION)
private var mView: Any? = null
private var mConstraintWidget: ConstraintWidget? = null
private val mCustomColors: HashMap? = HashMap()
private var mCustomFloats: HashMap? = HashMap()
var view: Any?
get() = mView
set(view) {
mView = view
if (mConstraintWidget != null) {
mConstraintWidget!!.companionWidget = mView
}
}
override var facade: Facade?
get() = mFacade
set(facade) {
mFacade = facade
if (facade != null) {
constraintWidget = facade.constraintWidget
}
}
override var constraintWidget: ConstraintWidget?
get() {
if (mConstraintWidget == null) {
mConstraintWidget = createConstraintWidget()
mConstraintWidget!!.companionWidget = mView
}
return mConstraintWidget
}
set(widget) {
if (widget == null) {
return
}
mConstraintWidget = widget
mConstraintWidget!!.companionWidget = mView
}
fun createConstraintWidget(): ConstraintWidget {
return ConstraintWidget(
width.value,
height.value
)
}
internal class IncorrectConstraintException(val errors: ArrayList) : Exception() {
override fun toString(): String {
return "IncorrectConstraintException: $errors"
}
}
/**
* Validate the constraints
*/
@Throws(IncorrectConstraintException::class)
fun validate() {
val errors = ArrayList()
if (mLeftToLeft != null && mLeftToRight != null) {
errors.add("LeftToLeft and LeftToRight both defined")
}
if (mRightToLeft != null && mRightToRight != null) {
errors.add("RightToLeft and RightToRight both defined")
}
if (mStartToStart != null && mStartToEnd != null) {
errors.add("StartToStart and StartToEnd both defined")
}
if (mEndToStart != null && mEndToEnd != null) {
errors.add("EndToStart and EndToEnd both defined")
}
if ((mLeftToLeft != null || mLeftToRight != null || mRightToLeft != null || mRightToRight != null)
&& (mStartToStart != null || mStartToEnd != null || mEndToStart != null || mEndToEnd != null)
) {
errors.add("Both left/right and start/end constraints defined")
}
if (errors.size > 0) {
throw IncorrectConstraintException(errors)
}
}
private operator fun get(reference: Any?): Any? {
return if (reference == null) {
null
} else reference as? ConstraintReference ?: mState.reference(reference)
}
fun setVerticalChainStyle(chainStyle: Int) {
mVerticalChainStyle = chainStyle
}
fun getVerticalChainStyle(chainStyle: Int): Int {
return mVerticalChainStyle
}
fun clearVertical(): ConstraintReference {
top().clear()
baseline().clear()
bottom().clear()
return this
}
fun clearHorizontal(): ConstraintReference {
start().clear()
end().clear()
left().clear()
right().clear()
return this
}
fun pivotX(x: Float): ConstraintReference {
pivotX = x
return this
}
fun pivotY(y: Float): ConstraintReference {
pivotY = y
return this
}
fun rotationX(x: Float): ConstraintReference {
rotationX = x
return this
}
fun rotationY(y: Float): ConstraintReference {
rotationY = y
return this
}
fun rotationZ(z: Float): ConstraintReference {
rotationZ = z
return this
}
fun translationX(x: Float): ConstraintReference {
translationX = x
return this
}
fun translationY(y: Float): ConstraintReference {
translationY = y
return this
}
fun translationZ(z: Float): ConstraintReference {
translationZ = z
return this
}
fun scaleX(x: Float): ConstraintReference {
scaleX = x
return this
}
fun scaleY(y: Float): ConstraintReference {
scaleY = y
return this
}
fun alpha(alpha: Float): ConstraintReference {
this.alpha = alpha
return this
}
fun visibility(visibility: Int): ConstraintReference {
mVisibility = visibility
return this
}
fun left(): ConstraintReference {
mLast = if (mLeftToLeft != null) {
State.Constraint.LEFT_TO_LEFT
} else {
State.Constraint.LEFT_TO_RIGHT
}
return this
}
fun right(): ConstraintReference {
mLast = if (mRightToLeft != null) {
State.Constraint.RIGHT_TO_LEFT
} else {
State.Constraint.RIGHT_TO_RIGHT
}
return this
}
fun start(): ConstraintReference {
mLast = if (mStartToStart != null) {
State.Constraint.START_TO_START
} else {
State.Constraint.START_TO_END
}
return this
}
fun end(): ConstraintReference {
mLast = if (mEndToStart != null) {
State.Constraint.END_TO_START
} else {
State.Constraint.END_TO_END
}
return this
}
fun top(): ConstraintReference {
mLast = if (mTopToTop != null) {
State.Constraint.TOP_TO_TOP
} else {
State.Constraint.TOP_TO_BOTTOM
}
return this
}
fun bottom(): ConstraintReference {
mLast = if (mBottomToTop != null) {
State.Constraint.BOTTOM_TO_TOP
} else {
State.Constraint.BOTTOM_TO_BOTTOM
}
return this
}
fun baseline(): ConstraintReference {
mLast = State.Constraint.BASELINE_TO_BASELINE
return this
}
fun addCustomColor(name: String, color: Int) {
mCustomColors!![name] = color
}
fun addCustomFloat(name: String, value: Float) {
if (mCustomFloats == null) {
mCustomFloats = HashMap()
}
mCustomFloats!![name] = value
}
private fun dereference() {
mLeftToLeft = get(mLeftToLeft)
mLeftToRight = get(mLeftToRight)
mRightToLeft = get(mRightToLeft)
mRightToRight = get(mRightToRight)
mStartToStart = get(mStartToStart)
mStartToEnd = get(mStartToEnd)
mEndToStart = get(mEndToStart)
mEndToEnd = get(mEndToEnd)
mTopToTop = get(mTopToTop)
mTopToBottom = get(mTopToBottom)
mBottomToTop = get(mBottomToTop)
mBottomToBottom = get(mBottomToBottom)
mBaselineToBaseline = get(mBaselineToBaseline)
mBaselineToTop = get(mBaselineToTop)
mBaselineToBottom = get(mBaselineToBottom)
}
fun leftToLeft(reference: Any?): ConstraintReference {
mLast = State.Constraint.LEFT_TO_LEFT
mLeftToLeft = reference
return this
}
fun leftToRight(reference: Any?): ConstraintReference {
mLast = State.Constraint.LEFT_TO_RIGHT
mLeftToRight = reference
return this
}
fun rightToLeft(reference: Any?): ConstraintReference {
mLast = State.Constraint.RIGHT_TO_LEFT
mRightToLeft = reference
return this
}
fun rightToRight(reference: Any?): ConstraintReference {
mLast = State.Constraint.RIGHT_TO_RIGHT
mRightToRight = reference
return this
}
fun startToStart(reference: Any?): ConstraintReference {
mLast = State.Constraint.START_TO_START
mStartToStart = reference
return this
}
fun startToEnd(reference: Any?): ConstraintReference {
mLast = State.Constraint.START_TO_END
mStartToEnd = reference
return this
}
fun endToStart(reference: Any?): ConstraintReference {
mLast = State.Constraint.END_TO_START
mEndToStart = reference
return this
}
fun endToEnd(reference: Any?): ConstraintReference {
mLast = State.Constraint.END_TO_END
mEndToEnd = reference
return this
}
fun topToTop(reference: Any?): ConstraintReference {
mLast = State.Constraint.TOP_TO_TOP
mTopToTop = reference
return this
}
fun topToBottom(reference: Any?): ConstraintReference {
mLast = State.Constraint.TOP_TO_BOTTOM
mTopToBottom = reference
return this
}
fun bottomToTop(reference: Any?): ConstraintReference {
mLast = State.Constraint.BOTTOM_TO_TOP
mBottomToTop = reference
return this
}
fun bottomToBottom(reference: Any?): ConstraintReference {
mLast = State.Constraint.BOTTOM_TO_BOTTOM
mBottomToBottom = reference
return this
}
fun baselineToBaseline(reference: Any?): ConstraintReference {
mLast = State.Constraint.BASELINE_TO_BASELINE
mBaselineToBaseline = reference
return this
}
fun baselineToTop(reference: Any?): ConstraintReference {
mLast = State.Constraint.BASELINE_TO_TOP
mBaselineToTop = reference
return this
}
fun baselineToBottom(reference: Any?): ConstraintReference {
mLast = State.Constraint.BASELINE_TO_BOTTOM
mBaselineToBottom = reference
return this
}
fun centerHorizontally(reference: Any?): ConstraintReference {
val ref = get(reference)
mStartToStart = ref
mEndToEnd = ref
mLast = State.Constraint.CENTER_HORIZONTALLY
mHorizontalBias = 0.5f
return this
}
fun centerVertically(reference: Any?): ConstraintReference {
val ref = get(reference)
mTopToTop = ref
mBottomToBottom = ref
mLast = State.Constraint.CENTER_VERTICALLY
mVerticalBias = 0.5f
return this
}
fun circularConstraint(reference: Any?, angle: Float, distance: Float): ConstraintReference {
val ref = get(reference)
mCircularConstraint = ref
mCircularAngle = angle
mCircularDistance = distance
mLast = State.Constraint.CIRCULAR_CONSTRAINT
return this
}
fun width(dimension: Dimension): ConstraintReference {
return setWidth(dimension)
}
fun height(dimension: Dimension): ConstraintReference {
return setHeight(dimension)
}
fun setWidth(dimension: Dimension): ConstraintReference {
width = dimension
return this
}
fun setHeight(dimension: Dimension): ConstraintReference {
height = dimension
return this
}
open fun margin(marginValue: Any?): ConstraintReference? {
return margin(mState.convertDimension(marginValue))
}
fun marginGone(marginGoneValue: Any?): ConstraintReference {
return marginGone(mState.convertDimension(marginGoneValue))
}
open fun margin(value: Int): ConstraintReference? {
if (mLast != null) {
when (mLast) {
State.Constraint.LEFT_TO_LEFT, State.Constraint.LEFT_TO_RIGHT -> {
mMarginLeft = value
}
State.Constraint.RIGHT_TO_LEFT, State.Constraint.RIGHT_TO_RIGHT -> {
mMarginRight = value
}
State.Constraint.START_TO_START, State.Constraint.START_TO_END -> {
mMarginStart = value
}
State.Constraint.END_TO_START, State.Constraint.END_TO_END -> {
mMarginEnd = value
}
State.Constraint.TOP_TO_TOP, State.Constraint.TOP_TO_BOTTOM -> {
mMarginTop = value
}
State.Constraint.BOTTOM_TO_TOP, State.Constraint.BOTTOM_TO_BOTTOM -> {
mMarginBottom = value
}
State.Constraint.BASELINE_TO_BOTTOM, State.Constraint.BASELINE_TO_TOP, State.Constraint.BASELINE_TO_BASELINE -> {
run { mMarginBaseline = value }
run { mCircularDistance = value.toFloat() }
}
State.Constraint.CIRCULAR_CONSTRAINT -> {
mCircularDistance = value.toFloat()
}
else -> {}
}
} else {
mMarginLeft = value
mMarginRight = value
mMarginStart = value
mMarginEnd = value
mMarginTop = value
mMarginBottom = value
}
return this
}
fun marginGone(value: Int): ConstraintReference {
if (mLast != null) {
when (mLast) {
State.Constraint.LEFT_TO_LEFT, State.Constraint.LEFT_TO_RIGHT -> {
mMarginLeftGone = value
}
State.Constraint.RIGHT_TO_LEFT, State.Constraint.RIGHT_TO_RIGHT -> {
mMarginRightGone = value
}
State.Constraint.START_TO_START, State.Constraint.START_TO_END -> {
mMarginStartGone = value
}
State.Constraint.END_TO_START, State.Constraint.END_TO_END -> {
mMarginEndGone = value
}
State.Constraint.TOP_TO_TOP, State.Constraint.TOP_TO_BOTTOM -> {
mMarginTopGone = value
}
State.Constraint.BOTTOM_TO_TOP, State.Constraint.BOTTOM_TO_BOTTOM -> {
mMarginBottomGone = value
}
State.Constraint.BASELINE_TO_TOP, State.Constraint.BASELINE_TO_BOTTOM, State.Constraint.BASELINE_TO_BASELINE -> {
mMarginBaselineGone = value
}
else -> {}
}
} else {
mMarginLeftGone = value
mMarginRightGone = value
mMarginStartGone = value
mMarginEndGone = value
mMarginTopGone = value
mMarginBottomGone = value
}
return this
}
fun horizontalBias(value: Float): ConstraintReference {
mHorizontalBias = value
return this
}
fun verticalBias(value: Float): ConstraintReference {
mVerticalBias = value
return this
}
open fun bias(value: Float): ConstraintReference? {
if (mLast == null) {
return this
}
when (mLast) {
State.Constraint.CENTER_HORIZONTALLY, State.Constraint.LEFT_TO_LEFT, State.Constraint.LEFT_TO_RIGHT, State.Constraint.RIGHT_TO_LEFT, State.Constraint.RIGHT_TO_RIGHT, State.Constraint.START_TO_START, State.Constraint.START_TO_END, State.Constraint.END_TO_START, State.Constraint.END_TO_END -> {
mHorizontalBias = value
}
State.Constraint.CENTER_VERTICALLY, State.Constraint.TOP_TO_TOP, State.Constraint.TOP_TO_BOTTOM, State.Constraint.BOTTOM_TO_TOP, State.Constraint.BOTTOM_TO_BOTTOM -> {
mVerticalBias = value
}
else -> {}
}
return this
}
fun clear(): ConstraintReference {
if (mLast != null) {
when (mLast) {
State.Constraint.LEFT_TO_LEFT, State.Constraint.LEFT_TO_RIGHT -> {
mLeftToLeft = null
mLeftToRight = null
mMarginLeft = 0
mMarginLeftGone = 0
}
State.Constraint.RIGHT_TO_LEFT, State.Constraint.RIGHT_TO_RIGHT -> {
mRightToLeft = null
mRightToRight = null
mMarginRight = 0
mMarginRightGone = 0
}
State.Constraint.START_TO_START, State.Constraint.START_TO_END -> {
mStartToStart = null
mStartToEnd = null
mMarginStart = 0
mMarginStartGone = 0
}
State.Constraint.END_TO_START, State.Constraint.END_TO_END -> {
mEndToStart = null
mEndToEnd = null
mMarginEnd = 0
mMarginEndGone = 0
}
State.Constraint.TOP_TO_TOP, State.Constraint.TOP_TO_BOTTOM -> {
mTopToTop = null
mTopToBottom = null
mMarginTop = 0
mMarginTopGone = 0
}
State.Constraint.BOTTOM_TO_TOP, State.Constraint.BOTTOM_TO_BOTTOM -> {
mBottomToTop = null
mBottomToBottom = null
mMarginBottom = 0
mMarginBottomGone = 0
}
State.Constraint.BASELINE_TO_BASELINE -> {
mBaselineToBaseline = null
}
State.Constraint.CIRCULAR_CONSTRAINT -> {
mCircularConstraint = null
}
else -> {}
}
} else {
mLeftToLeft = null
mLeftToRight = null
mMarginLeft = 0
mRightToLeft = null
mRightToRight = null
mMarginRight = 0
mStartToStart = null
mStartToEnd = null
mMarginStart = 0
mEndToStart = null
mEndToEnd = null
mMarginEnd = 0
mTopToTop = null
mTopToBottom = null
mMarginTop = 0
mBottomToTop = null
mBottomToBottom = null
mMarginBottom = 0
mBaselineToBaseline = null
mCircularConstraint = null
mHorizontalBias = 0.5f
mVerticalBias = 0.5f
mMarginLeftGone = 0
mMarginRightGone = 0
mMarginStartGone = 0
mMarginEndGone = 0
mMarginTopGone = 0
mMarginBottomGone = 0
}
return this
}
private fun getTarget(target: Any?): ConstraintWidget? {
if (target is Reference) {
return target.constraintWidget
}
return null
}
private fun applyConnection(widget: ConstraintWidget, opaqueTarget: Any?, type: State.Constraint) {
val target = getTarget(opaqueTarget) ?: return
when (type) {
else -> {}
}
when (type) {
State.Constraint.START_TO_START -> {
widget.getAnchor(ConstraintAnchor.Type.LEFT)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.LEFT
), mMarginStart, mMarginStartGone, false
)
}
State.Constraint.START_TO_END -> {
widget.getAnchor(ConstraintAnchor.Type.LEFT)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.RIGHT
), mMarginStart, mMarginStartGone, false
)
}
State.Constraint.END_TO_START -> {
widget.getAnchor(ConstraintAnchor.Type.RIGHT)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.LEFT
), mMarginEnd, mMarginEndGone, false
)
}
State.Constraint.END_TO_END -> {
widget.getAnchor(ConstraintAnchor.Type.RIGHT)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.RIGHT
), mMarginEnd, mMarginEndGone, false
)
}
State.Constraint.LEFT_TO_LEFT -> {
widget.getAnchor(ConstraintAnchor.Type.LEFT)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.LEFT
), mMarginLeft, mMarginLeftGone, false
)
}
State.Constraint.LEFT_TO_RIGHT -> {
widget.getAnchor(ConstraintAnchor.Type.LEFT)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.RIGHT
), mMarginLeft, mMarginLeftGone, false
)
}
State.Constraint.RIGHT_TO_LEFT -> {
widget.getAnchor(ConstraintAnchor.Type.RIGHT)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.LEFT
), mMarginRight, mMarginRightGone, false
)
}
State.Constraint.RIGHT_TO_RIGHT -> {
widget.getAnchor(ConstraintAnchor.Type.RIGHT)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.RIGHT
), mMarginRight, mMarginRightGone, false
)
}
State.Constraint.TOP_TO_TOP -> {
widget.getAnchor(ConstraintAnchor.Type.TOP)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.TOP
), mMarginTop, mMarginTopGone, false
)
}
State.Constraint.TOP_TO_BOTTOM -> {
widget.getAnchor(ConstraintAnchor.Type.TOP)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.BOTTOM
), mMarginTop, mMarginTopGone, false
)
}
State.Constraint.BOTTOM_TO_TOP -> {
widget.getAnchor(ConstraintAnchor.Type.BOTTOM)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.TOP
), mMarginBottom, mMarginBottomGone, false
)
}
State.Constraint.BOTTOM_TO_BOTTOM -> {
widget.getAnchor(ConstraintAnchor.Type.BOTTOM)!!.connect(
target.getAnchor(
ConstraintAnchor.Type.BOTTOM
), mMarginBottom, mMarginBottomGone, false
)
}
State.Constraint.BASELINE_TO_BASELINE -> {
widget.immediateConnect(ConstraintAnchor.Type.BASELINE, target, ConstraintAnchor.Type.BASELINE, mMarginBaseline, mMarginBaselineGone)
}
State.Constraint.BASELINE_TO_TOP -> {
widget.immediateConnect(ConstraintAnchor.Type.BASELINE, target, ConstraintAnchor.Type.TOP, mMarginBaseline, mMarginBaselineGone)
}
State.Constraint.BASELINE_TO_BOTTOM -> {
widget.immediateConnect(ConstraintAnchor.Type.BASELINE, target, ConstraintAnchor.Type.BOTTOM, mMarginBaseline, mMarginBaselineGone)
}
State.Constraint.CIRCULAR_CONSTRAINT -> {
widget.connectCircularConstraint(target, mCircularAngle, mCircularDistance.toInt())
}
else -> {}
}
}
override fun apply() {
if (mConstraintWidget == null) {
return
}
if (mFacade != null) {
mFacade!!.apply()
}
width.apply(mState, mConstraintWidget!!, ConstraintWidget.HORIZONTAL)
height.apply(mState, mConstraintWidget!!, ConstraintWidget.VERTICAL)
dereference()
applyConnection(mConstraintWidget!!, mLeftToLeft, State.Constraint.LEFT_TO_LEFT)
applyConnection(mConstraintWidget!!, mLeftToRight, State.Constraint.LEFT_TO_RIGHT)
applyConnection(mConstraintWidget!!, mRightToLeft, State.Constraint.RIGHT_TO_LEFT)
applyConnection(mConstraintWidget!!, mRightToRight, State.Constraint.RIGHT_TO_RIGHT)
applyConnection(mConstraintWidget!!, mStartToStart, State.Constraint.START_TO_START)
applyConnection(mConstraintWidget!!, mStartToEnd, State.Constraint.START_TO_END)
applyConnection(mConstraintWidget!!, mEndToStart, State.Constraint.END_TO_START)
applyConnection(mConstraintWidget!!, mEndToEnd, State.Constraint.END_TO_END)
applyConnection(mConstraintWidget!!, mTopToTop, State.Constraint.TOP_TO_TOP)
applyConnection(mConstraintWidget!!, mTopToBottom, State.Constraint.TOP_TO_BOTTOM)
applyConnection(mConstraintWidget!!, mBottomToTop, State.Constraint.BOTTOM_TO_TOP)
applyConnection(mConstraintWidget!!, mBottomToBottom, State.Constraint.BOTTOM_TO_BOTTOM)
applyConnection(mConstraintWidget!!, mBaselineToBaseline, State.Constraint.BASELINE_TO_BASELINE)
applyConnection(mConstraintWidget!!, mBaselineToTop, State.Constraint.BASELINE_TO_TOP)
applyConnection(mConstraintWidget!!, mBaselineToBottom, State.Constraint.BASELINE_TO_BOTTOM)
applyConnection(mConstraintWidget!!, mCircularConstraint, State.Constraint.CIRCULAR_CONSTRAINT)
if (horizontalChainStyle != ConstraintWidget.CHAIN_SPREAD) {
mConstraintWidget!!.horizontalChainStyle = horizontalChainStyle
}
if (mVerticalChainStyle != ConstraintWidget.CHAIN_SPREAD) {
mConstraintWidget!!.verticalChainStyle = mVerticalChainStyle
}
if (horizontalChainWeight != ConstraintWidget.UNKNOWN.toFloat()) {
mConstraintWidget!!.setHorizontalWeight(horizontalChainWeight)
}
if (verticalChainWeight != ConstraintWidget.UNKNOWN.toFloat()) {
mConstraintWidget!!.setVerticalWeight(verticalChainWeight)
}
mConstraintWidget!!.horizontalBiasPercent = mHorizontalBias
mConstraintWidget!!.verticalBiasPercent = mVerticalBias
mConstraintWidget!!.frame.pivotX = pivotX
mConstraintWidget!!.frame.pivotY = pivotY
mConstraintWidget!!.frame.rotationX = rotationX
mConstraintWidget!!.frame.rotationY = rotationY
mConstraintWidget!!.frame.rotationZ = rotationZ
mConstraintWidget!!.frame.translationX = translationX
mConstraintWidget!!.frame.translationY = translationY
mConstraintWidget!!.frame.translationZ = translationZ
mConstraintWidget!!.frame.scaleX = scaleX
mConstraintWidget!!.frame.scaleY = scaleY
mConstraintWidget!!.frame.alpha = alpha
mConstraintWidget!!.frame.visibility = mVisibility
mConstraintWidget!!.visibility = mVisibility
if (mCustomColors != null) {
for (key in mCustomColors.keys) {
val color = mCustomColors[key]
mConstraintWidget!!.frame.setCustomAttribute(key, TypedValues.Custom.TYPE_COLOR, color!!)
}
}
if (mCustomFloats != null) {
for (key in mCustomFloats!!.keys) {
val value = mCustomFloats!![key]!!
mConstraintWidget!!.frame.setCustomAttribute(key, TypedValues.Custom.TYPE_FLOAT, value)
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy