前言

在前面的博客写到我针对一个项目完成了动态布局的效果,顿时感觉很爽,那么下面我针对我在前文中所讲的tabhost的实现做出一个新的方法,tabhost基本已经被启用,现在基本使用Fragment与viewpage进行实现相同的功能,在园子里有很多这样的博客,现在我在这里呢,继续是参考了一些博客进行了一些总结!

原因:在加载过程中,你会发现使用tabhost的内存资源比fragment大得多,因此我没有很多的安卓的截图的原因在于我一直使用真机做开发,这样虽然在博客园上很少能够图文并茂,但也使开发的安卓软件是真实可靠的,当然我没有任何对使用虚拟机开发的人有任何意见。

特别是现在我完全使用android studio进行开发,虽然这个IDE,我自己也不太熟悉,但是使用这个IDE还是相当之方便的!还能看内存的使用情况

Fragment简介

好了,回归正途了,我们今天要讨论的是传说中Fragment,这玩意可以做好多事,就像我们的Activity一样,只要继承这个类就能激发其各种能力!说说Fragment的实质吧

Fragment自Android3.0引入的API,可以将其看作是Activity的子模块,其英文翻译是就是片段的意思!

使用fragment的布局文件

main_activity.xml

在这里,我需要规定我使用的viewpage的局域与我使用的相当于tabhost的按键布局文件

   <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:background="#f0f3f5"
android:orientation="vertical"
> <android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
>
</android.support.v4.view.ViewPager>
<include layout="@layout/bottom"
/>
</LinearLayout>

include layout="@layout/bottom"表示我包含了一个叫bottom的layout文件

先看这个布局的效果图!

在这里,我们可以知道上面的

那么bottom这个文件咋么写呢?在这里我还更改了button的样式,让页面更加好看!

   <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="98px"
android:orientation="horizontal"
android:layout_gravity="center"
android:background="#ffffff"
android:layout_alignParentBottom="true"
android:id="@+id/tab"
>
<LinearLayout
android:id="@+id/tab_home"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:layout_weight="1"
android:clickable="true" >
<RadioButton
android:gravity="center"
android:id="@+id/btnhometab"
android:layout_width="match_parent"
android:layout_height="match_parent"
style="@style/Widget.AppCompat.ActionButton"
android:checked="true"
android:button="@null"
android:text="首页"
android:textSize="10sp"
android:drawableTop="@drawable/tab_home"
android:textColor="@drawable/tab_text_color"
android:clickable="false"
/>
</LinearLayout>
<LinearLayout
android:id="@+id/tab_activity"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:layout_weight="1"
android:clickable="true"
>
<RadioButton
android:gravity="center"
android:id="@+id/btnactivitytab"
android:layout_width="match_parent"
android:layout_height="match_parent"
style="@style/Widget.AppCompat.ActionButton"
android:checked="true"
android:button="@null"
android:text="活动"
android:textSize="10sp"
android:drawableTop="@drawable/tab_activity"
android:textColor="@drawable/tab_text_color"
android:clickable="false"
/>
</LinearLayout>
<LinearLayout
android:id="@+id/tab_me"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:layout_weight="1"
android:clickable="true"
>
<RadioButton
android:gravity="center"
android:id="@+id/btnmetab"
android:layout_width="match_parent"
android:layout_height="match_parent"
style="@style/Widget.AppCompat.ActionButton"
android:checked="true"
android:button="@null"
android:text="我"
android:textSize="10sp"
android:drawableTop="@drawable/tab_me"
android:textColor="@drawable/tab_text_color"
android:clickable="false"
/>
</LinearLayout>
</LinearLayout>

我们来看一下效果图:

在这里我们可以看到我将button的styke样式改成了actionButton样式,当然,还有一点要注意的是我将linearout做为了点击事件,而底下的radiobutton使之触发效果失效(android:clickable="false")这样可以使没点到图片只要在这个区域内便可以实现点击事件在textcolor这个属性我又设置了

fragment配合viewpage实现tabhost外加活动功能!

我们先来看一下我所相匹配的mainactivity文件

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.view.Window;
import android.widget.LinearLayout;
import android.widget.RadioButton; import java.util.ArrayList;
import java.util.List; public class MainActivity extends android.support.v4.app.FragmentActivity { /******
*各类声明
*/
private ViewPager viewPager; private FragmentPagerAdapter pagerAdapter;
private List<Fragment> fragments; private LinearLayout homeTab;
private LinearLayout activityTab;
private LinearLayout meTab; private RadioButton homeRbtn;
private RadioButton activityRbtn;
private RadioButton meRbtn; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main);
GetView();//你可以先将其注释掉
initView();
initEvent();
setSelect(0);
}
/*****
* 动态布局实现 请参考我写的动态布局
*/
private void GetView(){
Autosize autosize = new Autosize();
// 获取实际的屏幕宽度
autosize.setScreensize(autosize.Metricwidth(this));
LinearLayout bottom = (LinearLayout) findViewById(R.id.tab);
autosize.llinearlayoutheight(98,bottom);
}
/******
* famage 处理
*
*/
private void initView() { viewPager = (ViewPager) findViewById(R.id.viewpager); //bottom的tab linearlayout id
homeTab = (LinearLayout) findViewById(R.id.tab_home);
activityTab = (LinearLayout) findViewById(R.id.tab_activity);
meTab = (LinearLayout) findViewById(R.id.tab_me); homeRbtn = (RadioButton) findViewById(R.id.btnhometab);
activityRbtn = (RadioButton) findViewById(R.id.btnactivitytab);
meRbtn = (RadioButton) findViewById(R.id.btnmetab); fragments = new ArrayList<Fragment>();
//添加tab
fragments.add(new FragmentHome());
fragments.add(new FragmentActivity());
fragments.add(new FragmentMe());
//相应的适配器
pagerAdapter = new FragmentPagerAdapter(getSupportFragmentManager()) { @Override
public android.support.v4.app.Fragment getItem(int position) {
return fragments.get(position);
} @Override
public int getCount() {
return fragments.size();
}
};
// 绑定适配器
viewPager.setAdapter(pagerAdapter);
viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override
public void onPageSelected(int position) {
int currentItem = viewPager.getCurrentItem();
setTab(currentItem);
} @Override
public void onPageScrollStateChanged(int state) {
}
});
}
//设置事件
private void initEvent(){
View.OnClickListener listener = new View.OnClickListener() {
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.tab_home:
setSelect(0);
break;
case R.id.tab_activity:
setSelect(1);
break;
case R.id.tab_me:
setSelect(2);
break;
default:
break; }
}
};
homeTab.setOnClickListener(listener);
activityTab.setOnClickListener(listener);
meTab.setOnClickListener(listener); } private void setTab(int i){
resetbtn();
// 切换内容区域
switch (i)
{
case 0:
homeRbtn.setChecked(true);
break;
case 1:
activityRbtn.setChecked(true);
break;
case 2:
meRbtn.setChecked(true);
break;
} }
private void setSelect(int i){
viewPager.setCurrentItem(i);
setTab(i);
} private void resetbtn(){
homeRbtn.setChecked(false);
activityRbtn.setChecked(false);
meRbtn.setChecked(false);
} }

相信大家对此有了一定的了解,我是通过radiobutton的不同状态来确定更改的颜色的!

tab_text_color.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_checked="true" android:color="#64c32f"/>
<!-- not selected -->
<item android:state_checked="false" android:color="#000000"/>
</selector>

tab_me.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:state_checked="false"
android:drawable="@drawable/firsttab2"/>
<item
android:state_checked="true"
android:drawable="@drawable/firsttab" />
</selector>

通过这两个xml文件,我做了相应的效果!

后记

后面我将写一篇有关百度定位最新版本的使用博客,如果你喜欢我写的博客呢!求关注!

android开发学习笔记系列(5)--fragment与viewpage的更多相关文章

  1. android开发学习笔记系列(1)-android起航

    前言 在学习安卓的过程中,我觉得非常有必要将自己所学的东西进行整理,因为每每当我知道我应该是如何去实现功能的时候,有许多细节问题我总是会遗漏,因此我也萌生了写一系列博客来描述自己学习的路线,让我的an ...

  2. android开发学习笔记系列(2)-android应用界面编程

    前言 本篇博客将会简要介绍andriod开发过程中的一些界面元素和编程的实现,我将大家走进安卓的XML世界,当然可能会涉及到java代码,当然本文主要是介绍XML文件的界面布局. 那么我们的XML存在 ...

  3. android开发学习笔记系列(4)--android动态布局

    前言 在做一个有关苏果APP的项目中,但是fuck的是,我完全使用相对布局之后及线性布局之后发现坑爹的事情了,屏幕不能适配,这是多大的痛,意味着,必须使用相应的代码实现动态布局!呵呵,不做项目不知道, ...

  4. android开发学习笔记系列(6)--代码规范

    在开发android的时候,我对自己写的代码很是不满,原因在于自己看到别人的代码,很是头痛,原因很简单,别人写的代码,我就要去猜他的意思,极其烦恼,嗯,就是他没有遵循代码规范,因此我在博客园上寻找一篇 ...

  5. android开发学习笔记系列(3)--ScrollView与HorizontalScrollView

    ScrollView与HorizontalScrollView 这是一个滚动视图,就是说如果你在你的UI中容不下那么多的内容,且你对自己的UI都已经设置好了px,OK,那么在适应屏幕过程中,我们并不希 ...

  6. android开发学习笔记000

    使用书籍:<疯狂android讲义>——李刚著,2011年7月出版 虽然现在已2014,可我挑来跳去,还是以这本书开始我的android之旅吧. “疯狂源自梦想,技术成就辉煌.” 让我这个 ...

  7. 步步为营 SharePoint 开发学习笔记系列总结

    转:http://www.cnblogs.com/springyangwc/archive/2011/08/03/2126763.html 概要 为时20多天的sharepoint开发学习笔记系列终于 ...

  8. 【转】Android开发学习笔记(一)——初识Android

    对于一名程序员来说,“自顶向下”虽然是一种最普通不过的分析问题和解决问题的方式,但其却是简单且较为有效的一种.所以,将其应用到Android的学习中来,不至于将自己的冲动演变为一种盲目和不知所措. 根 ...

  9. Android开发学习笔记DDMS的使用

    打开DDMS DDMS 的全称是Dalvik Debug Monitor Service,是 Android 开发环境中的Dalvik虚拟机调试监控服务. DDMS里面包含了:Device(设备) F ...

随机推荐

  1. hadoop一代集群运行代码案例

    hadoop一代集群运行代码案例 集群 一个 master,两个slave,IP分别是192.168.1.2.192.168.1.3.192.168.1.4               hadoop版 ...

  2. MapReduce编程解析

    MapReduce编程模型之案例 wordcount 输入数据 atguigu atguiguss sscls clsjiaobanzhangxuehadoop 输出数据 atguigu 2banzh ...

  3. codeforce 489d bfs分层处理

    这个题确实没想到用bfs进行分层处理,后来看到了大佬的题解之后才想到了这一点 bfs dfs早就学了,可是还是不大会应用到这上面 可以分为三层,起始点,中间点,尾点,需要的数据是中间点到尾点的访问次数 ...

  4. 学习JavaScript计划

    1.首先根据视频做小例子 2.每天记录到博客 3.这次坚持把这个学完,并完成接口测试界面的编写

  5. Java框架知识点总结

    一.Struts1的运行原理 在启动时通过前端总控制器ActionServlet加载struts-config.xml并进行解析,当用户在jsp页面发送请求被struts1的核心控制器ActionSe ...

  6. Linux Buffer/Cache 的区别

      以前经常使用free -h命令来查看当前操作系统的内存使用情况,同时也注意过返回信息中有一列是buff/cache,来公司之前,面试官还问过我这两个的区别,当时没有回答出来,现在特意回顾记录下: ...

  7. spark Graph 的PregelAPI 理解和使用

    spark Graph 的PregelAPI 理解和使用 图本质上是一种递归的数据结构,可以使用Spark GraphX 的PregelAPI接口对图数据进行批量计算, 之前一直不怎么理解Pregel ...

  8. JS通过ClassName禁止DIV点击

    //通过ClassName获取div,使用setAttribute设置div禁止点击 var itemRoom= document.getElementsByClassName("page- ...

  9. C# 不添加WEB引用调用WSDL接口

    在项目中添加WEB引用耦合度较高,更新时要更新引用,所以我建议不添加WEB引用调用WSDL接口,废话不多说,直接上代码 例如WSDL地址为:http://XXX.XX.XXX.XXX:9115/WsP ...

  10. Python 绝技 —— TCP服务器与客户端

    i春秋作家:wasrehpic 0×00 前言 「网络」一直以来都是黑客最热衷的竞技场.数据在网络中肆意传播:主机扫描.代码注入.网络嗅探.数据篡改重放.拒绝服务攻击……黑客的功底越深厚,能做的就越多 ...