由于只有2个G运存,Ubuntu16.04系统,AndroidStudio运行不起来,只能用Eclipse了,记录下笔记

滑动中的效果图

在Eclipse IDE下实现下滑隐藏ToolBar_第1张图片

第一步,导入扩展包,创建应用

  • 导入在sdk目录下的/sdk/extras/android/support/design库
  • /sdk/extras/android/support/v7/appcompat库
  • /sdk/extras/android/support/v7/recyclerview库
  • 导入时选择复制到Workspace,三个包导好后右键properties选择23以上的编译版本
  • 导入后右键设置isLibrary
  • 创建一个Android Project ,选择最低4.0,Target SDK 23, Compiler With 23
  • 创建好应用后把前面导入的库引入

第二步 修改MainActivity和清单文件

  • 修改MainActivity继承AppCompatActivity
public class MainActivity extends AppCompatActivity
  • 关于AppCompatActivity
    Base class for activities that use the support library action bar features.
    You can add an ActionBar to your activity when running on API level 7 or higher by extending
    this class for your activity and setting the activity theme to Theme.AppCompat or a similar theme.
    简单的说,AppCompatActivity是基于Activity并且有带有ActionBar,用来代替ActionbarActivity
    而Actionbar被Toolbar替代
    在AppCompatActivity里有一个 setSupportActionBar(Toolbar toolbar)方法,其文档描述如下:
    Set a Toolbar to act as the ActionBar for this Activity window.
    在AppCompatActivity里就带有直接设置Toolbar的api

  • 修改主题

android:theme="@style/MyAppTheme"该自定义主题在values->styles里定义,在跟标签resources下添加:这里自定义了一个style,继承了一个没有ActionBar的style,目的是为了隐藏ActionBar,用Toolbar替代 涉及到的颜色定义在values->color.xml里,该文件定义如下: <?xml version="1.0" encoding="utf-8"?>    #1e88e5    #536dfe    #ffffff    #b71c1c    #000000     #33000000
  • 关于这些颜色都代表哪些看图


    在Eclipse IDE下实现下滑隐藏ToolBar_第2张图片

    还有一些我就没有一一定义了,就用支持库自带的

第三步,修改activity_layout.xml,写页面布局

<?xml version="1.0" encoding="utf-8"?>                                                    

首先我的ViewPager里填充了RecyclerView,它支持app:layout_behavior属性

  • 关于CoordinatorLayout
    CoordinatorLayout继承自android.view.ViewGroup
    1、作为顶层布局,是一个Framelayout的加强版
    2、调度协调子布局,监听子控件,调节子控件
    CoordinatorLayout通过设置 子View 的 Behaviors来调度子View。
  • 关于layout_behavior属性
    可以看到在ViewPager里设置了app:layout_behavior="@string/appbar_scrolling_view_behavior"属性,它的值是android.support.design.widget.AppBarLayout$ScrollingViewBehavior,它就是CoordinatorLayout.Behavior的子类,给这个属性后viewpager就会显示在tablayout
    下方,如果没有指定该属性,那么会显示在AppBarLayout下方,个人猜测因为CoordinateLayout
    是一个加强版的framlayout,AppBarLayout后添加进CoordinateLayout里,所以才把ViewPager遮掉了
  • 关于AppBarLayout
    AppBarLayout 是继承LinerLayout实现的一个ViewGroup容器组件,它支持手势滑动操作,
    通过app:layout_scrollFlags属性来控制滚动时候的表现,当AppBarLayout接收到滚动事件,其
    内部的view就会根据该属性来改变自己,app:layout_scrollFlags="scroll|enterAlways"表示当布局
    向下滚动时隐藏(enterAlways)自身,当布局向上滚动时显示自身(scroll),这里有个细节,就是不管
    AppBarLayout放在哪里,最后都是在顶部

  • 关于Toolbar
    继承自android.widget.LinearLayout
    api描述:
    A standard toolbar for use within application content.
    一个标准的Toolbar是用来给应用展示内容的
    A Toolbar is a generalization of action bars for use within application layouts. While an action bar is traditionally
    Toolbar是应用程序布局里的Actionbar的一个扩展,虽然Actionbar通常
    part of an Activity's opaque window decor controlled by the framework, a Toolbar may be placed at any arbitrary
    作为不透明的Activity窗体装饰的一部分并且被framework控制,但是Toolbar却可以放在任意
    level of nesting within a view hierarchy. An application may choose to designate a Toolbar as the action bar for an
    级别的view结构中,应用程序可以用Toolbar来代替Actionbar,
    Activity using the setActionBar() method.
    通过setActionBar方法
    Toolbar supports a more focused feature set than ActionBar. From start to end, a toolbar may contain a
    Toolbar支持更多了主要特性,从开始到结束,Toolbar会包含以下
    combination of the following optional elements:
    几中元素的组合

A navigation button.
一个导航按钮

A branded logo image.
一个Logo图标

One or more custom views.
一个或者多个自定义view
An action menu.
一个菜单

  • 关于TabLayout
    继承自android.widget.HorizontalScrollView
    api描述:
    TabLayout provides a horizontal layout to display tabs
    提供了水平布局展示tab

第四步,修改MainActivity找到控件初始化控件

public class MainActivity extends AppCompatActivity {    private TabLayout tablayout;    private ViewPager viewpager;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main2);        tablayout = (TabLayout) findViewById(R.id.tablayout);        viewpager = (ViewPager) findViewById(R.id.viewpager);//viewpager里填充3个fragment        initView();    }    private void initView() {        ArrayList data = new ArrayList();//定义list装载fragment        BaseFragment fragmentA = new BaseFragment();//第一个fragment        BaseFragment fragmentB = new BaseFragment();        BaseFragment fragmentC = new BaseFragment();        data.add(fragmentA);        data.add(fragmentB);        data.add(fragmentC);                FragmentManager fm = getSupportFragmentManager();        MyAdapter adapter = new MyAdapter(data,fm);        viewpager.setAdapter(adapter);                tablayout.setupWithViewPager(viewpager);//把viewpager和tablayout关联        tablayout.getTabAt(0).setText("A");        tablayout.getTabAt(1).setText("B");        tablayout.getTabAt(2).setText("C");    }    //一个FragmentPagerAdapter,每个ViewPager页面都是Fragment    class MyAdapter extends FragmentPagerAdapter{        ArrayList data;        public MyAdapter(ArrayList data,FragmentManager fm) {            super(fm);            this.data = data;            Log.i("data size", data.size()+"");        }          @Override        public Fragment getItem(int pos) {            return data.get(pos);        }        @Override        public int getCount() {            return data.size();        }    }

BaseFragment代码

public class BaseFragment extends Fragment {    private RecyclerView mRecyclerView;    public BaseFragment() {    }    @Override    @Nullable    public View onCreateView(LayoutInflater inflater,            @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {        View view = inflater.inflate(R.layout.layout_fragment, null);        mRecyclerView = (RecyclerView) view.findViewById(R.id.recycler);        initRecyclerView();        return view;    }        private void initRecyclerView() {        String[] data = new String[]{"a","sss","aaa","dsfsdf","sdfsdfsd","dfsdfsf",                "a","sss","aaa","dsfsdf","sdfsdfsd","dfsdfsf",                "a","sss","aaa","dsfsdf","sdfsdfsd","dfsdfsf",                "a","sss","aaa","dsfsdf","sdfsdfsd","dfsdfsf",                "a","sss","aaa","dsfsdf","sdfsdfsd","dfsdfsf"        };        RecyclerAdapter adapter = new RecyclerAdapter(data);//创建RecyclerAdapter对象        LinearLayoutManager layoutManager = new LinearLayoutManager(getContext());//        layoutManager.setOrientation(LinearLayoutManager.VERTICAL);        mRecyclerView.setLayoutManager(layoutManager);//为RecyclerView设置布局管理器        mRecyclerView.setAdapter(adapter);    }}

layout_fragment代码

<?xml version="1.0" encoding="utf-8"?>            

RecyclerAdapter 代码

public class RecyclerAdapter extends RecyclerView.Adapter{        private String[] data = null;//传经来的要显示数据        public RecyclerAdapter(String[] data) {        this.data = data;    }        class ViewHolder extends RecyclerView.ViewHolder {        TextView tv_data;        public ViewHolder(View view) {            super(view);            //找到控件id            tv_data = (TextView) view.findViewById(R.id.tv_data);        }    }    @Override    public int getItemCount() {        Log.e("data count", data.length+"");        return data.length;    }    @Override    public void onBindViewHolder(ViewHolder holder, int position) {        //根据传入的holder,为viewholder设置数据        String str = data[position];        holder.tv_data.setText(str);    }    @Override    public ViewHolder onCreateViewHolder(final ViewGroup parent, int position) {        //返回一个viewholder,创建一个布局        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.layout_recycler_item, parent,false);        ViewHolder viewHolder = new ViewHolder(view);                // 在此处注册点击事件,和Listview不同        view.setOnClickListener(new OnClickListener() {                        @Override            public void onClick(View arg0) {                Toast.makeText(parent.getContext(), "click", Toast.LENGTH_SHORT).show();            }        });        return viewHolder;    }}

涉及到的layout_recycler_item代码

    <?xml version="1.0" encoding="utf-8"?>                

更多相关文章

  1. android学习小结3-各种控件使用方式DEMO
  2. Android开发开发技巧之 EditText 属性大全
  3. TextView属性
  4. android编辑布局文件时非要降低api level或者更改主题才能显示布
  5. Android 线性布局:LinearLayout
  6. Android学习笔记-Android非布局activity中布局文件及控件加载方

随机推荐

  1. android 导出jar包并使用
  2. Android中intent如何传递自定义数据类型
  3. Android开发_精准排布控件位置
  4. Android 图片Bitmap的剪切
  5. Debug Android and Linux suspend and re
  6. android webview里设置cookie
  7. android 动画分类
  8. Android:Service:AIDL实现进程通信
  9. Android子线程其实也可以刷新UI。。。。
  10. JDK ANT ANDROID Configure