全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android仿简书动态searchview搜索栏效果

简书的动态搜索栏效果是这样的,挺高大上的感觉。


ezgif.com-resize.gif

仔细想一下,其实实现起来非常简单,这是我做的效果,基本完美还原。


ezgif.com-resize (2).gif

实现这个效果, 只要关注几个点

1.搜索栏伸展和收缩动画效果实现
2.搜索栏伸展和收缩的时机
3.顶部透明度的渐变

搜索栏伸展和收缩动画效果实现:

我们只要明确,使用系统为我们提供的Transition框架,就可以轻而易举的实现了。
首先要引入依赖compile 'com.android.support:design:25.3.1',要知道我们使用到的这部分Transition效果只是封装了属性动画的内容,是可以兼容到5.0之前的。

private void expand() {
 //设置伸展状态时的布局
 tvSearch.setText("搜索简书的内容和朋友");
 RelativeLayout.LayoutParams LayoutParams = (RelativeLayout.LayoutParams) mSearchLayout.getLayoutParams();
 LayoutParams.width = LayoutParams.MATCH_PARENT;
 LayoutParams.setMargins(dip2px(10), dip2px(10), dip2px(10), dip2px(10));
 mSearchLayout.setLayoutParams(LayoutParams);
 //设置动画
 beginDelayedTransition(mSearchLayout);
 }

 private void reduce() {
 //设置收缩状态时的布局
 tvSearch.setText("搜索");
 RelativeLayout.LayoutParams LayoutParams = (RelativeLayout.LayoutParams) mSearchLayout.getLayoutParams();
 LayoutParams.width = dip2px(80);
 LayoutParams.setMargins(dip2px(10), dip2px(10), dip2px(10), dip2px(10));
 mSearchLayout.setLayoutParams(LayoutParams);
 //设置动画
 beginDelayedTransition(mSearchLayout);
 }

 void beginDelayedTransition(ViewGroup view) {
 mSet = new AutoTransition();
 //设置动画持续时间
 mSet.setDuration(300);
 // 开始表演
 TransitionManager.beginDelayedTransition(view, mSet);
 }

其中mSearchLayout就是搜索框的布局,只需要动态设置一下伸展和收缩的布局大小和其中显示的文字,剩下的就交给Transition吧~ 这样搜索框就可以来回摇摆了。。

搜索栏伸展和收缩的时机:

观察一下效果,伸展的时机是当顶部完全盖住banner的时候开始的,收缩的时机是滚动到顶部的时候触发。需要我们监听scllerview的滚动状态。这里的顶部我是用了自定义布局的toolbar,然后用一个imageview代替了banner。

//scrollview滚动状态监听
 mScrollView.getViewTreeObserver().addOnScrollChangedListener(new ViewTreeObserver.OnScrollChangedListener() {
  @Override
  public void onScrollChanged() {
  //改变toolbar的透明度
  changeToolbarAlpha();
  //滚动距离>=大图高度-toolbar高度 即toolbar完全盖住大图的时候 且不是伸展状态 进行伸展操作
  if (mScrollView.getScrollY() >=ivImg.getHeight() - toolbar.getHeight() && !isExpand) {
   expand();
   isExpand = true;
  }
  //滚动距离<=0时 即滚动到顶部时 且当前伸展状态 进行收缩操作
  else if (mScrollView.getScrollY()<=0&& isExpand) {
   reduce();
   isExpand = false;
  }
  }
 });
 }

当然简书的整个布局是基于recyclerview的,这里我为了方便使用了scrollerview。recyclerview也只需监听相应的滚动状态即可。

顶部透明度的渐变

直接上代码

 private void changeToolbarAlpha() {
 int scrollY = mScrollView.getScrollY();
 //快速下拉会引起瞬间scrollY<0
 if(scrollY<0){
  toolbar.getBackground().mutate().setAlpha(0);
  return;
 }
 //计算当前透明度比率
 float radio= Math.min(1,scrollY/(ivImg.getHeight()-toolbar.getHeight()*1f));
 //设置透明度
 toolbar.getBackground().mutate().setAlpha( (int)(radio * 0xFF));
 }

注意刚才监听滚动事件的时候调用changeToolbarAlpha()方法,并且需要初始设置为全透明
toolbar.getBackground().mutate().setAlpha(0);

好了关键代码就这么多点了~

下面附上完整代码

布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:background="#c2c0c0"
 >
 <ScrollView
 android:id="@+id/scrollView"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:scrollbars="none">
 <FrameLayout
  android:layout_width="match_parent"
  android:layout_height="wrap_content">

  <FrameLayout
  android:layout_width="match_parent"
  android:layout_height="1500dp">

  <ImageView
   android:id="@+id/iv_img"
   android:layout_width="match_parent"
   android:layout_height="180dp"
   android:scaleType="centerCrop"
   android:src="@drawable/night1" />
  </FrameLayout>
 </FrameLayout>
 </ScrollView>
 <android.support.v7.widget.Toolbar
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:id="@+id/toolbar"
 android:background="@android:color/white"
 android:fitsSystemWindows="true">
 <RelativeLayout
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  >
  <LinearLayout
  android:id="@+id/ll_search"
  android:layout_width="80dp"
  android:layout_height="30dp"
  android:layout_alignParentRight="true"
  android:layout_marginRight="10dp"
  android:layout_marginTop="10dp"
  android:layout_marginBottom="10dp"
  android:background="@drawable/shape_bg"
  android:gravity="center">

  <TextView
   android:id="@+id/tv_search"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:drawableLeft="@drawable/search"
   android:gravity="center_vertical"
   android:text="搜索"
   android:textColor="#8A8A8A" />
  </LinearLayout>
 </RelativeLayout>
 </android.support.v7.widget.Toolbar>
</RelativeLayout>

就一个activity

public class MainActivity extends AppCompatActivity {
 @Bind(R.id.tv_search)
 TextView tvSearch;
 @Bind(R.id.ll_search)
 LinearLayout mSearchLayout;
 @Bind(R.id.scrollView)
 ScrollView mScrollView;
 boolean isExpand = false;
 @Bind(R.id.iv_img)
 ImageView ivImg;
 @Bind(R.id.toolbar)
 Toolbar toolbar;
 private TransitionSet mSet;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 ButterKnife.bind(this);
 //设置全屏透明状态栏
 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
  getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
  ViewGroup rootView = (ViewGroup) ((ViewGroup)findViewById(android.R.id.content)).getChildAt(0);
  ViewCompat.setFitsSystemWindows(rootView,false);
  rootView.setClipToPadding(true);
 }
 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
 getWindow().clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS|
   WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
 getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN| View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
 getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);

  getWindow().setStatusBarColor(Color.TRANSPARENT);
 }
 //设置toolbar初始透明度为0
 toolbar.getBackground().mutate().setAlpha(0);
 //scrollview滚动状态监听
 mScrollView.getViewTreeObserver().addOnScrollChangedListener(new ViewTreeObserver.OnScrollChangedListener() {
  @Override
  public void onScrollChanged() {
  //改变toolbar的透明度
  changeToolbarAlpha();
  //滚动距离>=大图高度-toolbar高度 即toolbar完全盖住大图的时候 且不是伸展状态 进行伸展操作
  if (mScrollView.getScrollY() >=ivImg.getHeight() - toolbar.getHeight() && !isExpand) {
   expand();
   isExpand = true;
  }
  //滚动距离<=0时 即滚动到顶部时 且当前伸展状态 进行收缩操作
  else if (mScrollView.getScrollY()<=0&& isExpand) {
   reduce();
   isExpand = false;
  }
  }
 });
 }

 private void changeToolbarAlpha() {
 int scrollY = mScrollView.getScrollY();
 //快速下拉会引起瞬间scrollY<0
 if(scrollY<0){
  toolbar.getBackground().mutate().setAlpha(0);
  return;
 }
 //计算当前透明度比率
 float radio= Math.min(1,scrollY/(ivImg.getHeight()-toolbar.getHeight()*1f));
 //设置透明度
 toolbar.getBackground().mutate().setAlpha( (int)(radio * 0xFF));
 }


 private void expand() {
 //设置伸展状态时的布局
 tvSearch.setText("搜索简书的内容和朋友");
 RelativeLayout.LayoutParams LayoutParams = (RelativeLayout.LayoutParams) mSearchLayout.getLayoutParams();
 LayoutParams.width = LayoutParams.MATCH_PARENT;
 LayoutParams.setMargins(dip2px(10), dip2px(10), dip2px(10), dip2px(10));
 mSearchLayout.setLayoutParams(LayoutParams);
 //开始动画
 beginDelayedTransition(mSearchLayout);
 }

 private void reduce() {
 //设置收缩状态时的布局
 tvSearch.setText("搜索");
 RelativeLayout.LayoutParams LayoutParams = (RelativeLayout.LayoutParams) mSearchLayout.getLayoutParams();
 LayoutParams.width = dip2px(80);
 LayoutParams.setMargins(dip2px(10), dip2px(10), dip2px(10), dip2px(10));
 mSearchLayout.setLayoutParams(LayoutParams);
 //开始动画
 beginDelayedTransition(mSearchLayout);
 }

 void beginDelayedTransition(ViewGroup view) {
 mSet = new AutoTransition();
 mSet.setDuration(300);
 TransitionManager.beginDelayedTransition(view, mSet);
 }

 private int dip2px(float dpVale) {
 final float scale = getResources().getDisplayMetrics().density;
 return (int) (dpVale * scale + 0.5f);
 }
}

更完整的在这里https://github.com/yanyiqun001/dymicSearchview 希望大家多多支持

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Android  # 搜索栏  # searchview  # Android Studio搜索功能(查找功能)及快捷键图文详解  # Android实现搜索功能并本地保存搜索历史记录  # Android自定义View实现搜索框(SearchView)功能  # Android百度地图实现搜索和定位及自定义图标绘制并点击时弹出泡泡  # Android搜索框SearchView属性和用法详解  # Android SearchView搜索框组件的使用方法  # Android遍历所有文件夹和子目录搜索文件  # Android搜索框组件SearchView的基本使用方法  # Android ListView用EditText实现搜索功能效果  # Android实现简单动态搜索功能  # 大家多多  # 这是  # 我是  # 瞬间  # 几个  # 在这里  # 好了  # 是这样  # 这么多  # 只需  # 这部  # 点了  # 用了  # 要知道  # 自定义  # 我做  # 只需要  # 设置为  # 轻而易举  # 全屏 


相关文章: 定制建站价位费用解析与套餐推荐全攻略  如何通过西部建站助手安装IIS服务器?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  清除minerd进程的简单方法  如何通过商城自助建站源码实现零基础高效建站?  5种Android数据存储方式汇总  阿里云网站制作公司,阿里云快速搭建网站好用吗?  开封网站制作公司,网络用语开封是什么意思?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  建站之星上传入口如何快速找到?  建站之星如何快速更换网站模板?  定制建站哪家更专业可靠?推荐榜单揭晓  建站主机数据库如何配置才能提升网站性能?  想学网站制作怎么学,建立一个网站要花费多少?  制作网站的过程怎么写,用凡科建站如何制作自己的网站?  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  专业商城网站制作公司有哪些,pi商城官网是哪个?  大连网站制作公司哪家好一点,大连买房网站哪个好?  全景视频制作网站有哪些,全景图怎么做成网页?  如何批量查询域名的建站时间记录?  网站制作报价单模板图片,小松挖机官方网站报价?  建站之星如何实现网站加密操作?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  建站OpenVZ教程与优化策略:配置指南与性能提升  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  如何在IIS服务器上快速部署高效网站?  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  如何在Golang中指定模块版本_使用go.mod控制版本号  网站设计制作企业有哪些,抖音官网主页怎么设置?  如何通过万网虚拟主机快速搭建网站?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何在阿里云虚拟服务器快速搭建网站?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  建站主机选择指南:服务器配置与SEO优化实战技巧  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  网站按钮制作软件,如何实现网页中按钮的自动点击?  html制作网站的步骤有哪些,iapp如何添加网页?  建站之星代理如何优化在线客服效率?  c# await 一个已经完成的Task会发生什么  如何选择PHP开源工具快速搭建网站?  安徽网站建设与外贸建站服务专业定制方案  建站之星后台密码如何安全设置与找回?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  企业微网站怎么做,公司网站和公众号有什么区别?  如何选择建站程序?包含哪些必备功能与类型?  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  简单实现Android文件上传  官网自助建站平台指南:在线制作、快速建站与模板选择全解析 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。