高仿简书个人中心页面

Demo下载地址:

先贴上效果图

1. 步骤

1.1 把APP的主题改为NoAction

1.2 引入Material Design 包

implementation 'com.google.android.material:material:1.0.0'

1.3 新建activity_home_page.xml布局文件

/*

*/

下边讲解一些属性:

scrollFlags的效果

scrollFlags一共有五个值,一些值是可以组合作用在View上的。五个值分别是:

scroll:子View随ScrollView一起滚动

enterAlways:只要ScrollView向下移动,子View立即响应滚动

enterAlwaysCollapsed:当ScrollView滚动最顶层时,子View响应滚动事件,直至子View完全显示

exitUtilCollapsed:只要ScrollView向上滚动,子View立即响应滚动,直到达到最小高度

snap:当Scrollview滚动到最顶层时,子View响应滚动事件。松开手指时,依据AppBarLayout移出屏幕区域与生育可视区域对比,自动移向占比大的区域。

titleMarginStart 标题距离(开始)左边的距离

CollapsingToolbarLayout控件 以下的几个属性:

app:contentScrim=”?attr/colorPrimary” 当上滑到toolbar 高度期间直到达到toolbar高度时,给toolbar设置的背景色,以及过渡颜色。当然,这里不仅仅可以设置颜色,也可以设置图片。 如果不设置该属性,标题栏会过渡为以之前的图片为背景。

app:layout_scrollFlags=”scroll” 和介绍 AppBarLayout 时,给Toolbar 设置和配置一样。

app:expandedTitleGravity=”center_horizontal” 从单词意思可以看出,这是展示后,title的位置。

app:expandedTitleMarginStart=”50dp” 从单词意思可以看出,这是展示后,title 距离开始位置的边距。

app:expandedTitleTextAppearance=”@style/transparentText” 展开后标题文字的样式

app:collapsedTitleTextAppearance=”@style/ToolbarTitle” 折叠后标题文字的样式

1.4 新建HomePageActivity.java文件

import android.os.Bundle;

import android.view.View;

import androidx.appcompat.app.AppCompatActivity;

import androidx.appcompat.widget.Toolbar;

import androidx.fragment.app.Fragment;

import androidx.viewpager.widget.ViewPager;

import com.google.android.material.tabs.TabLayout;

import java.util.ArrayList;

import java.util.List;

/**

* 用户主页

* 展示用户个人信息

*/

public class HomePageActivity extends AppCompatActivity {

private TabLayout tab_layout;

private ViewPager viewPager;

private MyTabAdapter myFragmentPagerAdapter;

private ListmList;

private Liststrings;

private Toolbar toolbar;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_home_page);

initDate();

initView();

}

private void initDate(){

mList = new ArrayList<>();

strings = new ArrayList<>();

mList.add(new FragmentA());

strings.add("动态");

mList.add(new FragmentB());

strings.add("视频");

mList.add(new FragmentC());

strings.add("更多");

}

private void initView(){

toolbar = findViewById(R.id.toolBar);

toolbar.setTitle("Mr.H");

toolbar.setNavigationIcon(R.drawable.nav_ic_back);

//点击左边返回按钮监听事件

toolbar.setNavigationOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

onBackPressed();

}

});

tab_layout = findViewById(R.id.tl_tabLayout);

viewPager = findViewById(R.id.vp_viewPager);

myFragmentPagerAdapter = new MyTabAdapter(mList,strings,getSupportFragmentManager());

viewPager.setAdapter(myFragmentPagerAdapter);

//联动ViewPager

tab_layout.setupWithViewPager(viewPager);

}

}

1.5 一些java类Adapter、Fragment

FragmentA.java

package org.gpnu.mineui;

import android.os.Bundle;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

import androidx.annotation.NonNull;

import androidx.annotation.Nullable;

import androidx.fragment.app.Fragment;

import androidx.recyclerview.widget.DividerItemDecoration;

import androidx.recyclerview.widget.LinearLayoutManager;

import androidx.recyclerview.widget.RecyclerView;

/**

* 用户动态

*/

public class FragmentA extends Fragment {

private RecyclerView rv_track;

@Nullable

@Override

public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view = inflater.inflate(R.layout.fragment_a,container,false);

rv_track = view.findViewById(R.id.mRecyclerView);

MyAdapter adapter = new MyAdapter();

LinearLayoutManager layoutManager = new LinearLayoutManager(this.getContext());

rv_track.setLayoutManager(layoutManager);

rv_track.addItemDecoration(new DividerItemDecoration(this.getContext(), layoutManager.getOrientation()));//用类设置分割线

rv_track.setAdapter(adapter);

return view;

}

}

MyTabAdapter.java

package org.gpnu.mineui;

import androidx.annotation.NonNull;

import androidx.annotation.Nullable;

import androidx.fragment.app.Fragment;

import androidx.fragment.app.FragmentManager;

import androidx.fragment.app.FragmentPagerAdapter;

import java.util.List;

public class MyTabAdapter extends FragmentPagerAdapter {

private ListmList;

private Liststrings;

public MyTabAdapter(ListmList, Liststrings, @NonNull FragmentManager fm) {

super(fm);

this.mList = mList;

this.strings = strings;

}

@NonNull

@Override

public Fragment getItem(int position) {

return mList.get(position);

}

@Override

public int getCount() {

return strings.size();

}

@Nullable

@Override

public CharSequence getPageTitle(int position) {

return strings.get(position);

}

}

MyAdapter.java

package org.gpnu.mineui;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

import android.widget.TextView;

import androidx.annotation.NonNull;

import androidx.recyclerview.widget.RecyclerView;

public class MyAdapter extends RecyclerView.Adapter{

@NonNull

@Override

public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {

View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_view,parent,false);

return new MyViewHolder(view);

}

@Override

public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {

}

@Override

public int getItemCount() {

return 40;

}

class MyViewHolder extends RecyclerView.ViewHolder{

TextView textView;

public MyViewHolder(@NonNull View itemView) {

super(itemView);

textView = itemView.findViewById(R.id.tv_textview);

}

}

}

1.6 其他用的到一些布局文件

fragment_a.xml

item_view.xml

高仿简书Android,高仿简书个人中心页面相关推荐

  1. android+高仿视频录制,android高仿微信视频编辑页

    android高仿微信视频编辑页-视频多张图片提取 上一篇中介绍了有关视频提取图片的知识点,如果对这个不太了解 建议看下android提取视频多张图片和视频信息之前这篇. 这里实现的是仿微信的视频编辑 ...

  2. android+高仿视频录制,Android高仿微信拍照控件,实战推荐!

    原标题:Android高仿微信拍照控件,实战推荐! 作者:陈嘉桐 转自:ttps://github.com/CJT2325 控件介绍 不知道是不是在微信更新到6.0版本之后,微信将它的拍照和录制视频的 ...

  3. android高仿小米时钟,Android高仿小米时钟

    今日科技快讯 昨日,小米科技正式发布首款自主芯片松果澎湃S1和搭载澎湃S1芯片的小米5C手机.从立项做到量产结束,小米芯片用了28个月.S1的CPU为八核64位处理器,主频达2.2GHz,处理高计算量 ...

  4. android 动态壁纸仿抖音,Android高仿抖音照片电影功能

    本篇文章已授权微信公众号 guolin_blog (郭霖)独家发布 滤镜效果 filter.gif 转场效果 transfer.gif 基本用法 //添加图片 List photoDataList = ...

  5. 高仿知乎android客户端,仿知乎分享界面

    前言 最近在做一个资讯类的APP,上面需要一个分享功能,项目不大,如果去使用官方的SDK还需要审查之类的,感觉太麻烦.偶然看到知乎的分享界面做得不错,拿到我这个项目中正合适,在网上查了一下资料,使用B ...

  6. android 高仿苹果listview,android listview仿iphone特效

    ios常见视图在顶部往下拉(下冲)或底部往上拉(上冲)有一个弹性回退的动画效果.著名的CM ROM和一些手机厂商也争相集成这种效果.android 从2.3开始实现了下冲到底部和上冲到顶部时颜色渐变动 ...

  7. android 高仿网易新闻,Android高仿网易新闻客户端

    关于实现网易新闻客户端的界面,以前写过很多博客,请参考: 今天用ViewPager + FragmentAdapter + ViewPagerIndicator来实现. ViewPagerIndica ...

  8. android 高仿拼多多,Android高仿拼多多分类列表

    package com.zkteam.discover.fresco; import android.content.Context; import android.graphics.Bitmap; ...

  9. android仿苹果滑动,Android开发仿IOS的滑动按钮

    释放双眼,带上耳机,听听看~! 项目结构 MainActivity public class MainActivity extends AppCompatActivity { @Override pr ...

最新文章

  1. Science:英国Castrillo组揭示微生物群与根内皮的协调支持植物营养平衡!
  2. 用Windows Live Writer在51CTO写博客(2018年2月24日更新)
  3. Dynamic Web Module 3.0 requires Java 1.6 or newer
  4. VS2017-VC++中慎用sizeof
  5. 《R语言实战》第7章
  6. 【我的Android进阶之旅】Android 源代码中的Java代码中//$NON-NLS-1$ 注释是什么意思?...
  7. mac你没有权限打开应用程序_苹果mac卡顿怎么解决呢?轻松几招让你Mac流畅如新
  8. 使用代码创建BRF ruleset
  9. 1603 限高二叉排列树(计数DP)
  10. ubuntu修改ssh服务的端口号
  11. 清北学堂dp图论营游记day4
  12. 邻接矩阵存储图的深度优先遍历
  13. 从0开始学习 GitHub 系列之「向GitHub 提交代码」
  14. 大数据真实电商数据仓库全流程开发详解
  15. java 接口怎么规范属性_JAVA命名规范
  16. 大麦支持选座位、定时等功能
  17. yocto linux 内核源码,利用Bitbake、Poky、Yocto、OpenEmbedded编译生成车规AGL Linux
  18. U盘安装ESXI 6.7,并使用U盘启动服务器
  19. 时空跳跃者的追捕行动模拟赛
  20. 暴雪即将公布《暗黑破坏神3》新职业

热门文章

  1. Xshell传输文件到服务器(centos/ubuntu)上传/下载
  2. 下载和安装配置 MinGW-w64(免安装版)
  3. 电磁分析matlab,瞬变电磁一维解析解MATLAB代码
  4. Webpack 3.0来了,就问你慌不慌
  5. mycat全局表一致性检查
  6. 3. Oracle数据库在Linux系统安装步骤
  7. 远古Vod故障404排除实战
  8. 将新的驱动源文件添加进android内核进行编译
  9. 前端实现base64格式文件的下载
  10. 淘宝开放平台TOP SDK调用对接淘宝或天猫