电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Android實現(xiàn)京東首頁效果

瀏覽:202日期:2022-06-04 11:46:20

本文實例為大家分享了Android實現(xiàn)京東首頁效果的具體代碼,供大家參考,具體內(nèi)容如下

1.效果圖:

Android實現(xiàn)京東首頁效果

2.布局

源碼鏈接

<?xml version='1.0' encoding='utf-8'?><com.scwang.smart.refresh.layout.SmartRefreshLayout xmlns:android='http://schemas.android.com/apk/res/android' xmlns:app='http://schemas.android.com/apk/res-auto' android: android:layout_width='match_parent' android:layout_height='match_parent' android:background='@color/background_color' app:srlDisableContentWhenRefresh='true' app:srlEnableOverScrollBounce='false' app:srlHeaderMaxDragRate='2' app:srlPrimaryColor='@color/theme_color'> <RelativeLayoutandroid:layout_width='match_parent'android:layout_height='match_parent'> <androidx.coordinatorlayout.widget.CoordinatorLayout android:layout_width='match_parent' android:layout_height='match_parent'> <com.google.android.material.appbar.AppBarLayoutandroid: android:layout_width='match_parent'android:layout_height='wrap_content'app:elevation='0dp'app:layout_behavior='com.yuruiyin.appbarlayoutbehavior.AppBarLayoutBehavior'> <com.google.android.material.appbar.CollapsingToolbarLayout android:layout_width='match_parent' android:layout_height='wrap_content' app:layout_scrollFlags='scroll|exitUntilCollapsed'> <RelativeLayoutandroid:layout_width='match_parent'android:layout_height='wrap_content'android:background='@color/white_color'> <ImageView android:layout_width='match_parent' android:layout_height='180dp' android:scaleType='fitXY' android:visibility='gone' android:src='http://www.hdgsjgj.cn/bcjs/@drawable/ic_launcher_background' /> <RelativeLayout android: android:layout_width='match_parent' android:layout_height='wrap_content' /> </RelativeLayout> <!-- 給SlidingTabLayout占位的--> <androidx.appcompat.widget.Toolbarandroid: android:layout_width='match_parent'android:layout_height='40dp' /></com.google.android.material.appbar.CollapsingToolbarLayout> <com.flyco.tablayout.SlidingTabLayout android: android:layout_width='match_parent' android:layout_height='50dp' android:background='@color/background_color' app:tl_indicator_height='0dp' app:tl_textBold='SELECT' app:tl_textSelectColor='#f000' app:tl_textUnselectColor='@color/txt_color' app:tl_textsize='16sp' /> </com.google.android.material.appbar.AppBarLayout> <androidx.viewpager.widget.ViewPagerandroid: android:layout_width='match_parent'android:layout_height='match_parent'app:layout_behavior='@string/appbar_scrolling_view_behavior' /> </androidx.coordinatorlayout.widget.CoordinatorLayout><RelativeLayout android: android:layout_width='match_parent' android:layout_height='wrap_content' android:layout_marginBottom='50dp' android:layout_alignParentBottom='true'> </RelativeLayout> <RelativeLayout android: android:layout_width='match_parent' android:layout_height='40dp' android:background='@color/theme_color'> <include layout='@layout/top_view_layout' /> </RelativeLayout> </RelativeLayout></com.scwang.smart.refresh.layout.SmartRefreshLayout>3.功能

package com.example.doublesucktopdemo; import android.os.Bundle;import android.util.Log;import android.view.View;import android.widget.ImageView;import android.widget.LinearLayout;import android.widget.RelativeLayout;import android.widget.Toast; import androidx.annotation.NonNull;import androidx.annotation.Nullable;import androidx.cardview.widget.CardView;import androidx.coordinatorlayout.widget.CoordinatorLayout;import androidx.fragment.app.Fragment;import androidx.fragment.app.FragmentActivity;import androidx.recyclerview.widget.GridLayoutManager;import androidx.recyclerview.widget.LinearLayoutManager;import androidx.recyclerview.widget.RecyclerView;import androidx.viewpager.widget.ViewPager; import com.chad.library.adapter.base.BaseQuickAdapter;import com.example.doublesucktopdemo.adapter.HomeViewPagerAdapter;import com.example.doublesucktopdemo.adapter.MyBannerAdapter;import com.example.doublesucktopdemo.adapter.RecommendAdapter;import com.example.doublesucktopdemo.grid.MyAdapter2;import com.example.doublesucktopdemo.grid.PagerConfig;import com.example.doublesucktopdemo.grid.PagerGridLayoutManager;import com.example.doublesucktopdemo.widget.RecyclerViewDivider;import com.example.doublesucktopdemo.widget.RefreshHeaderView.TodayNewsHeader;import com.flyco.tablayout.SlidingTabLayout;import com.flyco.tablayout.listener.OnTabSelectListener;import com.google.android.material.appbar.AppBarLayout;import com.leaf.library.StatusBarUtil;import com.scwang.smart.refresh.layout.SmartRefreshLayout;import com.scwang.smart.refresh.layout.api.RefreshLayout;import com.scwang.smart.refresh.layout.listener.OnRefreshListener;import com.youth.banner.Banner;import com.youth.banner.config.IndicatorConfig;import com.youth.banner.indicator.CircleIndicator; import java.util.ArrayList;import java.util.List; /** * Created by weioule * on 2019/6/26. */public class MainActivity extends FragmentActivity implements PagerGridLayoutManager.PageListener { private SmartRefreshLayout refreshView; private AppBarLayout mAppBarLayout; private RelativeLayout mFloatSearchRl; ///非常重要 private RelativeLayout mHeaderLl; private RelativeLayout mFotterLl; CardView mCardView; private SlidingTabLayout mTabView; private ViewPager mViewPager; private int totalScrollRange, oldVerticalOffset = -1; private HomeViewPagerAdapter fragmentAdapter; private String[] titles = {'首頁', '手機(jī)', '食品', '生鮮', '休閑零食', '家居廚具', '美妝'}; private ArrayList<ProductBean> list = new ArrayList<>(); private List<Fragment> fragmentList; private int mRows = 1; //設(shè)置行數(shù) private int mColumns = 4; //設(shè)置列數(shù) private RecyclerView mRecyclerView; private MyAdapter2 mAdapter; private PagerGridLayoutManager mLayoutManager; private RelativeLayout lineParent; private int mTotal = 0; private int mCurrent = 0; private View lineChild; private ImageView iv_icon_bottom; private RelativeLayout rl_cancel_bottom; private String[] names = {'多多果園','九塊九特賣','多多愛消除','天天領(lǐng)現(xiàn)金' ,'行家?guī)湍氵x','限時秒殺','斷碼清倉','跟著好評買' ,'充值中心','醫(yī)藥館','簽到','多多賺大錢' ,'砍價免費拿','多多精靈','省錢月卡','現(xiàn)金大轉(zhuǎn)盤' }; @Override protected void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initView();addListener(); } private void initView() { // StatusBarUtil.setColor(this, getColor(R.color.theme_color));refreshView = findViewById(R.id.refresh_view);mFloatSearchRl = findViewById(R.id.rl_float_search);mAppBarLayout = findViewById(R.id.app_bar);mTabView = findViewById(R.id.tab_layout);mViewPager = findViewById(R.id.view_pager);mHeaderLl = findViewById(R.id.ll_header);mFotterLl = findViewById(R.id.ll_fotter);refreshView.setRefreshHeader(new TodayNewsHeader(this));addProductBeans();getData(); } private void addListener() {mAppBarLayout.addOnOffsetChangedListener(offsetChangedListener);refreshView.setOnRefreshListener(new OnRefreshListener() { @Override public void onRefresh(@NonNull RefreshLayout refreshLayout) {loadData(); }}); } private void loadData() {refreshView.postDelayed(new Runnable() { @Override public void run() {refreshView.finishRefresh();refreshView.setEnabled(true); }}, 800); } // 這里的處理是當(dāng)AppBarLayout處于最頂部也就是完全打開狀態(tài)verticalOffse=0時才允許刷新控件可用. private AppBarLayout.OnOffsetChangedListener offsetChangedListener = new AppBarLayout.OnOffsetChangedListener() { @Overridepublic void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffse) { totalScrollRange = appBarLayout.getTotalScrollRange(); if (oldVerticalOffset == verticalOffse) return; if (verticalOffse == 0) {refreshView.setEnabled(true); } else {refreshView.setEnabled(false); } if (verticalOffse <= -Utils.dp2px(40)) {mFloatSearchRl.setVisibility(View.VISIBLE); } else {mFloatSearchRl.setVisibility(View.GONE); } if (Math.abs(verticalOffse) >= totalScrollRange && totalScrollRange != 0) {mTabView.setBackgroundColor(getResources().getColor(R.color.white_color)); } else {mTabView.setBackgroundColor(getResources().getColor(R.color.background_color)); } oldVerticalOffset = verticalOffse;} }; public void getData() {mHeaderLl.removeAllViews();mFotterLl.removeAllViews();addTopView();addBannerView(); addBannerTab(); addBottom(); // addRecommendView(); // addFeaturedView(); 圖片initViewpager(); } private void addBannerTab() {View mTopView = getLayoutInflater().inflate(R.layout.activity_two, mHeaderLl, false);lineParent = mTopView.findViewById(R.id.rl_line_parent);lineChild = mTopView.findViewById(R.id.view_line_child);mLayoutManager = new PagerGridLayoutManager(mRows, mColumns, PagerGridLayoutManager.HORIZONTAL);// 系統(tǒng)帶的 RecyclerView,無需自定義mRecyclerView =mTopView.findViewById(R.id.recycler_view);// 水平分頁布局管理器mLayoutManager.setPageListener(this); // 設(shè)置頁面變化監(jiān)聽器mRecyclerView.setLayoutManager(mLayoutManager);// 如果需要查看調(diào)試日志可以設(shè)置為true,一般情況忽略即可PagerConfig.setShowLog(true);initData(); mHeaderLl.addView(mTopView); } private void initData() {List<String> list = new ArrayList<>();for (int i = 0; i < 16; i++) { list.add(names[i]);}// mAdapter.refreshDataList(list);// 使用原生的 Adapter 即可mAdapter = new MyAdapter2(MainActivity.this, list);mRecyclerView.setAdapter(mAdapter); } private void addTopView() {View mTopView = getLayoutInflater().inflate(R.layout.top_view_layout, mHeaderLl, false); mHeaderLl.addView(mTopView); } private void addBottom() {View mTopView = getLayoutInflater().inflate(R.layout.bottom_layout, mFotterLl, false);iv_icon_bottom = mTopView.findViewById(R.id.iv_icon_bottom);rl_cancel_bottom= mTopView.findViewById(R.id.rl_cancel_bottom);iv_icon_bottom.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) {Log.e('TAG','click iv_icon_bottom '); }});rl_cancel_bottom.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) {Log.e('TAG','click cancel'); }}); mFotterLl.addView(mTopView); } private void addBannerView() {View mBannerView = getLayoutInflater().inflate(R.layout.banner_layout, mHeaderLl, false);Banner mBanner = mBannerView.findViewById(R.id.banner); ArrayList<ProductBean> list = new ArrayList<>();for (int i = 0; i < 3; i++) { list.add(new ProductBean('三會一課','2','會議',R.mipmap.ic_launcher));} mBanner.addBannerLifecycleObserver(this).setAdapter(new MyBannerAdapter(list)).setIndicator(new CircleIndicator(this)).setIndicatorGravity(IndicatorConfig.Direction.RIGHT).start(); mHeaderLl.addView(mBannerView); } private void addRecommendView() {RecyclerView mRecyclerView = new RecyclerView(this); GridLayoutManager gridLayoutManager = new GridLayoutManager(this, 6);mRecyclerView.setLayoutManager(gridLayoutManager); RecommendAdapter adapter = new RecommendAdapter(list);adapter.setOnItemChildClickListener(new BaseQuickAdapter.OnItemChildClickListener() { @Override public void onItemChildClick(BaseQuickAdapter adapter, View view, int position) {ProductBean productBean = (ProductBean) adapter.getItem(position);Toast.makeText(MainActivity.this, productBean.getName(), Toast.LENGTH_SHORT).show(); }}); mRecyclerView.setAdapter(adapter);RecyclerViewDivider divider = new RecyclerViewDivider.Builder(this).setStyle(RecyclerViewDivider.Style.BOTH).setColor(0x00000000).setOrientation(RecyclerViewDivider.GRIDE_VIW).setSize(5).build();mRecyclerView.addItemDecoration(divider); mHeaderLl.addView(mRecyclerView); } private void addFeaturedView() {View view = getLayoutInflater().inflate(R.layout.featured_layout, mHeaderLl, false);mHeaderLl.addView(view); } private void initViewpager() {if (fragmentList == null) { fragmentList = new ArrayList<>();} else { fragmentList.clear();} for (int i = 0; i < titles.length; i++) { fragmentList.add(new HomeFragment(list));} fragmentAdapter = new HomeViewPagerAdapter(getSupportFragmentManager(), fragmentList);mViewPager.setAdapter(fragmentAdapter);mTabView.setOnTabSelectListener(onTabSelectListener);mViewPager.addOnPageChangeListener(onPageChangeListener); mTabView.setViewPager(mViewPager, titles); } private OnTabSelectListener onTabSelectListener = new OnTabSelectListener() {@Overridepublic void onTabSelect(int position) { mTabView.setCurrentTab(position);} @Overridepublic void onTabReselect(int position) {} }; private ViewPager.OnPageChangeListener onPageChangeListener = new ViewPager.OnPageChangeListener() {@Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {} @Overridepublic void onPageSelected(int position) { mTabView.setCurrentTab(position);} @Overridepublic void onPageScrollStateChanged(int state) {} }; /** * 控制appbar的滑動 * * @param isScroll true 允許滑動 false 禁止滑動 */ private void banAppBarScroll(boolean isScroll) {View mAppBarChildAt = mAppBarLayout.getChildAt(0);AppBarLayout.LayoutParams mAppBarParams = (AppBarLayout.LayoutParams) mAppBarChildAt.getLayoutParams();if (isScroll && mAppBarParams.getScrollFlags() == 0) { mAppBarParams.setScrollFlags(AppBarLayout.LayoutParams.SCROLL_FLAG_SCROLL | AppBarLayout.LayoutParams.SCROLL_FLAG_EXIT_UNTIL_COLLAPSED); mAppBarChildAt.setLayoutParams(mAppBarParams);} else if (mAppBarParams.getScrollFlags() != 0) mAppBarParams.setScrollFlags(0); } /** * 控制appbar的開關(guān) * 需要手動開關(guān)時調(diào)用 * * @param open true 打開 false 關(guān)閉 */ public void switchAppbarLayout(boolean open) {CoordinatorLayout.Behavior behavior = ((CoordinatorLayout.LayoutParams) mAppBarLayout.getLayoutParams()).getBehavior();if (behavior instanceof AppBarLayout.Behavior) { AppBarLayout.Behavior appBarLayoutBehavior = (AppBarLayout.Behavior) behavior; int topAndBottomOffset = appBarLayoutBehavior.getTopAndBottomOffset(); if (open && topAndBottomOffset != 0) {//打開appBarLayoutBehavior.setTopAndBottomOffset(0); } else if (!open) {//關(guān)閉if (totalScrollRange == 0) totalScrollRange = mAppBarLayout.getHeight();appBarLayoutBehavior.setTopAndBottomOffset(-totalScrollRange); }} } private void addProductBeans() {for (int i = 0; i < 10; i++) { list.add(new ProductBean('智慧美食','2','美食',R.mipmap.ic_launcher));} } @Override public void onPageSizeChanged(int pageSize) {mTotal = pageSize;Log.e('TAG', '總頁數(shù) = ' + pageSize); } @Override public void onPageSelect(int pageIndex, int pageSize) {mCurrent = pageIndex;Log.e('TAG', '選中頁碼 = ' + pageIndex + 't' + pageSize);//計算滾動條寬度float proportion = (float) ((pageIndex + 1) / pageSize);float transMaxRange = lineParent.getWidth() - lineChild.getWidth();//設(shè)置滾動條移動lineChild.setTranslationX(transMaxRange * proportion); }}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: 京東
相關(guān)文章:
主站蜘蛛池模板: 工控机,嵌入式主板,工业主板,arm主板,图像采集卡,poe网卡,朗锐智科 | 臭氧实验装置_实验室臭氧发生器-北京同林臭氧装置网 | 热镀锌槽钢|角钢|工字钢|圆钢|H型钢|扁钢|花纹板-天津千百顺钢铁贸易有限公司 | 合肥宠物店装修_合肥宠物美容院装修_合肥宠物医院设计装修公司-安徽盛世和居装饰 | 厂房出售_厂房仓库出租_写字楼招租_土地出售-中苣招商网-中苣招商网 | 辐射仪|辐射检测仪|辐射巡测仪|个人剂量报警仪|表面污染检测仪|辐射报警仪|辐射防护网 | 高效复合碳源-多核碳源生产厂家-污水处理反硝化菌种一长隆科技库巴鲁 | 档案密集架,移动密集架,手摇式密集架,吉林档案密集架-厂家直销★价格公道★质量保证 | 能耗监测系统-节能监测系统-能源管理系统-三水智能化 | AR开发公司_AR增强现实_AR工业_AR巡检|上海集英科技 | 派财经_聚焦数字经济内容服务平台| 三氯异氰尿酸-二氯-三氯-二氯异氰尿酸钠-优氯净-强氯精-消毒片-济南中北_优氯净厂家 | 临海涌泉蜜桔官网|涌泉蜜桔微商批发代理|涌泉蜜桔供应链|涌泉蜜桔一件代发 | 品牌策划-品牌设计-济南之式传媒广告有限公司官网-提供品牌整合丨影视创意丨公关活动丨数字营销丨自媒体运营丨数字营销 | 视频直播 -摄影摄像-视频拍摄-直播分发 | 油冷式_微型_TDY电动滚筒_外装_外置式电动滚筒厂家-淄博秉泓机械有限公司 | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 代理记账_公司起名核名_公司注册_工商注册-睿婕实业有限公司 | 温州中研白癜风专科_温州治疗白癜风_温州治疗白癜风医院哪家好_温州哪里治疗白癜风 | 煤矿支护网片_矿用勾花菱形网_缝管式_管缝式锚杆-邯郸市永年区志涛工矿配件有限公司 | 线材成型机,线材折弯机,线材成型机厂家,贝朗自动化设备有限公司1 | 特种阀门-调节阀门-高温熔盐阀-镍合金截止阀-钛阀门-高温阀门-高性能蝶阀-蒙乃尔合金阀门-福建捷斯特阀门制造有限公司 | 深圳彩钢板_彩钢瓦_岩棉板_夹芯板_防火复合彩钢板_长鑫 | 洛阳永磁工业大吊扇研发生产-工厂通风降温解决方案提供商-中实洛阳环境科技有限公司 | 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛婚外情取证-青岛王军侦探事务所 | 定制液氮罐_小型气相液氮罐_自增压液氮罐_班德液氮罐厂家 | 大学食堂装修设计_公司餐厅效果图_工厂食堂改造_迈普装饰 | 地图标注|微信高德百度地图标注|地图标记-做地图[ZuoMap.com] | PC构件-PC预制构件-构件设计-建筑预制构件-PC构件厂-锦萧新材料科技(浙江)股份有限公司 | 捷码低代码平台 - 3D数字孪生_大数据可视化开发平台「免费体验」 | 数码管_LED贴片灯_LED数码管厂家-无锡市冠卓电子科技有限公司 | 土壤养分检测仪_肥料养分检测仪_土壤水分检测仪-山东莱恩德仪器 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 节流截止放空阀-不锈钢阀门-气动|电动截止阀-鸿华阀门有限公司 | 紧急切断阀_气动切断阀_不锈钢阀门_截止阀_球阀_蝶阀_闸阀-上海上兆阀门制造有限公司 | 包头市鑫枫装饰有限公司| 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 换网器_自动换网器_液压换网器--郑州海科熔体泵有限公司 | 清水混凝土修复_混凝土色差修复剂_混凝土色差调整剂_清水混凝土色差修复_河南天工 | 上海心叶港澳台联考一对一培训_上海心叶港澳台联考,港澳台联考一对一升学指导 | 蜗轮丝杆升降机-螺旋升降机-丝杠升降机厂家-润驰传动 | 东莞动力锂电池保护板_BMS智能软件保护板_锂电池主动均衡保护板-东莞市倡芯电子科技有限公司 |