android 中viewpager+fragment仿微信底部TAG完美渐变
发布时间 - 2026-01-11 01:06:36 点击率:次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完美渐变效果,希望对大家有所帮助!
# android
# 微信底部TAG渐变
# 微信底部
# Android中Activity和Fragment传递数据的两种方式
# Android中Fragment相互切换间不被回收的实现方法
# Android开发中如何解决Fragment +Viewpager滑动页面重复加载的问题
# Android使用TabLayout+Fragment实现顶部选项卡
# Android使用TabLayou+fragment+viewpager实现滑动切换页面效果
# Android 中ActionBar+fragment实现页面导航的实例
# 选项卡
# 也在
# 其他的
# 给大家
# 自定义
# 所述
# 小编
# mTabIndicator
# protected
# Override
# returnVisit
# savedInstanceState
# microVisit
# FrgMicroVisit
# void
# MyPagerAdapter
# layout
# findViewById
# setOverflowShowingAlways
# onCreate
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
网站制作免费,什么网站能看正片电影?
Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】
Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)
CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】
Python函数文档自动校验_规范解析【教程】
重庆市网站制作公司,重庆招聘网站哪个好?
百度浏览器网页无法复制文字怎么办 百度浏览器复制修复
如何用VPS主机快速搭建个人网站?
,怎么在广州志愿者网站注册?
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
如何安全更换建站之星模板并保留数据?
如何在云指建站中生成FTP站点?
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
Laravel如何使用Service Container和依赖注入?(代码示例)
Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
如何用景安虚拟主机手机版绑定域名建站?
如何快速打造个性化非模板自助建站?
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
Android中AutoCompleteTextView自动提示
利用vue写todolist单页应用
Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道
python中快速进行多个字符替换的方法小结
如何在景安服务器上快速搭建个人网站?
如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】
如何快速上传建站程序避免常见错误?
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门
如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程
Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】
高端智能建站公司优选:品牌定制与SEO优化一站式服务
如何在Windows 2008云服务器安全搭建网站?
Laravel怎么在Blade中安全地输出原始HTML内容
谷歌Google入口永久地址_Google搜索引擎官网首页永久入口
JavaScript如何实现音频处理_Web Audio API如何工作?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
Python文件异常处理策略_健壮性说明【指导】
html5的keygen标签为什么废弃_替代方案说明【解答】
Laravel如何与Inertia.js和Vue/React构建现代单页应用
如何快速登录WAP自助建站平台?
Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知
如何续费美橙建站之星域名及服务?
香港服务器选型指南:免备案配置与高效建站方案解析
jQuery validate插件功能与用法详解
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
如何用已有域名快速搭建网站?

