SeniorUI28_Meterail Design综合使用实现侧拉栏主页

本文详细介绍了如何使用Toolbar、DrawerLayout、TabLayout和ViewPager等组件构建复杂UI界面,通过Palette API对ViewPager中的图片进行取色,实现状态栏、标题栏及TabLayout背景的动态配色,并利用RGB位运算技巧加深颜色,最终打造出一款响应式且视觉效果丰富的APP主页。

SeniorUI_高级UI汇总目录
SeniorUI28_Tablayout简介

一 效果图

在这里插入图片描述

二 需求

  • 实现一个APP的主页
  • 有侧拉栏,有顶部标题,有tab二级标题
  • 主内容区是个可滑动的Banner和二级标题联动
  • 状态栏、标题栏、二级标题tab的背景受到Banner显示内容图片的影响
  • 状态栏颜色加深

三 需求分析

  1. Toolbar实现顶部标题

  2. DrawerLayout实现侧拉栏

  3. TabLayout+ViewPager实现二级标题栏和Banner

  4. Palette 的API对ViewPager中图片取色

    获取对应Bitmap的Palette.Swatch设置标题栏、TabLayout和状态栏

  5. RGB的位运算实现颜色加深, 单通道颜色色值越小,颜色越深

四 主要代码

1 添加依赖

implementation ‘com.android.support:appcompat-v7:26.1.0’
compile “com.android.support:design:$supportLibVersion”
compile ‘com.android.support:palette-v7:23.4.0’

2 布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:orientation="vertical"
 >
    <include layout="@layout/layout_includ"/>
    <android.support.v4.widget.DrawerLayout
        android:id="@+id/drawer"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <!--两个子控件   -->

        <!--抽屉栏-->
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@drawable/drawer"
            android:layout_gravity="start"
            ></LinearLayout>

        <!--内容区域-->
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical"
            >
            <android.support.design.widget.TabLayout
                android:id="@+id/tablayout"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                app:tabMode="scrollable"
                app:tabSelectedTextColor="#00FFFF"
                app:tabTextColor="@color/colorAccent"
                app:tabIndicatorColor="@color/colorPrimary"
                >

            </android.support.design.widget.TabLayout>

            <android.support.v4.view.ViewPager
                android:id="@+id/viewpager"
                android:layout_width="match_parent"
                android:layout_height="match_parent"/>
        </LinearLayout>
    </android.support.v4.widget.DrawerLayout>
</LinearLayout>

3 代码使用

/**
 * Created by Ray on 2019-12-18.
 */
public class TabLayoutActivity extends AppCompatActivity {

    TabLayout tabLayout;
    ViewPager viewPager;
    MyAdatper myAdatper;
    Toolbar toolbar;
    DrawerLayout drawerLayout;
    private final String[] titels = {"分类", "主页", "热门推荐", "热门收藏", "本月热榜", "今日热榜", "专栏", "随机"};
    private int[] drawbles = {R.drawable.a, R.drawable.b, R.drawable.c, R.drawable.d, R.drawable.e, R.drawable.f, R.drawable.g, R.drawable.h};

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.tab_layout_activity);

        tabLayout = (TabLayout) findViewById(R.id.tablayout);
        viewPager = (ViewPager) findViewById(R.id.viewpager);
        toolbar = (Toolbar) findViewById(R.id.toolbar);
        drawerLayout = (DrawerLayout) findViewById(R.id.drawer);

        toolbar.setTitle("TabLayout等design包下View的综合使用");
        //顺序非常重要  设置 文字 样式调用setSupportActionBar  之前     设置监听在 setSupportActionBar之后
        setSupportActionBar(toolbar);

        ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.open, R.string.close);
        toggle.syncState();
        drawerLayout.addDrawerListener(toggle);

        myAdatper = new MyAdatper(getSupportFragmentManager());
        viewPager.setAdapter(myAdatper);
        //设置联动
        tabLayout.setupWithViewPager(viewPager);

        viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

            }

            @Override
            public void onPageSelected(int position) {
                colorChage(position);
            }

            @Override
            public void onPageScrollStateChanged(int state) {

            }
        });
        colorChage(0);
    }

    /**
     * 如果页面 发生切换     根据BItmap改变toolBar的颜色
     *
     * @param position
     */
    private void colorChage(int position) {
        Bitmap bitmap = BitmapFactory.decodeResource(getResources(), drawbles[position]);
        Palette.from(bitmap).generate(new Palette.PaletteAsyncListener() {
            @Override
            public void onGenerated(Palette palette) {
                //拿到鲜艳的颜色
                Palette.Swatch vibreant = palette.getVibrantSwatch();
                if (vibreant == null) {
                    for (Palette.Swatch swatch : palette.getSwatches()) {
                        if (swatch != null) {
                            vibreant = swatch;
                            break;
                        }
                    }
                }

                viewPager.setBackgroundColor(vibreant.getRgb());
                tabLayout.setSelectedTabIndicatorColor(vibreant.getRgb());
                tabLayout.setBackgroundColor(vibreant.getRgb());
                toolbar.setBackgroundColor(vibreant.getRgb());
                if (Build.VERSION.SDK_INT > 21) {
                    Window window = getWindow();
                    //状态栏 颜色加深
                    window.setStatusBarColor(colorBurn(vibreant.getRgb()));
                    window.setNavigationBarColor(vibreant.getRgb());
                }
            }
        });
    }

    private int colorBurn(int rgb) {
        //加深颜色
        int red = rgb >> 16 & 0xFF;
        int green = rgb >> 8 & 0xFF;
        int blue = rgb&0xFF;

        red = (int) Math.floor(red * (1 - 0.2));
        green = (int) Math.floor(green * (1 - 0.2));
        blue = (int) Math.floor(blue * (1 - 0.2));
        return Color.rgb(red, green, blue);
    }


    class MyAdatper extends FragmentPagerAdapter {


        public MyAdatper(FragmentManager fm) {
            super(fm);
        }

        @Override
        public Fragment getItem(int position) {
            Fragment fragment = new ImageFrament();
            Bundle bundle = new Bundle();
            bundle.putInt("id", drawbles[position]);
            fragment.setArguments(bundle);
            return fragment;
        }

        @Override
        public int getCount() {
            return drawbles.length;
        }

        @Override
        public CharSequence getPageTitle(int position) {
            return titels[position];
        }
    }
}

五 Demo

TabLayoutActivity

Delphi 12.3 作为一款面向 Windows 平台的集成开发环境,由 Embarcadero Technologies 负责其持续演进。该环境以 Object Pascal 语言为核心,并依托 Visual Component Library(VCL)框架,广泛应用于各类桌面软件、数据库系统及企业级解决方案的开发。在此生态中,Excel4Delphi 作为一个重要的社区开源项目,致力于搭建 Delphi 与 Microsoft Excel 之间的高效桥梁,使开发者能够在自研程序中直接调用 Excel 的文档处理、工作表管理、单元格操作及宏执行等功能。 该项目以库文件与组件包的形式提供,开发者将其集成至 Delphi 工程后,即可通过封装良好的接口实现对 Excel 的编程控制。具体功能涵盖创建与编辑工作簿、格式化单元格、批量导入导出数据,乃至执行内置公式与宏指令等高级操作。这一机制显著降低了在财务分析、报表自动生成、数据整理等场景中实现 Excel 功能集成的技术门槛,使开发者无需深入掌握 COM 编程或 Excel 底层 API 即可完成复杂任务。 使用 Excel4Delphi 需具备基础的 Delphi 编程知识,并对 Excel 对象模型有一定理解。实践中需注意不同 Excel 版本间的兼容性,并严格遵循项目文档进行环境配置与依赖部署。此外,操作过程中应遵循文件访问的最佳实践,例如确保目标文件未被独占锁定,并实施完整的异常处理机制,以防数据损毁或程序意外中断。 该项目的持续维护依赖于 Delphi 开发者社区的集体贡献,通过定期更新以适配新版开发环境与 Office 套件,并修复已发现的问题。对于需要深度融合 Excel 功能的 Delphi 应用而言,Excel4Delphi 提供了经过充分测试的可靠代码基础,使开发团队能更专注于业务逻辑与用户体验的优化,从而提升整体开发效率与软件质量。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值