SetupWizardLibrary/library/main/src/com/android/setupwizardlib/view/BottomScrollView.java
Aurimas Liutikas 4860e4ee48 Migrate setup-wizard-lib to androidx.
Test: make setup-wizard-lib
Bug: 76692459
Change-Id: I40171e973d442b1a1815e9e7d7c2cc984cb38bac
2018-04-18 17:26:19 -07:00

105 lines
3.2 KiB
Java

/*
* Copyright (C) 2015 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 com.android.setupwizardlib.view;
import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
import android.widget.ScrollView;
import androidx.annotation.VisibleForTesting;
/**
* An extension of ScrollView that will invoke a listener callback when the ScrollView needs
* scrolling, and when the ScrollView is being scrolled to the bottom. This is often used in Setup
* Wizard as a way to ensure that users see all the content before proceeding.
*/
public class BottomScrollView extends ScrollView {
public interface BottomScrollListener {
void onScrolledToBottom();
void onRequiresScroll();
}
private BottomScrollListener mListener;
private int mScrollThreshold;
private boolean mRequiringScroll = false;
private final Runnable mCheckScrollRunnable = new Runnable() {
@Override
public void run() {
checkScroll();
}
};
public BottomScrollView(Context context) {
super(context);
}
public BottomScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public BottomScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
public void setBottomScrollListener(BottomScrollListener l) {
mListener = l;
}
@VisibleForTesting
public int getScrollThreshold() {
return mScrollThreshold;
}
@Override
protected void onLayout(boolean changed, int l, int t, int r, int b) {
super.onLayout(changed, l, t, r, b);
final View child = getChildAt(0);
if (child != null) {
mScrollThreshold = Math.max(0, child.getMeasuredHeight() - b + t - getPaddingBottom());
}
if (b - t > 0) {
// Post check scroll in the next run loop, so that the callback methods will be invoked
// after the layout pass. This way a new layout pass will be scheduled if view
// properties are changed in the callbacks.
post(mCheckScrollRunnable);
}
}
@Override
protected void onScrollChanged(int l, int t, int oldl, int oldt) {
super.onScrollChanged(l, t, oldl, oldt);
if (oldt != t) {
checkScroll();
}
}
private void checkScroll() {
if (mListener != null) {
if (getScrollY() >= mScrollThreshold) {
mListener.onScrolledToBottom();
} else if (!mRequiringScroll) {
mRequiringScroll = true;
mListener.onRequiresScroll();
}
}
}
}