Android 滑动渐变背景Toolbar、点击置顶ScrollView

tools:context=“.MainActivity”>

<com.google.android.material.appbar.AppBarLayout

android:id=“@+id/appbar”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:theme=“@style/ThemeOverlay.AppCompat.Dark.ActionBar”>

<com.google.android.material.appbar.CollapsingToolbarLayout

android:layout_width=“match_parent”

android:layout_height=“300dp”

app:layout_scrollFlags=“scroll|exitUntilCollapsed”>

<ImageView

android:id=“@+id/iv_top”

android:layout_width=“match_parent”

android:layout_height=“300dp”

android:scaleType=“centerCrop”

android:src=“@drawable/top_bg” />

<androidx.appcompat.widget.Toolbar

android:layout_width=“match_parent”

android:layout_height=“80dp”

app:contentInsetStart=“0dp”

app:layout_collapseMode=“pin”>

<LinearLayout

android:id=“@+id/fl_layout”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:background=“#FFF”

android:gravity=“center”

android:paddingTop=“20dp”

app:layout_collapseMode=“pin”>

<TextView

android:id=“@+id/tv_title”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:text=“在座的各位都是正人君子”

android:textColor=“#000”

android:textSize=“18sp” />

</androidx.appcompat.widget.Toolbar>

</com.google.android.material.appbar.CollapsingToolbarLayout>

</com.google.android.material.appbar.AppBarLayout>

<com.llw.slidelayoutdemo.GoTopNestedScrollView

android:id=“@+id/go_top_scrollview”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:overScrollMode=“never”

app:layout_behavior=“@string/appbar_scrolling_view_behavior”>

<LinearLayout

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:orientation=“vertical”>

<ImageView

android:id=“@+id/iv_one”

android:layout_width=“match_parent”

android:layout_height=“600dp”

android:scaleType=“centerCrop” />

<ImageView

android:id=“@+id/iv_two”

android:layout_width=“match_parent”

android:layout_height=“600dp”

android:scaleType=“centerCrop” />

<ImageView

android:id=“@+id/iv_three”

android:layout_width=“match_parent”

android:layout_height=“600dp”

android:scaleType=“centerCrop” />

<ImageView

android:id=“@+id/iv_four”

android:layout_width=“match_parent”

android:layout_height=“600dp”

android:scaleType=“centerCrop” />

<ImageView

android:id=“@+id/iv_five”

android:layout_width=“match_parent”

android:layout_height=“600dp”

android:scaleType=“centerCrop” />

</com.llw.slidelayoutdemo.GoTopNestedScrollView>

</androidx.coordinatorlayout.widget.CoordinatorLayout>

<ImageView

android:id=“@+id/ivReturnTop”

android:layout_width=“50dp”

android:layout_height=“50dp”

android:layout_alignParentRight=“true”

android:layout_alignParentBottom=“true”

android:layout_margin=“10dp”

android:src=“@mipmap/icon_return_top”

android:visibility=“gone” />

这里还有一个状态栏工具类,代码如下:

package com.llw.slidelayoutdemo;

import android.app.Activity;

import android.graphics.Color;

import android.os.Build;

import android.view.View;

import android.view.Window;

import android.view.WindowManager;

import java.lang.reflect.Field;

import java.lang.reflect.Method;

public class StatusBarUtils {

/**

  • 兼容状态栏透明(沉浸式)

  • @param activity

*/

public static void setImmersionStateMode(Activity activity) {

StatusBarLightMode(activity);

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT != Build.VERSION_CODES.LOLLIPOP) {

// 透明状态栏

activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);

// 透明导航栏

// getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);

} else if (Build.VERSION.SDK_INT == Build.VERSION_CODES.LOLLIPOP) {

Window window = activity.getWindow();

window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS |

WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);

window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN

// | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION

| View.SYSTEM_UI_FLAG_LAYOUT_STABLE);

window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);

window.setStatusBarColor(Color.TRANSPARENT);

window.setNavigationBarColor(Color.TRANSPARENT);

}

}

/**

  • 设置状态栏黑色字体图标,

  • 适配4.4以上版本MIUIV、Flyme和6.0以上版本其他Android

  • @param activity

  • @return 1:MIUUI 2:Flyme 3:android6.0

*/

public static int StatusBarLightMode(Activity activity) {

int result = 0;

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {

if (MIUISetStatusBarLightMode(activity.getWindow(), true)) {

result = 1;

} else if (FlymeSetStatusBarLightMode(activity.getWindow(), true)) {

result = 2;

} else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {

activity.getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);

result = 3;

}

}

return result;

}

/**

  • 设置状态栏图标为深色和魅族特定的文字风格

  • 可以用来判断是否为Flyme用户

  • @param window 需要设置的窗口

  • @param dark 是否把状态栏字体及图标颜色设置为深色

  • @return boolean 成功执行返回true

*/

public static boolean FlymeSetStatusBarLightMode(Window window, boolean dark) {

boolean result = false;

if (window != null) {

try {

WindowManager.LayoutParams lp = window.getAttributes();

Field darkFlag = WindowManager.LayoutParams.class

.getDeclaredField(“MEIZU_FLAG_DARK_STATUS_BAR_ICON”);

Field meizuFlags = WindowManager.LayoutParams.class

.getDeclaredField(“meizuFlags”);

darkFlag.setAccessible(true);

meizuFlags.setAccessible(true);

int bit = darkFlag.getInt(null);

int value = meizuFlags.getInt(lp);

if (dark) {

value |= bit;

} else {

value &= ~bit;

}

meizuFlags.setInt(lp, value);

window.setAttributes(lp);

result = true;

} catch (Exception e) {

}

}

return result;

}

/**

  • 设置状态栏字体图标为深色,需要MIUIV6以上

  • @param window 需要设置的窗口

  • @param dark 是否把状态栏字体及图标颜色设置为深色

  • @return boolean 成功执行返回true

*/

public static boolean MIUISetStatusBarLightMode(Window window, boolean dark) {

boolean result = false;

if (window != null) {

Class clazz = window.getClass();

try {

int darkModeFlag = 0;

Class layoutParams = Class.forName(“android.view.MiuiWindowManager$LayoutParams”);

Field field = layoutParams.getField(“EXTRA_FLAG_STATUS_BAR_DARK_MODE”);

darkModeFlag = field.getInt(layoutParams);

Method extraFlagField = clazz.getMethod(“setExtraFlags”, int.class, int.class);

if (dark) {

extraFlagField.invoke(window, darkModeFlag, darkModeFlag);//状态栏透明且黑色字体

} else {

extraFlagField.invoke(window, 0, darkModeFlag);//清除黑色字体

}

result = true;

} catch (Exception e) {

}

}

return result;

}

}

接下来进入到MainActivity中

package com.llw.slidelayoutdemo;

import androidx.appcompat.app.AppCompatActivity;

import androidx.databinding.DataBindingUtil;

import android.graphics.Color;

import android.os.Bundle;

import android.util.DisplayMetrics;

import com.bumptech.glide.Glide;

import com.google.android.material.appbar.AppBarLayout;

import com.llw.slidelayoutdemo.databinding.ActivityMainBinding;

public class MainActivity extends AppCompatActivity {

ActivityMainBinding binding;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initView();//初始化视图

showImg();//显示网络图片

}

/**

  • 初始化视图

*/

private void initView() {

binding = DataBindingUtil.setContentView(this, R.layout.activity_main);//绑定视图

StatusBarUtils.setImmersionStateMode(this);//透明状态栏

//滑动偏移监听事件

binding.appbar.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {

@Override

public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {

int toolbarHeight = appBarLayout.getTotalScrollRange();

int dy = Math.abs(verticalOffset);

if (dy <= toolbarHeight) {

float scale = (float) dy / toolbarHeight;

float alpha = scale * 255;

binding.flLayout.setBackgroundColor(Color.argb((int) alpha, 255, 255, 255));//渐变背景透明度

binding.tvTitle.setTextColor(Color.argb((int) alpha,0,0,0));//渐变文字颜色透明度

}

}

});

//设置点击置顶的ImageView

binding.goTopScrollview.setImageViewOnClickGoToFirst(binding.ivReturnTop);

//ScrollView滑动超过屏幕高度则显示置顶按钮,不设置的话就会使用自定义View中的默认高度

DisplayMetrics metric = new DisplayMetrics();//获取屏幕高度

getWindowManager().getDefaultDisplay().getMetrics(metric);

binding.goTopScrollview.setScreenHeight(metric.heightPixels);//设置高度

}

/**

  • 使用Glide加载显示网络图片 记得加网络权限和http地址url访问许可

*/

private void showImg() {

Glide.with(this)

.load(“http://gank.io/images/2c924db2a1b84c5d8fdb9f8c5f6d1b71”)

.into(binding.ivOne);

Glide.with(this)

.load(“http://gank.io/images/92989b6a707b44dfb1c734e8d53d39a2”)

.into(binding.ivTwo);

Glide.with(this)

.load(“http://gank.io/images/4817628a6762410895f814079a6690a1”)

.into(binding.ivThree);

Glide.with(this)

.load(“http://gank.io/images/f9523ebe24a34edfaedf2dd0df8e2b99”)

.into(binding.ivFour);

Glide.with(this)

Android开发除了flutter还有什么是必须掌握的吗?

相信大多数从事Android开发的朋友们越来越发现,找工作越来越难了,面试的要求越来越高了

除了基础扎实的java知识,数据结构算法,设计模式还要求会底层源码,NDK技术,性能调优,还有会些小程序和跨平台,比如说flutter,以思维脑图的方式展示在下图;

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
(this)

.load(“http://gank.io/images/92989b6a707b44dfb1c734e8d53d39a2”)

.into(binding.ivTwo);

Glide.with(this)

.load(“http://gank.io/images/4817628a6762410895f814079a6690a1”)

.into(binding.ivThree);

Glide.with(this)

.load(“http://gank.io/images/f9523ebe24a34edfaedf2dd0df8e2b99”)

.into(binding.ivFour);

Glide.with(this)

Android开发除了flutter还有什么是必须掌握的吗?

相信大多数从事Android开发的朋友们越来越发现,找工作越来越难了,面试的要求越来越高了

除了基础扎实的java知识,数据结构算法,设计模式还要求会底层源码,NDK技术,性能调优,还有会些小程序和跨平台,比如说flutter,以思维脑图的方式展示在下图;

[外链图片转存中…(img-HulnuedU-1714450370156)]

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 26
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值