2019-02-13 20:43:30 +01:00
|
|
|
/* Copyright (C) 2015-2019 Andreas Shimokawa, Carsten Pfeiffer, Daniele
|
2017-04-26 00:14:25 +02:00
|
|
|
Gobbetti, walkjivefly
|
2017-03-10 14:53:19 +01:00
|
|
|
|
|
|
|
This file is part of Gadgetbridge.
|
|
|
|
|
|
|
|
Gadgetbridge is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as published
|
|
|
|
by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
Gadgetbridge is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
2015-08-25 00:33:37 +02:00
|
|
|
package nodomain.freeyourgadget.gadgetbridge.activities;
|
|
|
|
|
2019-01-26 15:52:40 +01:00
|
|
|
import androidx.annotation.Nullable;
|
|
|
|
import androidx.fragment.app.Fragment;
|
2015-08-25 00:33:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Abstract base class for fragments. Provides hooks that are called when
|
|
|
|
* the fragment is made visible and invisible in the activity. also allows
|
|
|
|
* the fragment to define the title to be shown in the activity.
|
2015-09-24 14:45:21 +02:00
|
|
|
*
|
2015-08-25 00:33:37 +02:00
|
|
|
* @see AbstractGBFragmentActivity
|
|
|
|
*/
|
|
|
|
public abstract class AbstractGBFragment extends Fragment {
|
2017-04-01 11:54:21 +02:00
|
|
|
private boolean mVisibleInActivity;
|
2015-08-25 00:33:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when this fragment has been fully scrolled into the activity.
|
|
|
|
*
|
|
|
|
* @see #isVisibleInActivity()
|
|
|
|
* @see #onMadeInvisibleInActivity()
|
|
|
|
*/
|
|
|
|
protected void onMadeVisibleInActivity() {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when this fragment has been scrolled out of the activity.
|
2015-09-24 14:45:21 +02:00
|
|
|
*
|
2015-08-25 00:33:37 +02:00
|
|
|
* @see #isVisibleInActivity()
|
|
|
|
* @see #onMadeVisibleInActivity()
|
|
|
|
*/
|
|
|
|
protected void onMadeInvisibleInActivity() {
|
2017-04-01 11:54:21 +02:00
|
|
|
mVisibleInActivity = false;
|
2015-08-25 00:33:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if this fragment is currently visible in the hosting
|
|
|
|
* activity, not taking into account whether the screen is enabled at all.
|
|
|
|
*/
|
|
|
|
public boolean isVisibleInActivity() {
|
2017-04-01 11:54:21 +02:00
|
|
|
return mVisibleInActivity;
|
2015-08-25 00:33:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Nullable
|
|
|
|
protected abstract CharSequence getTitle();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Internal
|
2015-09-24 14:45:21 +02:00
|
|
|
*
|
2015-08-25 00:33:37 +02:00
|
|
|
* @hide
|
|
|
|
*/
|
|
|
|
public void onMadeVisibleInActivityInternal() {
|
2017-04-01 11:54:21 +02:00
|
|
|
mVisibleInActivity = true;
|
2015-08-25 00:33:37 +02:00
|
|
|
if (isVisible()) {
|
|
|
|
onMadeVisibleInActivity();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|