Android仿人人客户端(v5.7.1)——消息中心视图的实现

转载请标明出处:http://blog.csdn.net/android_ls/article/details/9411389
声明:仿人人项目,所用所有图片资源都来源于其它Android移动应用,编写本应用的目的在于学习交流,如涉及侵权请告知,我会及时换掉用到的相关图片。

一、人人官方的消息中心截图如下:

        


二、消息中心视图的实现。

        我个人觉得人人官方的消息中心看着怪怪的,不舒服。因此,实现时我稍作修改,具体实现如下:

        1、定义类去继承FrameLayout,源码如下:

package com.everyone.android.ui.message;

import android.util.AttributeSet;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.FrameLayout;

import com.everyone.android.ui.EveryoneActivity;

/**
 * 功能描述:消息中心视图
 * @author android_ls
 */
public class MessageLayout extends FrameLayout implements OnClickListener {

    private EveryoneActivity mActivity;
   
    public MessageLayout(EveryoneActivity activity) {
        super(activity);
        mActivity = activity;

        setupViews();
    }

    public MessageLayout(EveryoneActivity activity, AttributeSet attrs) {
        super(activity, attrs);
        mActivity = activity;

        setupViews();
    }

    private void setupViews() {
        
    }

    @Override
    public void onClick(View v) {

    }

}
    2、在setupViews()方法中, 为其设置布局文件代码如下:

 final LayoutInflater mLayoutInflater = LayoutInflater.from(getContext());
        LinearLayout rootView = (LinearLayout) mLayoutInflater.inflate(R.layout.message, null);
        addView(rootView);
         3、message.xml配置如下:

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

    <com.everyone.android.widget.TopMenuNavbar
        android:id="@+id/rl_top_menu_navbar"
        style="@style/top_navbar" />

    <RadioGroup
        android:id="@+id/rg_message"
        android:layout_width="fill_parent"
        android:layout_height="40dip"
        android:gravity="center_vertical"
        android:orientation="horizontal" >

        <RadioButton
            android:id="@+id/rb_message"
            style="@style/message_radio_button"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="1"
            android:text="消息" />

        <RadioButton
            android:id="@+id/rb_friend"
            style="@style/message_radio_button"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="1"
            android:text="好友申请" />

        <RadioButton
            android:id="@+id/rb_birthday"
            style="@style/message_radio_button"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="1"
            android:text="生日提醒" />
    </RadioGroup>

    <android.support.v4.view.ViewPager
        android:id="@+id/vp_message"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        >
    </android.support.v4.view.ViewPager>

</LinearLayout>

        在styles.xml中添加的样式如下:

 <style name="message_radio_button">
        <item name="android:background">@drawable/v5_0_1_tabsbar_background</item>
        <item name="android:button">@null</item>
        <item name="android:checked">false</item>
        <item name="android:gravity">center</item>
        <item name="android:textColor">#000000</item>
        <item name="android:textSize">14sp</item>
    </style>

       4、在setupViews()方法中,添加的处理代码如下:

// 对顶部的导航栏进行设置
        topMenuNavbar = (TopMenuNavbar) rootView.findViewById(R.id.rl_top_menu_navbar);
        topMenuNavbar.mLlRefresh.setOnClickListener(this);

        topMenuNavbar.tvTitle.setText("消息中心");
        topMenuNavbar.ivDownListIcon.setVisibility(View.GONE);
        topMenuNavbar.ivRefresh.setVisibility(View.GONE);

        // 初始化RadioGroup及相关组件
        rgMessageNavbar = (RadioGroup) rootView.findViewById(R.id.rg_message);
        rbMessage = (RadioButton) rootView.findViewById(R.id.rb_message);
        rbMessage.setChecked(true);
        rbFriend = (RadioButton) rootView.findViewById(R.id.rb_friend);
        rbBirthDay = (RadioButton) rootView.findViewById(R.id.rb_birthday);

        // 初始化ViewPager组件的子视图
        View messageView = mLayoutInflater.inflate(R.layout.message_message, null);
        View friendView = mLayoutInflater.inflate(R.layout.message_friend, null);
        View birthdayView = mLayoutInflater.inflate(R.layout.message_birthday, null);

        ArrayList<View> views = new ArrayList<View>();
        views.add(messageView);
        views.add(friendView);
        views.add(birthdayView);

        // 初始化ViewPager组件,并为其设置数据适配器
        mViewPager = (ViewPager) rootView.findViewById(R.id.vp_message);
        ViewPagerAdapter mPagerAdapter = new ViewPagerAdapter(views);
        mViewPager.setAdapter(mPagerAdapter);
        mViewPager.setCurrentItem(0);

        mViewPager.setOnPageChangeListener(new OnPageChangeListener() {

            public void onPageSelected(int arg0) {

            }

            public void onPageScrolled(int arg0, float arg1, int arg2) {

            }

            public void onPageScrollStateChanged(int arg0) {
                if (arg0 == ViewPager.SCROLL_STATE_IDLE) {
                    switch (mViewPager.getCurrentItem()) {
                    case 0:
                        rbMessage.setChecked(true);
                        break;

                    case 1:
                        rbFriend.setChecked(true);
                        break;

                    case 2:
                        rbBirthDay.setChecked(true);
                        break;
                    }
                }
            }
        });

        rgMessageNavbar.setOnCheckedChangeListener(new OnCheckedChangeListener() {

            public void onCheckedChanged(RadioGroup group, int checkedId) {
                switch (checkedId) {
                case R.id.rb_message:
                    mViewPager.setCurrentItem(0);
                    break;

                case R.id.rb_friend:
                    mViewPager.setCurrentItem(1);
                    break;

                case R.id.rb_birthday:
                    mViewPager.setCurrentItem(2);
                    break;
                }
            }
        });
          5、运行后的效果图如下:

    默认选中消息,效果图如下:



   当前选择“好友申请”,效果图如下:


三、完整源码

    ViewPagerAdapter类的源码如下:

package com.everyone.android.ui.message;

import java.util.ArrayList;

import android.os.Parcelable;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;

/**
 * 功能描述:消息中心视图中ViewPager对象的数据适配器
 * @author android_ls
 */
public class ViewPagerAdapter extends PagerAdapter {

    private ArrayList<View> mViews;

    public ViewPagerAdapter(ArrayList<View> list) {
        this.mViews = list;
    }

    @Override
    public Object instantiateItem(View arg0, int arg1) {
        ((ViewPager) arg0).addView(mViews.get(arg1));
        return mViews.get(arg1);
    }

    @Override
    public void destroyItem(View arg0, int arg1, Object arg2) {
        ((ViewPager) arg0).removeView(mViews.get(arg1));
    }

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

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

    @Override
    public void finishUpdate(View arg0) {
        // TODO Auto-generated method stub

    }

    @Override
    public void restoreState(Parcelable arg0, ClassLoader arg1) {
        // TODO Auto-generated method stub

    }

    @Override
    public Parcelable saveState() {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public void startUpdate(View arg0) {
        // TODO Auto-generated method stub

    }

}
    消息中心视图(MessageLayout)源码如下:

package com.everyone.android.ui.message;

import java.util.ArrayList;

import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.FrameLayout;
import android.widget.LinearLayout;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.RadioGroup.OnCheckedChangeListener;

import com.everyone.android.R;
import com.everyone.android.ui.EveryoneActivity;
import com.everyone.android.widget.TopMenuNavbar;

/**
 * 功能描述:消息中心视图
 * @author android_ls
 */
public class MessageLayout extends FrameLayout implements OnClickListener {

    private TopMenuNavbar topMenuNavbar;

    /**
     * 获取顶部左侧的menu组件
     * @return
     */
    public LinearLayout getMenuView() {
        return topMenuNavbar.llShowMenu;
    }

    private ViewPager mViewPager;

    private RadioGroup rgMessageNavbar;

    private RadioButton rbMessage;

    private RadioButton rbFriend;

    private RadioButton rbBirthDay;

    private EveryoneActivity mActivity;

    public MessageLayout(EveryoneActivity activity) {
        super(activity);
        mActivity = activity;

        setupViews();
    }

    public MessageLayout(EveryoneActivity activity, AttributeSet attrs) {
        super(activity, attrs);
        mActivity = activity;

        setupViews();
    }

    private void setupViews() {
        final LayoutInflater mLayoutInflater = LayoutInflater.from(getContext());
        LinearLayout rootView = (LinearLayout) mLayoutInflater.inflate(R.layout.message, null);
        addView(rootView);

        // 对顶部的导航栏进行设置
        topMenuNavbar = (TopMenuNavbar) rootView.findViewById(R.id.rl_top_menu_navbar);
        topMenuNavbar.mLlRefresh.setOnClickListener(this);

        topMenuNavbar.tvTitle.setText("消息中心");
        topMenuNavbar.ivDownListIcon.setVisibility(View.GONE);
        topMenuNavbar.ivRefresh.setVisibility(View.GONE);

        // 初始化RadioGroup及相关组件
        rgMessageNavbar = (RadioGroup) rootView.findViewById(R.id.rg_message);
        rbMessage = (RadioButton) rootView.findViewById(R.id.rb_message);
        rbMessage.setChecked(true);
        rbFriend = (RadioButton) rootView.findViewById(R.id.rb_friend);
        rbBirthDay = (RadioButton) rootView.findViewById(R.id.rb_birthday);

        // 初始化ViewPager组件的子视图
        View messageView = mLayoutInflater.inflate(R.layout.message_message, null);
        View friendView = mLayoutInflater.inflate(R.layout.message_friend, null);
        View birthdayView = mLayoutInflater.inflate(R.layout.message_birthday, null);

        ArrayList<View> views = new ArrayList<View>();
        views.add(messageView);
        views.add(friendView);
        views.add(birthdayView);

        // 初始化ViewPager组件,并为其设置数据适配器
        mViewPager = (ViewPager) rootView.findViewById(R.id.vp_message);
        ViewPagerAdapter mPagerAdapter = new ViewPagerAdapter(views);
        mViewPager.setAdapter(mPagerAdapter);
        mViewPager.setCurrentItem(0);

        mViewPager.setOnPageChangeListener(new OnPageChangeListener() {

            public void onPageSelected(int arg0) {

            }

            public void onPageScrolled(int arg0, float arg1, int arg2) {

            }

            public void onPageScrollStateChanged(int arg0) {
                if (arg0 == ViewPager.SCROLL_STATE_IDLE) {
                    switch (mViewPager.getCurrentItem()) {
                    case 0:
                        rbMessage.setChecked(true);
                        break;

                    case 1:
                        rbFriend.setChecked(true);
                        break;

                    case 2:
                        rbBirthDay.setChecked(true);
                        break;
                    }
                }
            }
        });

        rgMessageNavbar.setOnCheckedChangeListener(new OnCheckedChangeListener() {

            public void onCheckedChanged(RadioGroup group, int checkedId) {
                switch (checkedId) {
                case R.id.rb_message:
                    mViewPager.setCurrentItem(0);
                    break;

                case R.id.rb_friend:
                    mViewPager.setCurrentItem(1);
                    break;

                case R.id.rb_birthday:
                    mViewPager.setCurrentItem(2);
                    break;
                }
            }
        });

    }

    @Override
    public void onClick(View v) {
        switch (v.getId()) {
        case R.id.ll_refresh:
            // 顶部右侧编辑事件处理

            break;
        default:
            break;
        }
    }

}

   由于人人开放平台未提供有关消息的API,因此,这里我只实现其UI部分。
 








  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值