android 中viewpager+fragment仿微信底部TAG完美渐变

viewpager+fragment仿微信底部TAG完美渐变,在图片渐变的同时字的颜色也在变,注意,是渐变哦!

效果图:

activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:zhy="http://schemas.android.com/apk/res/com.Sing.weixin"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical" >
 <android.support.v4.view.ViewPager
  android:id="@+id/id_viewpager"
  android:layout_width="fill_parent"
  android:layout_height="0dp"
  android:layout_weight="1" >
 </android.support.v4.view.ViewPager>
 <LinearLayout
  android:layout_width="fill_parent"
  android:layout_height="60dp"
  android:background="@drawable/tabbg"
  android:orientation="horizontal" >
  <com.Sing.weixin.ChangeColorIconWithTextView
   android:id="@+id/id_indicator_one"
   android:layout_width="0dp"
   android:layout_height="fill_parent"
   android:layout_weight="1"
   android:padding="5dp"
   zhy:icon="@drawable/ic_menu_start_conversation"
   zhy:text="@string/tab_one"
   zhy:text_size="12sp" />
  <com.Sing.weixin.ChangeColorIconWithTextView
   android:id="@+id/id_indicator_two"
   android:layout_width="0dp"
   android:layout_height="fill_parent"
   android:layout_weight="1"
   android:padding="5dp"
   zhy:icon="@drawable/ic_menu_friendslist"
   zhy:text="@string/tab_two"
   zhy:text_size="12sp" />
 </LinearLayout>
</LinearLayout> 

MainActivity.java

package com.Sing.weixin;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;
import android.annotation.SuppressLint;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewConfiguration;
@SuppressLint("NewApi")
public class MainActivity extends FragmentActivity implements
  OnPageChangeListener, OnClickListener {
 private ViewPager mViewPager;
 // 选项卡一Fragment
 private FrgReturnVisit returnVisit;
 // 选项卡一Fragment
 private FrgMicroVisit microVisit;
 private List<ChangeColorIconWithTextView> mTabIndicator = new ArrayList<ChangeColorIconWithTextView>();
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  setOverflowShowingAlways();
  mViewPager = (ViewPager) findViewById(R.id.id_viewpager);
  mViewPager.setAdapter(new MyPagerAdapter(getSupportFragmentManager()));
  initTabIndicator();
  mViewPager.setOnPageChangeListener(this);
 }
 private void initTabIndicator() {
  ChangeColorIconWithTextView one = (ChangeColorIconWithTextView) findViewById(R.id.id_indicator_one);
  ChangeColorIconWithTextView two = (ChangeColorIconWithTextView) findViewById(R.id.id_indicator_two);
  mTabIndicator.add(one);
  mTabIndicator.add(two);
  one.setOnClickListener(this);
  two.setOnClickListener(this);
  one.setIconAlpha(1.0f);
 }
 @Override
 public void onPageSelected(int arg0) {
 }
 @Override
 public void onPageScrolled(int position, float positionOffset,
   int positionOffsetPixels) {
  if (positionOffset > 0) {
   ChangeColorIconWithTextView left = mTabIndicator.get(position);
   ChangeColorIconWithTextView right = mTabIndicator.get(position + 1);
   left.setIconAlpha(1 - positionOffset);
   right.setIconAlpha(positionOffset);
  }
 }
 @Override
 public void onPageScrollStateChanged(int state) {
 }
 @Override
 public void onClick(View v) {
  resetOtherTabs();
  switch (v.getId()) {
  case R.id.id_indicator_one:
   mTabIndicator.get(0).setIconAlpha(1.0f);
   mViewPager.setCurrentItem(0, false);
   break;
  case R.id.id_indicator_two:
   mTabIndicator.get(1).setIconAlpha(1.0f);
   mViewPager.setCurrentItem(1, false);
   break;
  }
 }
 /**
  * 重置其他的Tab
  */
 private void resetOtherTabs() {
  for (int i = 0; i < mTabIndicator.size(); i++) {
   mTabIndicator.get(i).setIconAlpha(0);
  }
 }
 private void setOverflowShowingAlways() {
  try {
   // true if a permanent menu key is present, false otherwise.
   ViewConfiguration config = ViewConfiguration.get(this);
   Field menuKeyField = ViewConfiguration.class.getDeclaredField("sHasPermanentMenuKey");
   menuKeyField.setAccessible(true);
   menuKeyField.setBoolean(config, false);
  } catch (Exception e) {
   e.printStackTrace();
  }
 }
 public class MyPagerAdapter extends FragmentPagerAdapter {
  public MyPagerAdapter(FragmentManager fm) {
   super(fm);
  }
  private final String[] titles = { "选项一", "选项二"};
  @Override
  public CharSequence getPageTitle(int position) {
   return titles[position];
  }
  @Override
  public int getCount() {
   return titles.length;
  }
  @Override
  public Fragment getItem(int position) {
   switch (position) {
   case 0:
    if (returnVisit == null) {
     returnVisit = new FrgReturnVisit();
    }
    return returnVisit;
   case 1:
    if (microVisit == null) {
     microVisit = new FrgMicroVisit();
    }
    return microVisit;
   default:
    return null;
   }
  }
 }
} 

ChangeColorIconWithTextView.java

package com.Sing.weixin;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Bitmap;
import android.graphics.Bitmap.Config;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.graphics.Rect;
import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle;
import android.os.Looper;
import android.os.Parcelable;
import android.util.AttributeSet;
import android.util.TypedValue;
import android.view.View;
public class ChangeColorIconWithTextView extends View {
 private Bitmap mBitmap;
 private Canvas mCanvas;
 private Paint mPaint;
 /**
  * 颜色
  */
 private int mColor = 0xFF45C01A;
 /**
  * 透明度 0.0-1.0
  */
 private float mAlpha = 0f;
 /**
  * 图标
  */
 private Bitmap mIconBitmap;
 /**
  * 限制绘制icon的范围
  */
 private Rect mIconRect;
 /**
  * icon底部文本
  */
 private String mText = "demo";
 private int mTextSize = (int) TypedValue.applyDimension(
   TypedValue.COMPLEX_UNIT_SP, 10, getResources().getDisplayMetrics());
 private Paint mTextPaint;
 private Rect mTextBound = new Rect();
 public ChangeColorIconWithTextView(Context context) {
  super(context);
 }
 /**
  * 初始化自定义属性值
  *
  * @param context
  * @param attrs
  */
 public ChangeColorIconWithTextView(Context context, AttributeSet attrs) {
  super(context, attrs);
  // 获取设置的图标
  TypedArray a = context.obtainStyledAttributes(attrs,
    R.styleable.ChangeColorIconView);
  int n = a.getIndexCount();
  for (int i = 0; i < n; i++) {
   int attr = a.getIndex(i);
   switch (attr) {
   case R.styleable.ChangeColorIconView_icon:
    BitmapDrawable drawable = (BitmapDrawable) a.getDrawable(attr);
    mIconBitmap = drawable.getBitmap();
    break;
   case R.styleable.ChangeColorIconView_color:
    mColor = a.getColor(attr, 0x45C01A);
    break;
   case R.styleable.ChangeColorIconView_text:
    mText = a.getString(attr);
    break;
   case R.styleable.ChangeColorIconView_text_size:
    mTextSize = (int) a.getDimension(attr, TypedValue
      .applyDimension(TypedValue.COMPLEX_UNIT_SP, 10,
        getResources().getDisplayMetrics()));
    break;
   }
  }
  a.recycle();
  mTextPaint = new Paint();
  mTextPaint.setTextSize(mTextSize);
  mTextPaint.setColor(0xff555555);
  // 得到text绘制范围
  mTextPaint.getTextBounds(mText, 0, mText.length(), mTextBound);
 }
 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  super.onMeasure(widthMeasureSpec, heightMeasureSpec);
  // 得到绘制icon的宽
  int bitmapWidth = Math.min(getMeasuredWidth() - getPaddingLeft()
    - getPaddingRight(), getMeasuredHeight() - getPaddingTop()
    - getPaddingBottom() - mTextBound.height());
  int left = getMeasuredWidth() / 2 - bitmapWidth / 2;
  int top = (getMeasuredHeight() - mTextBound.height()) / 2 - bitmapWidth
    / 2;
  // 设置icon的绘制范围
  mIconRect = new Rect(left, top, left + bitmapWidth, top + bitmapWidth);
 }
 @Override
 protected void onDraw(Canvas canvas) {
  int alpha = (int) Math.ceil((255 * mAlpha));
  canvas.drawBitmap(mIconBitmap, null, mIconRect, null);
  setupTargetBitmap(alpha);
  drawSourceText(canvas, alpha);
  drawTargetText(canvas, alpha);
  canvas.drawBitmap(mBitmap, 0, 0, null);
 }
 private void setupTargetBitmap(int alpha) {
  mBitmap = Bitmap.createBitmap(getMeasuredWidth(), getMeasuredHeight(),
    Config.ARGB_8888);
  mCanvas = new Canvas(mBitmap);
  mPaint = new Paint();
  mPaint.setColor(mColor);
  mPaint.setAntiAlias(true);
  mPaint.setDither(true);
  mPaint.setAlpha(alpha);
  mCanvas.drawRect(mIconRect, mPaint);
  mPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST_IN));
  mPaint.setAlpha(255);
  mCanvas.drawBitmap(mIconBitmap, null, mIconRect, mPaint);
 }
 private void drawSourceText(Canvas canvas, int alpha) {
  mTextPaint.setTextSize(mTextSize);
  mTextPaint.setColor(0xff333333);
  mTextPaint.setAlpha(255 - alpha);
  canvas.drawText(mText, mIconRect.left + mIconRect.width() / 2
    - mTextBound.width() / 2,
    mIconRect.bottom + mTextBound.height(), mTextPaint);
 }
 private void drawTargetText(Canvas canvas, int alpha) {
  mTextPaint.setColor(mColor);
  mTextPaint.setAlpha(alpha);
  canvas.drawText(mText, mIconRect.left + mIconRect.width() / 2
    - mTextBound.width() / 2,
    mIconRect.bottom + mTextBound.height(), mTextPaint);
 }
 public void setIconAlpha(float alpha) {
  this.mAlpha = alpha;
  invalidateView();
 }
 private void invalidateView() {
  if (Looper.getMainLooper() == Looper.myLooper()) {
   invalidate();
  } else {
   postInvalidate();
  }
 }
 public void setIconColor(int color) {
  mColor = color;
 }
 public void setIcon(int resId) {
  this.mIconBitmap = BitmapFactory.decodeResource(getResources(), resId);
  if (mIconRect != null)
   invalidateView();
 }
 public void setIcon(Bitmap iconBitmap) {
  this.mIconBitmap = iconBitmap;
  if (mIconRect != null)
   invalidateView();
 }
 private static final String INSTANCE_STATE = "instance_state";
 private static final String STATE_ALPHA = "state_alpha";
 @Override
 protected Parcelable onSaveInstanceState() {
  Bundle bundle = new Bundle();
  bundle.putParcelable(INSTANCE_STATE, super.onSaveInstanceState());
  bundle.putFloat(STATE_ALPHA, mAlpha);
  return bundle;
 }
 @Override
 protected void onRestoreInstanceState(Parcelable state) {
  if (state instanceof Bundle) {
   Bundle bundle = (Bundle) state;
   mAlpha = bundle.getFloat(STATE_ALPHA);
   super.onRestoreInstanceState(bundle.getParcelable(INSTANCE_STATE));
  } else {
   super.onRestoreInstanceState(state);
  }
 }
} 

github:https://github.com/ganchuanpu/Demo_Sing_weixin

以上所述是小编给大家介绍的android 中viewpager+fragment仿微信底部TAG完美渐变效果,希望对大家有所帮助!

(0)

相关推荐

  • Android使用TabLayou+fragment+viewpager实现滑动切换页面效果

    TabLayou 主要实现的是标题头的 滑动 这个 控件 类似于 ScrollView XML中的布局 <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" > <android.support.design.widget.TabLayout a

  • Android中Activity和Fragment传递数据的两种方式

    1.第一种方式,也是最常用的方式,就是使用Bundle来传递参数 MyFragment myFragment = new MyFragment(); Bundle bundle = new Bundle(); bundle.putString("DATA",values);//这里的values就是我们要传的值 myFragment.setArguments(bundle); 然后在Fragment中的onCreatView方法中,通过getArgments()方法,获取到bundle

  • Android开发中如何解决Fragment +Viewpager滑动页面重复加载的问题

    前言 之前在做一个Viewpager上面加载多个Fragment时总会实例化已经创建好的Fragmnet对象类似 viewPager.setAdapter(new FragmentPagerAdapter(getSupportFragmentManager()) { @Override public Fragment getItem(int position) { switch(position){ case 0: fragments=new Fragmnet01(); break; case

  • Android中Fragment相互切换间不被回收的实现方法

    前言 Android运行在各种各样的设备中,有小屏幕的手机,超大屏的平板甚至电视.针对屏幕尺寸的差距,很多情况下,都是先针对手机开发一套App,然后拷贝一份,修改布局以适应平板神马超级大屏的.难道无法做到一个App可以同时适应手机和平板么,当然了,必须有啊.Fragment的出现就是为了解决这样的问题. 如今市面上的应用基本上都是单Activity+多Fragment实现的了,而这类APP都有在相互切换时不被回收,即切换回原来的Fragment时还是原先的状态,这就是这里要实现的了. 这里使用F

  • Android使用TabLayout+Fragment实现顶部选项卡

    先看效果图: 使用Tablayout,首先需要在项目中加入Design包 dependencies { compile 'com.android.support:design:24.1.1' } 在activity_main.xml布局文件中 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/

  • Android 中ActionBar+fragment实现页面导航的实例

    Android 中ActionBar+fragment实现页面导航的实例 为保证android2.0以上均能运行,使用support.v7库下的actionbar及fragment 继承自AppCompatActivity(ActionBarActivity已过时)使用getSupportActionBar()得到ActionBar, ActionBar.Tab,这里Tab必须设置监听,在监听中实现Fragment的切换. 这里重点提一下,Theme主题一定要适配,因为我使用的是AppCompa

  • android 中viewpager+fragment仿微信底部TAG完美渐变

    viewpager+fragment仿微信底部TAG完美渐变,在图片渐变的同时字的颜色也在变,注意,是渐变哦! 效果图: activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:zhy="http://schemas.android.com/apk/res/com.Sing.weixin" xmlns:tools="

  • Android中使用PopupWindow 仿微信点赞和评论弹出

    微信朋友圈的点赞和评论功能,有2个组成部分:左下角的"更多"按钮:点击该按钮后弹出的对话框: PopupWindow,弹出框使用PopupWindow实现,这是点赞和评论的载体,具体要涉及 PopupWindow 点击非窗口位置和再次点击消失以及显示位置的问题(根据相应更多按钮的位置确定 PopupWindow 的显示位置 package com.example.cmm.helloworld; import android.app.AlertDialog; import android

  • Android 仿微信底部渐变Tab效果

    先来看一下效果图 除了第三个的发现Tab有所差别外,其他的基本还原了微信的底部Tab渐变效果 每个Tab都是一个自定义View,根据ImageView的tint属性来实现颜色渐变效果,tint属性的使用可以看我的上一篇文章 我将自定义View命名为ShadeView,包含四个自定义属性 意思分别为图标.背景色.底部文本.底部文本大小 <declare-styleable name="ShadeView"> <attr name="icon" for

  • Android仿微信底部菜单栏效果

    前言 在市面上,大多数的APP都需要通过底部菜单栏来将程序的功能进行分类整理,通常都是分为3-5个大模块,从而正确有效地引导用户去使用我们的APP.实现底部菜单栏的方法也有很多种. 1.仿微信底部菜单栏(ViewPager+ImagerView+TextView) ......(其他方式后续会补充) 效果预览 首先来个开胃菜,看看实现效果: 先贴出项目所需的资源文件,这些可随个人自由更改颜色和文字 colors.xml <color name="bg_line_light_gray&quo

  • Android仿微信底部按钮滑动变色

    Android仿微信底部按钮滑动变色,这里只针对使用Fragment为Tab页的滑动操作,进行简单的变色讲解. 首先说下OnPageChangeListener这个监听 //这个监听有三个方法 public abstract void onPageScrollStateChanged (int state) public abstract void onPageScrolled (int position, float positionOffset, int positionOffsetPixe

  • Android仿微信底部菜单栏功能显示未读消息数量

    底部菜单栏很重要,我看了一下很多应用软件都是用了底部菜单栏,这里使用了tabhost做了一种通用的(就是可以像微信那样显示未读消息数量的,虽然之前也做过但是layout下的xml写的太臃肿,这里去掉了很多不必要的层,个人看起来还是不错的,所以贴出来方便以后使用). 先看一下做出来之后的效果: 以后使用的时候就可以换成自己项目的图片和字体了,主框架不用变哈哈, 首先是要布局layout下xml文件 main.xml: <?xml version="1.0" encoding=&qu

  • Android中ViewPager获取当前显示的Fragment

    前言 在项目中,有时会用到在ViewPager中显示同样类型的Fragment,同时这样的Fragment的个数是动态的,但是PagerAdapter没有给我们提供getCurrentFragment类似的方法.下面就给大家介绍下Android中ViewPager获取当前显示的Fragment的方法,一起看看吧. 一.使用 getSupportFragmentManager().findFragmentByTag()方法 Viewpager + FragmentPagerAdapter 情况下

  • ViewPager+RadioGroup仿微信主界面

    话不多说,先上图,如图效果,可以点击底部按钮选择页面,也可以滑动页面进行选择. 那么我们下面就来实现一下吧. 首先创建工程WXTest,主界面布局使用ViewPager+RadioGroup来实现,界面代码如下. <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&quo

  • 使用ViewPage+Fragment仿微信界面

    本文实例为大家分享了ViewPage+Fragment仿微信界面的具体代码,供大家参考,具体内容如下 实现效果: 左右滑动可切换界面,点击也可以实现 界面与碎片: 主界面: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="h

  • Android 中ViewPager重排序与更新实例详解

    Android 中ViewPager重排序与更新实例详解 最近的项目中有栏目订阅功能,在更改栏目顺序以后需要更新ViewPager.类似于网易新闻的频道管理. 在重新排序之后调用了PagerAdapter的notifyDataSetChanged方法,发现ViewPager并没有更新,于是我开始跟踪源码,在调用PagerAdapter的notifyDataSetChanged方法后,会触发Viewpager的dataSetChanged方法. void dataSetChanged() { //

随机推荐