Files
app_Settings/src/com/android/settings/datausage/MeasurableLinearLayout.java
Sunny Shao 076ed573eb Revert^2 "Nullability Annotations replacement"
This reverts commit 19d1d3d15d.

Reason for revert: revert it because this is not the root cause.

bug: 316867690
Change-Id: I0f168dbb64044aa720202af7b1040afd4f028c9c
2024-01-10 07:34:01 +00:00

48 lines
1.6 KiB
Java

package com.android.settings.datausage;
import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
import android.widget.LinearLayout;
import androidx.annotation.Nullable;
public class MeasurableLinearLayout extends LinearLayout {
private View mFixedView;
private View mDisposableView;
public MeasurableLinearLayout(Context context) {
super(context, null);
}
public MeasurableLinearLayout(Context context, @Nullable AttributeSet attrs) {
super(context, attrs, 0);
}
public MeasurableLinearLayout(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr, 0);
}
public MeasurableLinearLayout(Context context, AttributeSet attrs,
int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
if (mDisposableView != null && getMeasuredWidth() - mFixedView.getMeasuredWidth()
< mDisposableView.getMeasuredWidth()) {
mDisposableView.setVisibility(GONE);
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
} else if (mDisposableView != null && mDisposableView.getVisibility() != VISIBLE) {
mDisposableView.setVisibility(VISIBLE);
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
}
}
public void setChildren(View fixedView, View disposableView) {
mFixedView = fixedView;
mDisposableView = disposableView;
}
}