viewpager+将activity转化成view 做主界面(可点击可滑动,超容易理解的demo)_localactivitymanager demo-程序员宅基地

技术标签: 【Android】  android  viewpager  

笔者之前已经做过了一个使用viewpgaer轮播效果的博客,但是viewpager本身也是深受androider的喜爱,如今基本每个app都会用到相关的功能,本篇文章也是讲一下用viewpager做主界面的用法。(笔者对viewpager的学习也是比较曲折,网上各种找不到符合自己功能的代码)


笔者之后又学习了viewpager+fragment的使用,地址为:http://blog.csdn.net/double2hao/article/details/50450377


主要功能:(源码在文章最后)

1、滑动的同时改变标题栏

2、点击标题栏的同时滑动


效果:

     


主要文件:

      


MainActivity:

import android.app.Activity;
import android.app.LocalActivityManager;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageView;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends Activity {

    //控件
    private ImageView img1, img2, img3, img4;
    private ViewPager vp;

    //LocalActivityManager用来获取每个activity的view,放于Adapter中
    //MyViewPageAdapter用来放viewpager的内容
    //OnClickListener设置底部图片的点击事件
    //OnPageChangeListener设置图片的滑动事件
    private LocalActivityManager manager;
    private MyViewPageAdapter viewPageAdapter;
    private OnClickListener clickListener;
    private OnPageChangeListener pageChangeListener;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        manager = new LocalActivityManager(this, true);
        manager.dispatchCreate(savedInstanceState);

        vp = (ViewPager) findViewById(R.id.viewpager);
        InitView();
    }


    private void InitView() {
        // TODO Auto-generated method stub
        img1 = (ImageView) findViewById(R.id.main_img1);
        img2 = (ImageView) findViewById(R.id.main_img2);
        img3 = (ImageView) findViewById(R.id.main_img3);
        img4 = (ImageView) findViewById(R.id.main_img4);
        clickListener = new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub

                switch (v.getId()) {
                    case R.id.main_img1:
                        vp.setCurrentItem(0);
                        break;
                    case R.id.main_img2:
                        vp.setCurrentItem(1);
                        break;
                    case R.id.main_img3:
                        vp.setCurrentItem(2);
                        break;
                    case R.id.main_img4:
                        vp.setCurrentItem(3);
                        break;
                }
            }
        };

        img1.setOnClickListener(clickListener);
        img2.setOnClickListener(clickListener);
        img3.setOnClickListener(clickListener);
        img4.setOnClickListener(clickListener);
        InitPager();

    }

    private void InitPager() {
        // TODO Auto-generated method stub
        pageChangeListener = new OnPageChangeListener() {
            @Override
            public void onPageSelected(int arg0) {
                // TODO Auto-generated method stub
                switch (arg0) {
                    case 0:
                        img1.setImageResource(R.drawable.main_icon1_1);
                        img2.setImageResource(R.drawable.main_icon2_2);
                        img3.setImageResource(R.drawable.main_icon3_2);
                        img4.setImageResource(R.drawable.main_icon4_2);
                        break;
                    case 1:
                        img1.setImageResource(R.drawable.main_icon1_2);
                        img2.setImageResource(R.drawable.main_icon2_1);
                        img3.setImageResource(R.drawable.main_icon3_2);
                        img4.setImageResource(R.drawable.main_icon4_2);
                        break;
                    case 2:
                        img1.setImageResource(R.drawable.main_icon1_2);
                        img2.setImageResource(R.drawable.main_icon2_2);
                        img3.setImageResource(R.drawable.main_icon3_1);
                        img4.setImageResource(R.drawable.main_icon4_2);
                        break;
                    case 3:
                        img1.setImageResource(R.drawable.main_icon1_2);
                        img2.setImageResource(R.drawable.main_icon2_2);
                        img3.setImageResource(R.drawable.main_icon3_2);
                        img4.setImageResource(R.drawable.main_icon4_1);
                        break;
                }
            }

            @Override
            public void onPageScrolled(int arg0, float arg1, int arg2) {
                // TODO Auto-generated method stub

            }

            @Override
            public void onPageScrollStateChanged(int arg0) {
                // TODO Auto-generated method stub

            }
        };

        AddActivitiesToViewPager();
        vp.setCurrentItem(0);
        vp.setOnPageChangeListener(pageChangeListener);
    }

    private void AddActivitiesToViewPager() {
        List<View> mViews = new ArrayList<View>();
        Intent intent = new Intent();

        intent.setClass(this, Activity_one.class);
        intent.putExtra("id", 1);
        mViews.add(getView("QualityActivity1", intent));

        intent.setClass(this, Activity_two.class);
        intent.putExtra("id", 2);
        mViews.add(getView("QualityActivity2", intent));

        intent.setClass(this, Activity_three.class);
        intent.putExtra("id", 3);
        mViews.add(getView("QualityActivity3", intent));

        intent.setClass(this, Activity_four.class);
        intent.putExtra("id", 4);
        mViews.add(getView("QualityActivity4", intent));

        viewPageAdapter = new MyViewPageAdapter(mViews);
        vp.setAdapter(viewPageAdapter);

    }

    private View getView(String id, Intent intent) {
        return manager.startActivity(id, intent).getDecorView();

    }

}

MyViewPagerAdapter:

import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;

import java.io.Serializable;
import java.util.List;

public class MyViewPageAdapter extends PagerAdapter implements Serializable {
    private List<View> views;

    public MyViewPageAdapter(List<View> views) {
        this.views = views;
    }

    @Override
    public int getCount() {
        return views.size();
    }

    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
        return arg0 == arg1;
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView(views.get(position));
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        container.addView(views.get(position), 0);
        return views.get(position);
    }
}

Activity_one:

import android.app.Activity;
import android.os.Bundle;

public class Activity_one extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.layout1);

    }
}

activity_main:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#F5F3F2">

    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_above="@+id/titile" />

    <LinearLayout
        android:id="@+id/titile"
        android:layout_width="match_parent"
        android:layout_height="70dp"
        android:layout_alignParentBottom="true"
        android:background="@drawable/tabbar_bg"
        android:orientation="horizontal">


        <ImageView
            android:id="@+id/main_img1"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:src="@drawable/main_icon1_1" />


        <ImageView
            android:id="@+id/main_img2"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:src="@drawable/main_icon2_2" />


        <ImageView
            android:id="@+id/main_img3"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:src="@drawable/main_icon3_2" />


        <ImageView
            android:id="@+id/main_img4"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:src="@drawable/main_icon4_2" />

    </LinearLayout>

</RelativeLayout>


layout1:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="pager1"
        android:textSize="30sp"/>
</LinearLayout>




android studio源码地址:http://download.csdn.net/detail/double2hao/9328023

如果是使用eclipse的新手,可以将源码下载下来后,将图片抠出来。(不过还是建议赶紧换android studio哦)





版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Double2hao/article/details/50183567

智能推荐

计算机游戏的产生,孩子容易沉迷计算机游戏,原来是因为过程中产生“心流”经验?...-程序员宅基地

文章浏览阅读89次。原标题:孩子容易沉迷计算机游戏,原来是因为过程中产生“心流”经验?孩子容易沉迷计算机游戏,是因为过程中产生心流经验,从而获得满足感。在学习情境中,若也能提供促发心流经验的条件,自然会让孩子学而不倦。有人说:“与其给孩子鱼吃,不如教他钓鱼的技巧。”但有些孩子即使学会了技巧,却对钓鱼没兴趣,甚至恨透了钓鱼,怎么办? 我听过许多中学生,在确认考上大学的那一天,拿起他的书包到淡水河边的桥上,把教科书全部倒..._学了计算机还会迷游戏吗

DANN:Domain-Adversarial Training of Neural Networks_域分类器的误差和损失-程序员宅基地

文章浏览阅读2.2w次,点赞12次,收藏74次。DANN原理理解DANN中源域和目标域经过相同的映射来实现对齐。DANN的目标函数分为两部分:1. 源域分类损失项2. 源域和目标域域分类损失项1.源域分类损失项对于一个m维的数据点X,通过一个隐含层Gf,数据点变为D维: 然后经过一个分类层Gy得到分类结果: 这个点的源域分类损失定义为: ..._域分类器的误差和损失

DEDECMS织梦提示Fatal error: Call to a member错误怎么解决?_fatalthrowableerror in commoncontroller.php line 3-程序员宅基地

文章浏览阅读87次。DEDECMS织梦提示Fatal error: Call to a member错误怎么解决?在管理目录找到index_top.php,找开在96行找到如下代码:<li><a href="javascript:OpenMenu(10,'','file_manage_main.php?activepath=/templets',10)">模板管理</a></li> 改为: <li><a href="javascrip..._fatalthrowableerror in commoncontroller.php line 32: call to a member functi

Fastlio公式推导(手写)_fast lio pose_lid-程序员宅基地

文章浏览阅读439次,点赞9次,收藏7次。_fast lio pose_lid

mouseover与mouseout,mouseenter与mouseleave;-程序员宅基地

文章浏览阅读103次。而父元素绑定mouseenter和mouseleave事件只对父元素有效,子元素不会触发,即mouseenter和mouseleave事件不会冒泡至父元素。3.在父元素上绑定mouseover和mouseout事件,子元素同样也会触发,即子元素mouseover和mouseout事件会冒泡至父元素;2.mouseover触发优先级高于mouseenter,mouseout触发优先级高于mouseleave;1.mouseover与mouseout,mouseenter与mouseleave;

QPushButton 样式-程序员宅基地

文章浏览阅读1k次。设置按钮的状态, 默认状态, 鼠标滑过状态, 鼠标点击状态,用三张图片分别表示不同的状态 ui->close->setStyleSheet("QPushButton{border-image: url(:/image/close.png);}" "QPushButton:hover{border-image: url(:/image/close2..._qpushbutton 样式

随便推点

mac10.9+php5.5.15+brew0.9.5的安装-程序员宅基地

文章浏览阅读296次。Brew 是 Mac 下面的包管理工具,通过 Github 托管适合 Mac 的编译配置以及 Patch,可以方便的安装开发工具。 Mac 自带ruby 所以安装起来很方便,同时它也会自动把git也给你装上。官方网站: http://brew.sh安装方法:?1ruby -e "$(curl -fsSL http..._mac安装php5.5.9

Mybatis-Plus 实现查询条件为空时不生效_mybatis条件为空不参与判断-程序员宅基地

文章浏览阅读1.8w次,点赞11次,收藏24次。Mybatis-Plus 实现查询条件为空时不生效当我们查询条件中的值不确定是否有空值时,我们期待查询时,Mybatis+能自动帮我们判空。比如这样:this.page( new Query<OperatorsEntity>().getPage(queryFields), new QueryWrapper<OperatorsEntity>() .eq("province_id",queryFields.getProvinceId()) _mybatis条件为空不参与判断

【Ceph】Ceph介绍、原理、架构-程序员宅基地

文章浏览阅读8k次,点赞11次,收藏78次。Ceph技术栈/学习图谱_ceph

为了好玩:二十一点模拟器-程序员宅基地

文章浏览阅读1.1k次。介绍 您是否想过为房屋边缘指定特定的规则集? 你真的可以数卡打败房子吗? 优势到底有多大? 当发牌者显示7时,将硬16击中真的是最好的策略吗? 所有这些以及更多这些都可以通过此VBScript二十一点模拟器得到解答。 插入您要测试的规则,修改基本策略,计数值,指数,下注坡道等。 看看它们如何影响整个房屋的优势! 如何使用 大多数脚本参数都在注释后面脚本顶部的常量定义中。 其余的位于“初始..._21点模拟器

Qt画笔实现折线图-程序员宅基地

文章浏览阅读731次。参考:https://www.cnblogs.com/lsgxeva/p/7821550.html效果图:void BrokenLine::paintEvent(QPaintEvent *event){ // 折线上的点 static QList<QPointF> points = QList<QPointF>() << Q..._qt 中如何画折线图

STC8G1K08------ADC__-程序员宅基地

文章浏览阅读5.3k次,点赞4次,收藏32次。STC8G1K08------ADC_stc8g1k08