日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

自定义behavior-仿华为应用市场

發布時間:2025/3/17 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 自定义behavior-仿华为应用市场 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Behavior 配合 CoordinatorLayout 可以實現很多酷炫的交互,掌握自定義 Behavior 也是很大的提升 。先看看要實現的效果如下:

上面這個效果是「華為應用市場」的首頁效果。使用 RecycleView(ListView)也是可以實現的。不過需要對滑動事件的處理相對較多。如果使用自定義 behavior 就不需要那么復雜了。

自定義 behavior 有兩種

  • 一個 view 依賴另外一個 view。(A 依賴于 B ,B 的狀態發生變化,A 也發生變化)
  • 一個view 監聽 CoordinateLayout 中嵌套子 View 的滑動狀態。
  • 觀察上面的效果可以很明顯的發現: 搜索框和 導航欄都是跟隨 Banner 的滑動做出相應變化。這里我們使用第一種方法來完成。(自定義搜索框可以查看源碼)

    先看看布局:

    <android.support.design.widget.CoordinatorLayoutxmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"android:layout_width="match_parent"android:layout_height="match_parent"android:fitsSystemWindows="true"><android.support.design.widget.AppBarLayoutandroid:id="@+id/appbar"android:background="@android:color/transparent"android:layout_width="match_parent"android:layout_height="wrap_content"android:fitsSystemWindows="true"><android.support.design.widget.CollapsingToolbarLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:fitsSystemWindows="true"app:layout_scrollFlags="scroll|exitUntilCollapsed"><com.bigkoo.convenientbanner.ConvenientBannerandroid:id="@+id/convenientBanner"android:layout_width="match_parent"android:layout_height="@dimen/bannner_height"app:canLoop="true"app:layout_collapseMode="pin" /><android.support.v7.widget.Toolbarandroid:id="@+id/toolbar"android:layout_width="match_parent"android:layout_height="50dp"android:minHeight="?attr/actionBarSize"app:contentInsetStart="0dp"app:layout_collapseMode="pin"><TextViewandroid:id="@+id/tab"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@color/white"android:gravity="center"android:text="@string/market_title"android:textSize="20sp" /></android.support.v7.widget.Toolbar></android.support.design.widget.CollapsingToolbarLayout></android.support.design.widget.AppBarLayout><android.support.v4.widget.NestedScrollViewandroid:id="@+id/net"android:layout_width="match_parent"android:layout_height="match_parent"app:layout_behavior="@string/appbar_scrolling_view_behavior"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical"><TextViewandroid:layout_width="match_parent"android:layout_height="@dimen/item_height"android:background="@drawable/sp_itembg_one"android:gravity="center"android:text="Item1"android:textColor="@color/white"android:textSize="32sp" /><TextViewandroid:layout_width="match_parent"android:layout_height="@dimen/item_height"android:background="@drawable/sp_itembg_two"android:gravity="center"android:text="Item2"android:textColor="@color/white"android:textSize="32sp" /><TextViewandroid:layout_width="match_parent"android:layout_height="@dimen/item_height"android:background="@drawable/sp_itembg_three"android:gravity="center"android:text="Item3"android:textColor="@color/white"android:textSize="32sp" /><TextViewandroid:layout_width="match_parent"android:layout_height="@dimen/item_height"android:background="@drawable/sp_itembg_four"android:gravity="center"android:text="Item4"android:textColor="@color/white"android:textSize="32sp" /><TextViewandroid:layout_width="match_parent"android:layout_height="@dimen/item_height"android:background="@drawable/sp_itembg_five"android:gravity="center"android:text="Item5"android:textColor="@color/white"android:textSize="32sp" /></LinearLayout></android.support.v4.widget.NestedScrollView><com.ruomiz.coordinatorheader.SearchBarandroid:id="@+id/searchBar"android:layout_width="match_parent"android:layout_height="30dp"android:layout_gravity="top"android:layout_marginBottom="5dp"android:layout_marginTop="160dp"android:paddingLeft="20dp"android:paddingRight="20dp"app:layout_behavior="@string/scrollingBehavior"/></android.support.design.widget.CoordinatorLayout> 復制代碼

    先實現搜索框跟隨 banner 位移效果的 自定義Behavior(代碼很簡單)

    //需要重寫有兩個參數的構造函數 public MarketScrollingBehavior(Context context, AttributeSet attrs) {super(context, attrs); }@Override public boolean layoutDependsOn(CoordinatorLayout parent, SearchBar child, View dependency) {return dependency != null && dependency instanceof AppBarLayout; }@Override public boolean onDependentViewChanged(CoordinatorLayout parent, SearchBar child, View dependency) {float y = dependency.getY(); int totalScrollRange = ((AppBarLayout) dependency).getTotalScrollRange();//獲取 AppBarLayout的高度if (Math.abs(y) < totalScrollRange * 0.6) { if (child.getCurrentState() == SearchBar.State.OPEN) { //當searchBar處于展開狀態child.setTranslationY(y); } else if (child.getCurrentState() == SearchBar.State.EXPANDING){ //當searchBar展開和收縮的過程中child.setTranslationY(y);}}return true;} 復制代碼

    監聽 AppBarLayout 的位移,導航欄跟隨 banner 滑動 顏色漸變,搜索框也隨之展開或收縮。

    mAppBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {@Overridepublic void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {if (verticalOffset == 0) {mTab.setTextColor(Color.argb(255, 255, 255, 255)); mTab.setBackgroundColor(Color.argb(0, 255, 255, 255)); } else if (Math.abs(verticalOffset) >= appBarLayout.getTotalScrollRange()) {mTab.setTextColor(Color.argb(255, 0, 0, 0));mTab.setBackgroundColor(Color.argb(255, 255, 255, 255));} else {float percent = (Math.abs(verticalOffset) * 100 / appBarLayout.getTotalScrollRange()) * 0.01f;int alpha = (int) Math.floor(percent * 255); // 顏色的透明通道 255為不透明 if (Math.abs(verticalOffset) * 4 > appBarLayout.getTotalScrollRange()) {mTab.setTextColor(Color.argb(alpha, 0, 0, 0)); //Tab 字體顏色漸變} else {mTab.setTextColor(Color.argb(255 - alpha * 4, 255, 255, 255));}mTab.setBackgroundColor(Color.argb(alpha, 255, 255, 255)); //Tab 背景逐漸透明if (Math.abs(verticalOffset) > appBarLayout.getTotalScrollRange() * 0.6) {if (mSearchBar.getCurrentState() == SearchBar.State.OPEN) {mSearchBar.closeAnimation(); //搜索框收縮動畫}} else {if (mSearchBar.getCurrentState() == SearchBar.State.CLOSED) {mSearchBar.startAnimation(); //搜索框展開動畫}}}} }); 復制代碼

    最后實現的效果如下:

    具體請查看源碼

    總結

    以上是生活随笔為你收集整理的自定义behavior-仿华为应用市场的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 一本一道波多野结衣av黑人 | 我和公激情中文字幕 | 成人免费视频国产免费麻豆 | 色婷婷午夜 | 亚洲一二三在线 | 亚洲伦理天堂 | 久久人人添人人爽添人人片 | 国产在线aaa | 国产裸体永久免费无遮挡 | 免播放器在线视频 | 超碰超碰在线 | 欧美日韩高清一区 | 中国黄色三级视频 | 朝桐光一区二区三区 | 玖草视频在线观看 | 久久艹这里只有精品 | 性爱动漫 | 欧美日韩一区精品 | 日皮视频在线观看 | 乱色精品无码一区二区国产盗 | 婷婷激情社区 | 精品麻豆av | 秋霞国产午夜精品免费视频 | 日本www色视频| 精品乱码久久久久久中文字幕 | 日韩在线视频观看免费 | 中文字幕av高清片 | 青草视频在线观看免费 | 亚洲欧美一区二区三区孕妇 | 久久人人爽人人爽人人片av免费 | 五个女闺蜜把我玩到尿失禁 | 久久精品一日日躁夜夜躁 | 久久噜| 粉嫩av网站 | 久久久青草 | 久久综合桃花网 | 日韩三级国产精品 | 91视频免费在线观看 | 国产又粗又猛视频 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 国产毛片av | 亚色成人 | 一区二区三区精品国产 | 久操精品 | 欧日韩视频 | 午夜视频福利网站 | www免费网站在线观看 | www.av网 | 1000亚洲裸体人体 | 五月婷在线 | 日韩欧美国产一区二区三区在线观看 | 四虎国产在线观看 | 粗喘呻吟撞击猛烈疯狂 | 一区二区三区美女视频 | 亚洲视频一区二区三区四区 | 性高湖久久久久久久久免费 | 高清一区二区三区四区 | 97超碰超碰 | 精品日韩中文字幕 | 91亚洲国产成人精品一区二三 | 一道本一区二区 | 日本成人黄色片 | 欧美日韩一区二区在线视频 | 完全免费在线视频 | 激情丁香| 中文字幕色站 | 五月天国产精品 | 少妇性l交大片免潘金莲 | 日韩一级片免费 | 激情六月综合 | 亚洲视频在线播放 | 三级视频黄色 | 黄色av网站在线观看 | 在线播放成人av | 国产精品亚洲一区二区三区 | 亚洲精品一区二区三区婷婷月 | 狐狸视频污| 亚洲人xxxx| 亚洲自拍偷拍欧美 | 久久久精品综合 | 亚洲小说区图片区都市 | 毛片看| 亚洲第一中文字幕 | 荫蒂被男人添免费视频 | 色噜噜一区二区三区 | 俺也去网站 | 插插综合视频 | 小泽玛利亚一区二区三区视频 | 欧美又大粗又爽又黄大片视频 | 亚洲欧洲一级 | 无套白嫩进入乌克兰美女 | 香蕉视频官网 | 西方av在线 | www黄色大片 | 国产亚洲精品电影 | 日韩欧美成人免费视频 | 天堂色av | 一区自拍| 浮力影院国产第一页 |