android TranslateAnimation 顶部segment分段移动动画
本人开发的开发者技术变现资源聚集地,大家支持下,下面是网址
https://www.baiydu.com
这里实现的功能是从主页布局的fragment点击跳转到一个acitivity,然后顶部是一个切换的segment底部部是一个listview,点击segment分段让listview加载不同的内容。我这里没再使用viewpager,应该使用viewpager+listview也能实现。我这里使用的算是一个自定义的viewpager。下面我主要围绕TranslateAnimation segment切换动画类来谈,这东西吭比较多,我原本也是才做android开发的, 它这个类实现动画很多效果上的bug,效果bug直接说明android这个动画类没ios做的好,我遇到的这些效果bug主要出现在控件移动的距离和移动时间上的计算上。比如移动动画带有缓冲,或则移动分段两个以上,就没有动画效果。

下面先帖上布局,主要就是
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:background="@color/white_color"
android:orientation="vertical" >
<TextView
android:layout_width="match_parent"
android:layout_height="@dimen/navigationbar_height"
android:textSize="@dimen/title_fontsize"
android:text="在线视频" android:textColor="@color/navigation_title_color"
android:background="@color/navigationbar_backround_color"
android:gravity="center"/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="53dp"
android:orientation="vertical"
android:animateLayoutChanges="true"
>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="50dp"
android:orientation="horizontal"
> <TextView
android:layout_width="match_parent"
android:layout_height="@dimen/navigationbar_height"
android:layout_weight="1"
android:textSize="@dimen/title_fontsize"
android:text="推荐"
android:id="@+id/tuijianVideo"
android:textColor="@color/hot_price_color"
android:background="@color/navigationbar_backround_color"
android:gravity="center"/>
<TextView
android:layout_width="match_parent"
android:layout_height="@dimen/navigationbar_height"
android:textSize="@dimen/title_fontsize"
android:layout_weight="1"
android:text="电影"
android:id="@+id/dianying"
android:textColor="@color/navigation_title_color"
android:background="@color/navigationbar_backround_color"
android:gravity="center"/>
<TextView
android:layout_width="match_parent"
android:layout_height="@dimen/navigationbar_height"
android:textSize="@dimen/title_fontsize"
android:text="电视"
android:id="@+id/dianshi"
android:layout_weight="1"
android:textColor="@color/navigation_title_color"
android:background="@color/navigationbar_backround_color"
android:gravity="center"/>
<TextView
android:layout_width="match_parent"
android:layout_height="@dimen/navigationbar_height"
android:textSize="@dimen/title_fontsize"
android:text="动漫"
android:layout_weight="1"
android:id="@+id/dongman"
android:textColor="@color/navigation_title_color"
android:background="@color/navigationbar_backround_color"
android:gravity="center"/>
<TextView
android:layout_width="match_parent"
android:layout_height="@dimen/navigationbar_height"
android:textSize="@dimen/title_fontsize"
android:text="综艺"
android:id="@+id/zongyi"
android:layout_weight="1"
android:textColor="@color/navigation_title_color"
android:background="@color/navigationbar_backround_color"
android:gravity="center"/>
</LinearLayout> <ImageView
android:layout_width="match_parent"
android:id="@+id/Imagezhishiqi"
android:layout_height="3dp"
android:background="@color/hot_price_color"/>
</LinearLayout> <com.lt.WBTaoBaoKe.custom.xPullRefresh.XListView
android:id="@+id/xListView"
android:layout_width="fill_parent"
android:layout_height="fill_parent" android:cacheColorHint="#00000000">
</com.lt.WBTaoBaoKe.custom.xPullRefresh.XListView>
</LinearLayout>
下面贴代码,有动画说明的详细注视
public class HomeFragment_VideoActivity extends Activity implements View.OnClickListener {
private ListViewAdapter listViewAdapter;
private ViewPagerAdapter viewPagerAdapter;
private Context context;
private LinearLayout.LayoutParams zhishiqilinearParams;
private int zhishiqiWidth;
private ImageView zhishiqi;
private TextView tuijianView;
private TextView dianying;
private TextView dianshi;
private TextView dongman;
private TextView zongyi;
private int currentTopItemIndex;
private TranslateAnimation moveAnimation;
private int moveStepValue;
//视频数据
private XListView listView;
private JSONArray CurrentVideoDataArray;
private int currentVideoPageIndex;
private String refreshTime = "第一次刷新";
private ViewGroup.MarginLayoutParams margin;
@Override
protected void onCreate(final Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
context = getApplicationContext();
setContentView(R.layout.home_video_activity);
//指示器
zhishiqi = (ImageView) findViewById(R.id.Imagezhishiqi);
currentTopItemIndex = 1;
DisplayMetrics dm = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(dm);
int width = dm.widthPixels;
//由于我们分段是固定的5段,所以这里先使用手机屏幕宽度/5,计算出分段指示器的宽度
zhishiqiWidth = width / 5;
//由于在固定布局中无法准确设置出指示器的宽度,所以这里需要使用计算出的宽度重新设置指示器宽度
zhishiqilinearParams = (LinearLayout.LayoutParams) zhishiqi.getLayoutParams();
zhishiqilinearParams.width = zhishiqiWidth;
zhishiqi.setLayoutParams(zhishiqilinearParams);
//下面都是每个分段里面显示文字的textview控件
tuijianView = (TextView) findViewById(R.id.tuijianVideo);
dianying = (TextView) findViewById(R.id.dianying);
dianshi = (TextView) findViewById(R.id.dianshi);
dongman = (TextView) findViewById(R.id.dongman);
zongyi = (TextView) findViewById(R.id.zongyi);
tuijianView.setTag(1);
dianying.setTag(2);
dianshi.setTag(3);
dongman.setTag(4);
zongyi.setTag(5);
tuijianView.setOnClickListener(this);
dianying.setOnClickListener(this);
dianshi.setOnClickListener(this);
dongman.setOnClickListener(this);
zongyi.setOnClickListener(this);
}
//每个分段textview点击事件
@Override
public void onClick(View v) {
int tag = (Integer) v.getTag();
//获得控件移动的段数确定移动方向,如果是正数表示向右移动,负数左移动
moveStepValue = tag - currentTopItemIndex;
switch (tag) {
case 1:
if (currentTopItemIndex == 1) {
return;
} else {
currentTopItemIndex = tag;
tuijianView.setTextColor(this.getResources().getColor(R.color.hot_price_color));
dianying.setTextColor(this.getResources().getColor(R.color.white_color));
dianshi.setTextColor(this.getResources().getColor(R.color.white_color));
dongman.setTextColor(this.getResources().getColor(R.color.white_color));
zongyi.setTextColor(this.getResources().getColor(R.color.white_color));
}
break;
case 2:
if (currentTopItemIndex == 2) {
return;
} else {
currentTopItemIndex = tag;
tuijianView.setTextColor(this.getResources().getColor(R.color.white_color));
dianying.setTextColor(this.getResources().getColor(R.color.hot_price_color));
dianshi.setTextColor(this.getResources().getColor(R.color.white_color));
dongman.setTextColor(this.getResources().getColor(R.color.white_color));
zongyi.setTextColor(this.getResources().getColor(R.color.white_color));
}
break;
case 3:
if (currentTopItemIndex == 3) {
return;
} else {
currentTopItemIndex = tag;
tuijianView.setTextColor(this.getResources().getColor(R.color.white_color));
dianying.setTextColor(this.getResources().getColor(R.color.white_color));
dianshi.setTextColor(this.getResources().getColor(R.color.hot_price_color));
dongman.setTextColor(this.getResources().getColor(R.color.white_color));
zongyi.setTextColor(this.getResources().getColor(R.color.white_color));
}
break;
case 4:
if (currentTopItemIndex == 4) {
return;
} else {
currentTopItemIndex = tag;
tuijianView.setTextColor(this.getResources().getColor(R.color.white_color));
dianying.setTextColor(this.getResources().getColor(R.color.white_color));
dianshi.setTextColor(this.getResources().getColor(R.color.white_color));
dongman.setTextColor(this.getResources().getColor(R.color.hot_price_color));
zongyi.setTextColor(this.getResources().getColor(R.color.white_color));
}
break;
default:
if (currentTopItemIndex == 5) {
return;
} else {
currentTopItemIndex = tag;
tuijianView.setTextColor(this.getResources().getColor(R.color.white_color));
dianying.setTextColor(this.getResources().getColor(R.color.white_color));
dianshi.setTextColor(this.getResources().getColor(R.color.white_color));
dongman.setTextColor(this.getResources().getColor(R.color.white_color));
zongyi.setTextColor(this.getResources().getColor(R.color.hot_price_color));
}
break;
}
margin = new ViewGroup.MarginLayoutParams(tuijianView.getLayoutParams());
//Animation.RELATIVE_TO_SELF, 0.0f,这两个其实是一个参数(合并一起看,表示相对定位+坐标变动值),所以只看2/4/6/8这4个参数
//第一个值:0.0f表示控件的原始x坐标不变动。
//第二个值moveStepValue*0.5f表示原始x坐标前提下变动的值
//第三个值0.0f表示y坐标变动
//第四个值0.0f表示原始y坐标前提下变动的值
//重点:这里由于我们只是x坐标左右移动,所以y轴的值一只不变动0.0f 0.0f
//当moveStepValue为负数时,moveStepValue*0.5f segment是往左移动,正数往右移动,这样动画效果才不会有bug,
moveAnimation = new TranslateAnimation(Animation.RELATIVE_TO_SELF, 0.0f,
Animation.RELATIVE_TO_SELF, moveStepValue * 0.5f, Animation.RELATIVE_TO_SELF,
0.0f, Animation.RELATIVE_TO_SELF, 0.0f);
//下面的代码是计算动画的执行时间,如果不计算就会出现切换分段数量不一致,指示器的动画执行速度太快或太慢。
if (moveStepValue < 1) {
moveStepValue = moveStepValue * -1;
}
moveAnimation.setDuration(moveStepValue * 70);
moveAnimation.setAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationRepeat(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
zhishiqi.clearAnimation();
//移动效果实现之后,还需要将移动segment分段的margin设置一次,如果不设置动画又会反回去,为什么这样我觉得应该是和android是使用xhtml布局的原因。
zhishiqilinearParams.setMargins((currentTopItemIndex - 1) * zhishiqiWidth, margin.topMargin, zhishiqiWidth, zhishiqilinearParams.height);
zhishiqi.setLayoutParams(zhishiqilinearParams);
}
});
zhishiqi.startAnimation(moveAnimation);
zhishiqi.setVisibility(View.VISIBLE);
}
}
android TranslateAnimation 顶部segment分段移动动画的更多相关文章
- 【Android UI设计和开发】动画(Animation)详细说明(一)
Android开发之动画效果浅析 请尊重他人的劳动成果.转载请注明出处:Android开发之动画效果浅析 程序执行效果图: Android动画主要包括补间动画(Tween)View Animation ...
- Android自定义Activity酷炫的动画跳转效果
两个Activity跳转的时候,自定义翻页效果: Intent intent = new Intent(FirstActivity.this, SecondActivity.class); sta ...
- 转Android 用Animation-list实现逐帧动画
Android 用Animation-list实现逐帧动画 第一步:先上图片素材,以下素材放到res/drawable目录下: http://blog.csdn.net/aminfo/arti ...
- Android开发之漫漫长途 XVII——动画
该文章是一个系列文章,是本人在Android开发的漫漫长途上的一点感想和记录,我会尽量按照先易后难的顺序进行编写该系列.该系列引用了<Android开发艺术探索>以及<深入理解And ...
- android xml实现animation 4种动画效果
animation有四种动画类型 分别为alpha(透明的渐变).rotate(旋转).scale(尺寸伸缩).translate(移动),二实现的分发有两种,一种是javaCode,另外一种是XML ...
- Android 用Animation-list实现逐帧动画 (转载)
转自:http://blog.csdn.net/aminfo/article/details/7847761 第一步:先上图片素材,以下素材放到res/drawable目录下: http://blog ...
- [Swift通天遁地]九、拔剑吧-(3)创建多种自定义Segment分段样式的控件
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- [Swift通天遁地]九、拔剑吧-(4)使用开源类库创建可滑动的Segment分段控件
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- Android开发 navigation的跳转动画实现
前言 此篇博客只简短的介绍navigation如何添加跳转页面的动画属性,如果你还为接触了解过navigation.建议你看我另一篇博客Android开发 navigation入门详解 创建动画xml ...
随机推荐
- FPGA计算3行同列数据之和
实验:FPGA计算3行同列数据之和 实验要求:PC机通过串口发送3行数据(一行有56个数据,3行共有56*3=168个数据)给FPGA,FPGA计算3行同一列数据的和,并将结果通过串口返回给上位机. ...
- HTML细节
link 设置body中超链接默认颜色 : alink 设置body中超链接点击时候的颜色: vlink 设置body中超链接访问过后的颜色 字体的大小 size 大小 取值范围 ...
- 手把手教小白如何用css+js实现页面中图片放大展示效果
1.前言 很多童鞋会在项目中遇到一些上传图片,展示图片的操作,但是图片呢有大有小,为了页面的美观,有时候我们需要将图片展示成固定宽高度,但是呢,领导就会说,我想看大图片,怎么办?想看就看呀, ...
- ExtJs的expand和collapse
最近在研究ExtJs的窗口组件(Ext.window),关于扩展显示expand和折叠显示collapse的一点心得记录一下,以便后查. var win2 = new Ext.window({ id ...
- Hadoop - 国内各站点最高温度、气压和风速统计
版权说明: 本文章版权归本人及博客园共同所有,转载请标明原文出处(http://www.cnblogs.com/mikevictor07/),以下内容为个人理解,仅供参考. 一.简介 该实例统计国内 ...
- vue+mockjs 模拟数据,实现前后端分离开发
在项目中尝试了mockjs,mock数据,实现前后端分离开发. 关于mockjs,官网描述的是 1.前后端分离 2.不需要修改既有代码,就可以拦截 Ajax 请求,返回模拟的响应数据. 3.数据类型丰 ...
- Unity 发布的 WebGL 使用SendMessage传递多个参数
如果要实现Unity与浏览器的数据交互一般都会采用两种方式 方法一: Application.ExternalCall("SayHello","helloworld&qu ...
- 【水题】HDU--1280 前m大的数
还记得Gardon给小希布置的那个作业么?(上次比赛的1005)其实小希已经找回了原来的那张数表,现在她想确认一下她的答案是否正确,但是整个的答案是很庞大的表,小希只想让你把答案中最大的M个数告诉她就 ...
- 【NO.3-1】Jmeter - 在Windows配置HOSTS的方法
在Windows配置HOSTS 那么还记得Windows如何修改HOSTS文件吗? (1) 进入到C:\Windows\System32\drivers\etc (2) 通过”记事本”来打开hosts ...
- Webapi文档描述-swagger优化
一.前言 最近做的项目使用WebApi,采取前后端分离的方式,后台提供API接口给前端开发人员.这个过程中遇到一个问题后台开发人员怎么提供接口说明文档给前端开发人员,最初打算使用word.Xmind思 ...