https://www.jianshu.com/p/122354d2243f
Design
多个布局相互使用
<?xml version="1.0" encoding="utf-8"?>
<!--协调者布局-->
<androidx.coordinatorlayout.widget.CoordinatorLayout 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"
tools:context=".design.Main4Activity">
<!-- 通过协调者布局,取到滑动事件
它可以让你定制当某个可滚动View的滚动手势发生变化时,其内部的子View实现何种动作。 -->
<com.google.android.material.appbar.AppBarLayout
android:layout_width="match_parent"
android:id="@+id/app_bar"
android:layout_height="wrap_content">
<!-- 可折叠布局 可以单做帧布局来使用
scroll|exitUntilCollapsed 与minHeight 结合使用 效果最常用
app:contentScrim="@color/colorAccent" 蒙版效果-->
<com.google.android.material.appbar.CollapsingToolbarLayout
android:layout_width="match_parent"
android:layout_height="200dp"
android:minHeight="50dp"
app:collapsedTitleGravity="left"
app:expandedTitleGravity="bottom|right"
app:contentScrim="@color/colorAccent"
app:layout_scrollFlags="scroll|exitUntilCollapsed"
>
<ImageView
android:layout_width="match_parent"
android:layout_height="300dp"
android:src="@mipmap/kawayi"
android:scaleType="centerCrop" />
<!-- 折叠以后留下的bar
layout_collapseMode 吸附效果-->
<androidx.appcompat.widget.Toolbar
android:layout_width="match_parent"
android:layout_height="50dp"
app:title="标题"
android:id="@+id/bar"
app:layout_collapseMode="pin" />
</com.google.android.material.appbar.CollapsingToolbarLayout>
</com.google.android.material.appbar.AppBarLayout>
<!-- ScrollView的替代品 layout_behavior属性为固定写法-> 点进去看看 -->
<androidx.core.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
<LinearLayout
android:layout_width="match_parent"
android:orientation="vertical"
android:layout_height="wrap_content">
<TextView
android:layout_width="match_parent"
android:layout_height="500dp"
android:background="#ff0000" />
<ImageView
android:layout_width="match_parent"
android:layout_height="300dp"
android:src="@drawable/ic_launcher_background" />
</LinearLayout>
</androidx.core.widget.NestedScrollView>
<!-- 圆形风格按钮-->
<com.google.android.material.floatingactionbutton.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:layout_anchor="@id/app_bar"
android:src="@mipmap/ic_launcher"
app:layout_anchorGravity="bottom|right"
android:layout_marginRight="10dp"
android:layout_marginBottom="10dp"/>
</androidx.coordinatorlayout.widget.CoordinatorLayout>
侧滑布局
<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/drawer_layout">
<LinearLayout
android:id="@+id/main_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#ff0000"
android:orientation="horizontal">
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/btn"
android:text="于谦说:"></Button>
</LinearLayout>
<LinearLayout
android:id="@+id/left_layout"
android:layout_width="250dp"
android:layout_height="match_parent"
android:background="#00ff00"
android:orientation="horizontal"
android:layout_gravity="start" >
<TextView
android:layout_width="wrap_content"
android:text="什么乱七八糟的."
android:layout_height="wrap_content"></TextView>
</LinearLayout>
</androidx.drawerlayout.widget.DrawerLayout>
java代码
package com.fenghongzhang.test.design;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.drawerlayout.widget.DrawerLayout;
import com.fenghongzhang.test.R;
public class Main5Activity extends AppCompatActivity {
private DrawerLayout mDrawerLayout;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main5);
mDrawerLayout = findViewById(R.id.drawer_layout);
mDrawerLayout.addDrawerListener(new DrawerLayout.DrawerListener() {
@Override
public void onDrawerSlide(@NonNull View drawerView, float slideOffset) {
Log.i("Simon", "onDrawerSlide");
}
@Override
public void onDrawerOpened(@NonNull View drawerView) {
Log.i("Simon", "onDrawerOpened");
}
@Override
public void onDrawerClosed(@NonNull View drawerView) {
Log.i("Simon", "onDrawerClosed");
}
@Override
public void onDrawerStateChanged(int newState) {
Log.i("Simon", "onDrawerStateChanged");
}
});
}
}