2018-02-26 14:27:32 +01:00
|
|
|
/* Copyright (C) 2015-2018 Andreas Shimokawa, Carsten Pfeiffer
|
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;
|
|
|
|
|
|
|
|
import android.os.Bundle;
|
2019-01-26 15:52:40 +01:00
|
|
|
|
|
|
|
import androidx.fragment.app.FragmentManager;
|
|
|
|
import androidx.fragment.app.FragmentPagerAdapter;
|
|
|
|
import androidx.fragment.app.FragmentStatePagerAdapter;
|
|
|
|
import androidx.viewpager.widget.PagerAdapter;
|
2015-08-25 00:33:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A base activity that supports paging through fragments by swiping.
|
|
|
|
* Subclasses will have to add a ViewPager to their layout and add something
|
|
|
|
* like this to hook it to the fragments:
|
2015-09-24 14:45:21 +02:00
|
|
|
* <p/>
|
2015-08-25 00:33:37 +02:00
|
|
|
* <pre>
|
|
|
|
* // Set up the ViewPager with the sections adapter.
|
|
|
|
* ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
|
|
|
|
* viewPager.setAdapter(getPagerAdapter());
|
|
|
|
* </pre>
|
|
|
|
*
|
|
|
|
* @see AbstractGBFragment
|
|
|
|
*/
|
2017-09-03 01:02:31 +02:00
|
|
|
public abstract class AbstractGBFragmentActivity extends AbstractGBActivity {
|
2015-08-25 00:33:37 +02:00
|
|
|
/**
|
2019-01-26 15:52:40 +01:00
|
|
|
* The {@link PagerAdapter} that will provide
|
2015-08-25 00:33:37 +02:00
|
|
|
* fragments for each of the sections. We use a
|
|
|
|
* {@link FragmentPagerAdapter} derivative, which will keep every
|
|
|
|
* loaded fragment in memory. If this becomes too memory intensive, it
|
|
|
|
* may be best to switch to a
|
2019-01-26 15:52:40 +01:00
|
|
|
* {@link FragmentStatePagerAdapter}.
|
2015-08-25 00:33:37 +02:00
|
|
|
*/
|
|
|
|
private AbstractFragmentPagerAdapter mSectionsPagerAdapter;
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void onCreate(Bundle savedInstanceState) {
|
|
|
|
super.onCreate(savedInstanceState);
|
|
|
|
|
|
|
|
// Create the adapter that will return a fragment for each of the three
|
|
|
|
// primary sections of the activity.
|
|
|
|
mSectionsPagerAdapter = createFragmentPagerAdapter(getSupportFragmentManager());
|
|
|
|
}
|
|
|
|
|
|
|
|
public AbstractFragmentPagerAdapter getPagerAdapter() {
|
|
|
|
return mSectionsPagerAdapter;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a PagerAdapter that will create the fragments to be used with this
|
|
|
|
* activity. The fragments should typically extend AbstractGBFragment
|
2015-09-24 14:45:21 +02:00
|
|
|
*
|
2015-08-25 00:33:37 +02:00
|
|
|
* @param fragmentManager
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
protected abstract AbstractFragmentPagerAdapter createFragmentPagerAdapter(FragmentManager fragmentManager);
|
|
|
|
}
|