高仿京东2020版首页效果2

代码 代码 1156 人阅读 | 0 人回复

<
本篇结果图:
GitHub:https://github.com/baiyuliang/JdRefresh
150244f3o7vwjyjdj7del0.jpg

上一篇:下仿京东2020版尾页规划及革新结果,缺陷是用了NestedScrollView嵌套了ViewPager,结果能够完成,但实践使用中体验仿佛依旧有面好的,缘故原由能够检察该篇专客尾部分析。
初版得规划规划图:
150245dmrrm6ndfkkak0gg.jpg

开初考虑到TabLayout战RecyclerView(ViewPager中)能够一同滑动,以是很随便念到的法子便是用Scrollview将二者嵌套出来,结果是完成了,可是Scrollview嵌套Viewpager的短处不言而喻!
而第两版即本篇专客并非为了解决Scrollview嵌套Viewpager的成绩,而是换一种思绪来完成!
规划规划图,很简朴,便两层:
150245bzpunnqf10nluzf7.jpg

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3.     android:layout_width="match_parent"
  4.     android:layout_height="match_parent"
  5.     android:background="#f7f7f7"
  6.     android:focusable="true"
  7.     android:focusableInTouchMode="true">
  8.     <LinearLayout
  9.         android:id="@+id/ll_content"
  10.         android:layout_width="match_parent"
  11.         android:layout_height="wrap_content"
  12.         android:orientation="vertical">
  13.         <net.lucode.hackware.magicindicator.MagicIndicator
  14.             android:id="@+id/magicIndicator"
  15.             android:layout_width="match_parent"
  16.             android:layout_height="35dp"
  17.             android:background="#acddee"
  18.             android:visibility="gone" />
  19.         <com.byl.jdrefresh.v1.CustomViewPager
  20.             android:id="@+id/customViewPager"
  21.             android:layout_width="match_parent"
  22.             android:layout_height="match_parent" />
  23.     </LinearLayout>
  24.     <RelativeLayout 搜刮栏.../>
  25. </RelativeLayout>
复造代码
而初版中的第一层战第两层(自界说JdScrollVIew)放正在了Tab1的fragment中:
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3.     android:layout_width="match_parent"
  4.     android:layout_height="match_parent"
  5.     android:orientation="vertical">
  6.     <com.byl.jdrefresh.v2.JdScrollView2
  7.         android:id="@+id/jdScrollView"
  8.         android:layout_width="match_parent"
  9.         android:layout_height="match_parent" />
  10. </LinearLayout>
复造代码
JdScrollVIew规划 仅需求将本来规划中的ViewPager换成RecyclerView便可,详细可参考源码!
但如许做仿佛并出有处理TabLayout战列表一同滑动的结果啊?!
实在,那里与了一个巧,MainActivity中的有一个TabLayout,而tab1也便是尾页中的Fragment也包罗了一个一摸一样的TabLayout(NestedScrollview嵌套TabLayout+RecyclerView),当viewpager的position==0时,MainActivity中的TabLayout躲藏,别的页里时显现,一切的结果操纵由MainActivity转移到了Tab1Fragment中,如许也便制止了利用ScrollView嵌套Viewpager这类形式!
  1. <span class="token tag">    <span class="token tag">    <span class="token tag">    <span class="token tag">        <span class="token tag">        <span class="token tag">        <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3.     android:layout_width="match_parent"
  4.     android:layout_height="match_parent"
  5.     android:orientation="vertical">
  6.     <com.byl.jdrefresh.v2.JdScrollView2
  7.         android:id="@+id/jdScrollView"
  8.         android:layout_width="match_parent"
  9.         android:layout_height="match_parent" />
  10. </LinearLayout>
复造代码
此外,本篇再本来的根底上多减了一个功用,能够参考京东app,即下推超出必然间隔后,布景会主动背下齐屏睁开,然后主动进进到告白页里:
150246bl0mvdssaaxdmzeq.jpg

完成计划,便是正在脚势抬起(ACTION_UP)时,判定当前下推的间隔,超出某一设定值时,则主动正在必然工夫内乱让图片及团体规划处于齐屏形态,实在便是依托ValueAnimator,不竭的设置布景图的marginTop和内乱容的paddingTop:
  1.     case MotionEvent.ACTION_UP:
  2.                 if (adScrollDistance > 500) {
  3.                     isInterceptTouch = true;
  4.                     AnimUtils.start(-(int) (marginTop + adScrollDistance), 500, new AnimUtils.OnAnimListener() {
  5.                         @Override
  6.                         public void onUpdate(int value) {
  7.                             layoutAd(marginTop + adScrollDistance + value);
  8.                             ll_content.setPadding(0, (int) (paddingTop + adScrollDistance + AD_START_SCROLL_DISTANCE) + value, 0, 0);
  9.                         }
  10.                         @Override
  11.                         public void onEnd() {
  12.                             context.startActivity(new Intent(context, AdActivity.class));
  13.                             new Handler().postDelayed(() -> {
  14.                                 tv_refresh_state.setText("下推革新");
  15.                                 isInterceptTouch = false;
  16.                                 recyclerView.setRefreshing(false);
  17.                                 isInterceptScroll = false;
  18.                                 REFRESH_STATUS = REFRESH_DONE;
  19.                                 layoutAd(marginTop);
  20.                                 iv_ad.setImageAlpha(0);
  21.                                 if (onPullListener != null) onPullListener.onPull(255);
  22.                                 ll_content.setPadding(0, paddingTop, 0, 0);
  23.                                 reset();
  24.                             }, 300);
  25.                         }
  26.                     });
  27.                     return true;
  28.                 }
  29.                 ......
复造代码
有一面需求留意的是,图片的下度,并非屏幕下度,而是屏幕的下度+
150246mupru0dbrpdbfdtb.jpg

那一部分的下度:
  1. screenHeight = SysUtils.getScreenHeight(context);
  2. topRemainHeight = SysUtils.Dp2Px(context, imageShowHeight) - StatusBarUtil.getStatusBarHeight(context) - SysUtils.Dp2Px(context, 40);//40是搜刮栏下度,是几便写几
  3. RelativeLayout.LayoutParams layoutParams = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.MATCH_PARENT, screenHeight + topRemainHeight);
  4. marginTop = -(screenHeight + topRemainHeight - SysUtils.Dp2Px(context, imageShowHeight));
  5. layoutParams.topMargin = marginTop;
  6. iv_ad.setLayoutParams(layoutParams);
复造代码
如许做的缘故原由是,假设只把布景图设为屏幕下度,则布景图经由过程不竭设置marginTop曲至为0完整睁开时,白框部分(地点内乱容区团体不竭设置paddingTop)会恰好卡正在底部,其实不会完整躲藏失落,缘故原由实在很简朴,如图:
150246ukytphhnntt7hpan.jpg

图片抵达底部时,因为白框取图片底部是持仄的,以是恰好漏正在了里面,因而,需求便需求上里所道的办法,将图片下度正在屏幕下度根底上再+白框部分下度,如许图片齐屏时,全部屏幕内乱容便只要图片显现了!
GitHub:https://github.com/baiyuliang/JdRefresh

免责声明:假如进犯了您的权益,请联络站少,我们会实时删除侵权内乱容,感谢协作!
1、本网站属于个人的非赢利性网站,转载的文章遵循原作者的版权声明,如果原文没有版权声明,按照目前互联网开放的原则,我们将在不通知作者的情况下,转载文章;如果原文明确注明“禁止转载”,我们一定不会转载。如果我们转载的文章不符合作者的版权声明或者作者不想让我们转载您的文章的话,请发帖留言提供原创证明,我们将积极配合您!
2、本网站转载文章仅为传播更多信息之目的,凡在本网站出现的信息,均仅供参考。本网站将尽力确保所提供信息的准确性及可靠性,但不保证信息的正确性和完整性,且不对因信息的不正确或遗漏导致的任何损失或损害承担责任。
3、任何透过本网站网页而链接及得到的资讯、产品及服务,本网站概不负责,亦不负任何法律责任。
4、本网站所刊发、转载的文章,其版权均归原作者所有,如其他媒体、网站或个人从本网下载使用,请在转载有关文章时务必尊重该文章的著作权,保留本网注明的“稿件来源”,并自负版权等法律责任。
回复

使用道具 举报

 
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则