Slider: Android可以滑动页面的项目
Slider 说明
1.基于SwipeBackLayout和Slidr开源项目进行功能的扩展补充
2.让任何页面通过简单的实现SliderUi接口即可拥有滑动功能
使用方法
1.目前支持activity与fragment页面滑动
2.通过如下简单操作,即可让页面具备滑动功能。
public class SampleActivity extends Activity implements SliderUi { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_slider); SliderUtils.attachUi(this, null) } @Override public Activity getUiActivity() { return this; } @Override public boolean isActivityUi() { return true; } @Override public boolean isFinishingUi() { return isFinishing(); } @Override public void finishUi() { finish(); } @Override public View getRootView() { return getWindow().getDecorView(); } }
亦或通过简单的继承:
public class ExtendsActivity extends SliderActivity { }
或者是直接通过SliderUtils类加入也可以达到想要的滑动效果。
SliderUtils.attachActivity(this, null);
需要注意的是activity在manifest下配置theme需复写android:windowIsTranslucent,否则拉开的背景会全黑。
<style name="ActivityTheme" parent="Theme.AppCompat.Light.DarkActionBar"> <item name="android:windowIsTranslucent">true</item> </style>
如果设备版本大于android 5.0,也可以如下代码。在低于5.0版本下如何能在代码中修改,目前没有深入,所以在此也希望大家能共同完善!
SliderUtils.attachUi(this, null); Utils.convertActivityToTranslucent activity)
关于fragment实现滑动功能,也基本可以通过类似的方式进行。而fragment不受android:windowIsTranslucent的影响。
public class SampleFragment extends Fragment implements SliderUi { private ISlider iSlider; private View rootView; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { rootView = inflater.inflate(R.layout.fragment_sample, container, false); iSlider = SliderUtils.attachUi(this, null); return iSlider.getSliderView(); } @Override public Activity getUiActivity() { return getActivity(); } @Override public boolean isActivityUi() { return false; } @Override public boolean isFinishingUi() { return isRemoving(); } @Override public void finishUi() { getUiActivity().getFragmentManager().beginTransaction().remove(this).commit(); } @Override public View getRootView() { return rootView; } }
或者通过继承,需要注意的是:在SliderFragment中onCreateView由于已经被final覆写了,所以要实现另一个抽象方法 creatingView并返回当前layout的inflate对象。
public class ExtendsFragment extends SliderFragment { @Override public View creatingView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { return inflater.inflate(R.layout.fragment_entends, container, false); } }
最简单的当然是直接把当前fragment传入SliderUtils.attachFragment(Fragment fragment, SliderConfig config,View rootView) 来实现:
public class AdapterFragment extends Fragment{ private ISlider iSlider; private View rootView; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // Inflate the layout for this fragment rootView=inflater.inflate(R.layout.fragment_adapter, container, false); iSlider = SliderUtils.attachFragment(this, null,rootView); return iSlider.getSliderView(); }
SliderConfig
如果你想改变Slider的一些属性,可以在任何地方通过iSlider来设置或者在初始化的时候传入.
iSlider.setConfig(mConfig);
ISlider
ISlider是在SliderUtils.attach*方法返回的接口对象,通过该接口可以操作或者获得Slider对象。
使用项目
在项目的build.gradle文件中添加库依赖
dependencies{ compile 'com.komi.slider:slider:0.1.0' }
Pull Requests 与 Issues
欢迎大家发现问题与共同维护该项目,喜欢就Star吧,后面会扩展更多实用功能