如图是效果图

当  点击下面 不同 的按钮 进入 不同的界面

其中 要一个 主布局当做容器 , 和3个不同的 布局来对应下面的3个按钮界面

主程序的 代码和布局如下

 import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentTransaction;
import android.view.View;
import android.widget.Button; import com.example.huanshop.activity.R;
import com.example.huanshop.activity.main.MyShopFragment;
import com.example.huanshop.base.BaseFragmentActivity; public class ProducteTimeLimit extends BaseFragmentActivity {
private int index;
// 当前fragment的index
private int currentTabIndex;
private TimeLimitShopFragment timeLimitShop;
private TimeLimitQiangShop timeLimitQiangShop;
private MyShopFragment myShopFragment;
private Fragment[] fragments;
private Button[] btnTabs; @Override
protected void setContentView() {
// TODO Auto-generated method stub
setContentView(R.layout.timeshop);
} @Override
protected void setFindViewById() {
// TODO Auto-generated method stub
btnTabs = new Button[3];
btnTabs[0] = (Button) findViewById(R.id.timelimited);
btnTabs[1] = (Button) findViewById(R.id.lastshop);
btnTabs[2] = (Button) findViewById(R.id.brandshop);
// 把第一个设置成默认选中状态
btnTabs[0].setSelected(true); } @Override
protected void setControll() {
// TODO Auto-generated method stub
timeLimitShop = new TimeLimitShopFragment();
timeLimitQiangShop = new TimeLimitQiangShop();
myShopFragment = new MyShopFragment();
fragments = new Fragment[] { timeLimitShop, timeLimitQiangShop,
myShopFragment };
// 添加显示第一个fragment
getSupportFragmentManager().beginTransaction()
.add(R.id.timeshopfragment, timeLimitShop)
.add(R.id.timeshopfragment, timeLimitQiangShop)
.add(R.id.timeshopfragment, myShopFragment)
.hide(timeLimitQiangShop).hide(myShopFragment)
.hide(myShopFragment).show(timeLimitShop).commit();
} @Override
protected void setListener() {
// TODO Auto-generated method stub } public void onTabClicked(View view) {
switch (view.getId()) {
case R.id.timelimited:
index = 0;
break;
case R.id.lastshop:
index = 1;
break;
case R.id.brandshop:
index = 2;
break;
}
if (currentTabIndex != 0) {
btnTabs[0].setSelected(false);
}
if (currentTabIndex != index) {
FragmentTransaction trx = getSupportFragmentManager()
.beginTransaction();
trx.hide(fragments[currentTabIndex]); if (!fragments[index].isAdded()) {
trx.add(R.id.timeshopfragment, fragments[index]);
}
trx.show(fragments[index]).commit();
}
btnTabs[currentTabIndex].setSelected(false);
// 把当前tab设为选中状态
btnTabs[index].setSelected(true);
currentTabIndex = index;
} }

主代码的布局文件

 <?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
style="@style/all_layout_style" > <LinearLayout
android:id="@+id/timebtton1"
android:layout_width="match_parent"
android:layout_height="60dp"
android:layout_alignParentBottom="true"
android:background="@color/bottom_bar_normal_bg"
android:gravity="center_vertical"
android:orientation="vertical" > <View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="#999999" /> <LinearLayout
android:id="@+id/main_bottom"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/bottom_bar_normal_bg"
android:gravity="center_vertical"
android:orientation="horizontal" > <RelativeLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1" > <Button
style="@style/main_btn"
android:id="@+id/timelimited"
android:clickable="true"
android:drawableTop="@drawable/tab_home_bg"
android:text="限时购" />
</RelativeLayout> <RelativeLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1" > <Button
style="@style/main_btn"
android:id="@+id/lastshop"
android:drawableTop="@drawable/tab_classify_bg"
android:text="最后疯抢" />
</RelativeLayout> <RelativeLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1" > <Button
style="@style/main_btn"
android:id="@+id/brandshop"
android:drawableTop="@drawable/tab_classify_bg"
android:text="品牌促销" />
</RelativeLayout>
</LinearLayout>
</LinearLayout>
<!-- --> <RelativeLayout
android:id="@+id/timeshopfragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_above="@id/timebtton1" >
</RelativeLayout> </RelativeLayout>

其中3个fragment这里值给出一个

 import java.util.List;

 import com.android.http.LoadControler;
import com.android.http.RequestManager;
import com.android.http.RequestManager.RequestListener;
import com.example.huanshop.activity.R;
import com.example.huanshop.activity.main.HomeFragment;
import com.example.huanshop.adapter.ProducteTimeAdapter;
import com.example.huanshop.entity.Product;
import com.example.huanshop.util.HttpUtil;
import com.example.huanshop.widget.MyListView;
import com.google.gson.Gson;
import com.google.gson.reflect.TypeToken;
import com.nostra13.universalimageloader.core.ImageLoader;
import com.nostra13.universalimageloader.core.ImageLoaderConfiguration; import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.Toast; public class TimeLimitQiangShop extends Fragment implements RequestListener {
private MyListView listView;
private ProducteTimeAdapter listAdapter;
private List<Product> products;
private LoadControler load;
private ImageLoader loader;
private String urlString = HttpUtil.BASEURL + "Product/GetByIsSpecial/4"; @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// TODO Auto-generated method stub
return inflater.inflate(R.layout.producttimeqiang, container, false);
} @Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
setFindViewById();
setListener();
setControll();
} private void setFindViewById() {
// TODO Auto-generated method stub
loader = ImageLoader.getInstance();
loader.init(ImageLoaderConfiguration.createDefault(getActivity()));
listView = (MyListView) getActivity().findViewById(R.id.timeqiang);
} private void setControll() {
// TODO Auto-generated method stub
load = RequestManager.getInstance().get(urlString, this, 2);
} private void setListener() {
// TODO Auto-generated method stub
listView.setOnItemClickListener(new OnItemClickListener() { @Override
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
// TODO Auto-generated method stub
HomeFragment.kucun = products.get(position).getKucun() + "";
HomeFragment.Title = products.get(position).getTitle();
HomeFragment.SmallPic = products.get(position).getSmallPic();
HomeFragment.Contens = products.get(position).getContens();
HomeFragment.Price = products.get(position).getPrice() + "";
HomeFragment.SalePrice = products.get(position).getSalePrice()
+ "";
HomeFragment.BuyCount = products.get(position).getBuyCount()
+ "";
HomeFragment.producteId = products.get(position).getId() + "";
Intent intent = new Intent(getActivity(),
ProducteDetailsActivity.class);
// intent.putExtra("positon", position);
startActivity(intent);
}
});
} @Override
public void onError(String arg0, String arg1, int arg2) {
// TODO Auto-generated method stub } @Override
public void onRequest() {
// TODO Auto-generated method stub } @Override
public void onSuccess(String arg0, String arg1, int arg2) {
// TODO Auto-generated method stub
switch (arg2) {
case 2:
products = new Gson().fromJson(arg0,
new TypeToken<List<Product>>() {
}.getType());
if (products.size() == 0) {
Toast.makeText(getActivity(), "没有产品", 1000).show();
} else {
listAdapter = new ProducteTimeAdapter(getActivity(), products);
listView.setAdapter(listAdapter);
listAdapter.notifyDataSetChanged();
}
}
}
}

FragmentActivity的简单使用的更多相关文章

  1. 简单研究Loader笔记

    2015-11-11 18:25:34 1. Loader是什么? /** * Static library support version of the framework's {@link and ...

  2. TabLayout 简单使用。

    先上效果图 在使用TabLayout 之前需要导入design包. 我使用的是android studio 只要在build.gradle中加入 compile 'com.android.suppor ...

  3. android FragmentActivity+FragmentTabHost+Fragment框架布局

    这周比较闲,计划系统的学习一下android开发,我本是一名IOS程序员,对手机开发还是有自己的一套思路的, 固这套思路用到我当前学android上了,先选择从Main页面的tabbar部分代码入手, ...

  4. 【Android UI设计与开发】4.底部菜单栏(一)Fragment介绍和简单实现

    TabActivity在Android4.0以后已经被完全弃用,取而代之的是Fragment.Fragment是Android3.0新增的概念,Fragment翻译成中文是碎片的意思,不过却和Acti ...

  5. ☆ fragment和fragmentactivity解析 (转)

    一.为什么要使用Fragment  1.当我们需要动态的多界面切换的时候,就需要将UI元素和Activity融合成一 个模块.在2.3中我们一般通过各种Activity中进行跳转来实现多界面的跳转和单 ...

  6. 【原创】StickHeaderListView的简单实现,解决footerView问题

    1.前言: 前几天用了GitHub上se.emilsjolander.stickylistheaders这个组件,然后发现这个组件的listview不能添加footerView,加了footer后,滑 ...

  7. Android FragmentActivity+viewpager的使用

    使用场景,打算设计一个“底部菜单栏+其余可滑动的页面”的简单的功能. package com.lanyuweng.mibaby; import android.content.Intent; impo ...

  8. Android Fragment 简单实例

    Android上的界面展示都是通过Activity实现的.Activity实在是太经常使用了.我相信大家都已经很熟悉了,这里就不再赘述. 可是Activity也有它的局限性,相同的界面在手机上显示可能 ...

  9. Fragment的简单使用

    最近一直有点忙,刚刚看到一个朋友的留言提到Fragment中加载ListView的问题,这里写了一个非常简单的测试,至于对Fragment的增.删.改实现动态布局构建灵活的UI,以后有时间在讨论: M ...

随机推荐

  1. C++_基础6-名称空间

    名称空间 背景:C++中,名称可以是变量.函数.结构.枚举.类以及类和结构的成员.当随着项目的增大,名称相互冲突的可能性也将增加.例如许多厂商的类库,可能导致名称冲突.这种冲突被称为名称空间问题. 解 ...

  2. 关于strcmp函数的用法

    strcmp函数是在string.h库下的han函数, 具体用法如下: strcmp函数是用来比较2个字符串的函数,如srcmp(字如果符串1,字符串2),从第一个字符开始比较,如果到最后两个字符串完 ...

  3. 找出数组中的最小值(es5/es6)

    1.命令式编程,只需要迭代数组,检查当前最小值是否大于数组元素,如果是更新最小值即可. var s = [2,3,4,5,6,7,8]; for(var i=0,m=s.length;i<m;i ...

  4. 划分型博弈型dp

    划分型动态规划: 513. Perfect Squares https://www.lintcode.com/problem/perfect-squares/description?_from=lad ...

  5. C++ GUI Qt4编程(05)-2.2GoToCell

    1. 使用Qt设计师创建GoToCell对话框. 2. gotocelldialog.cpp #include <QRegExp> #include "gotocelldialo ...

  6. git撤销commit,但未git push的命令

    在git push的时候,有时候我们会想办法撤销git commit的内容 1.找到之前提交的git commit的id git log 找到想要撤销的id 2.git reset –hard id ...

  7. 《The Python Standard Library》——http模块阅读笔记2

    http.server是用来构建HTTP服务器(web服务器)的模块,定义了许多相关的类. 创建及运行服务器的代码一般为: def run(server_class=HTTPServer, handl ...

  8. maven 引入本地 jar

    $ 参考1 : https://www.cnblogs.com/lixuwu/p/5855031.html ! 注: 参考1中的第二种方法,作者并未实际尝试,我尝试了,虽然在eclipse 中编译不报 ...

  9. layer弹出层显示在top顶层

    父页面 导入 layer.js 或者 layui.all.js,导入后就能正常显示在父窗口页面区域. 1.显示在顶层窗口 top.layer.open({ type: 2, area: ['98%', ...

  10. 使用JavaFX打开fxml,找不到打开的图形界面

    解决方案: 将 HKEY_CURRENT_USER\Software\JavaSoft\Prefs\com\oracle\javafx\scenebuilder\app\preferences\/S/ ...