博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
View移动问题之别样解决方案
阅读量:6694 次
发布时间:2019-06-25

本文共 4825 字,大约阅读时间需要 16 分钟。

之前写过一篇关于的博客,主要用于“出发城市”和“到达城市”交换有动画效果,但是在实际应用中发现,在某些机型上实现该效果之后,若是该界面出现卡顿现象的话,之前移动的view又会回到原处(具体是什么原因还不清楚,请知道的老大告知一下),这样就可能会出现出发城市和达到城市颠倒问题。

在多番研究和请教高手之后,终于找到了一种比较完美的解决方案,以下是高人的原话:

“在framelayout中叠加两层图层 一个实际的数据层一个是动画层 当用户点击 切换按钮是时候 你把 事件数据层给隐藏掉 把动画层给展示出来 ,当动画结束之后 你把动画层给隐藏掉 把数据层展示出来并且 值交换”

 

我翻译一下:

就是有两个出发城市和到达城市,两个出发城市是重叠的,那个达到城市是重叠的,交换前是显示数据层的出发城市和达到城市,在点击交换之后,隐藏数据层(再将数据层的出发城市和到达城市数据交换),显示动画层,给动画层的出发城市到达城市添加移动动画,移动到目的位置之后再次显示数据层,隐藏动画层,这样就达到了出发城市和到达城市交换的且有动画的效果了

 

部分代码:

其中_txtFromStation,_txtToStation是动画层控件;txtFromStation,txtToStation是数据层控件

<RelativeLayout

android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:layout_weight="2"
android:orientation="vertical" >

<!-- 出发城市 -->

<TextView

android:id="@+id/rl_02"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:layout_marginLeft="10dp"
android:gravity="center_vertical"
android:text="@string/from_station_hint"
android:textColor="@color/font_title"
android:textSize="@dimen/text_size_normal" />

<TextView

android:id="@+id/choose_fromStation"
android:layout_width="match_parent"
android:layout_height="39dp"
android:layout_above="@+id/ly_split_01"
android:layout_marginLeft="5dp"
android:layout_toRightOf="@+id/rl_02"
android:background="@drawable/not_corner_selector"
android:gravity="center_vertical"
android:paddingLeft="5dp"
android:text="成都"
android:textColor="@color/black"
android:textSize="@dimen/text_size_xlarge" >
</TextView>

<TextView

android:id="@+id/_choose_fromStation"
android:layout_width="match_parent"
android:layout_height="39dp"
android:layout_above="@+id/ly_split_01"
android:layout_marginLeft="5dp"
android:layout_toRightOf="@+id/rl_02"
android:background="@drawable/not_corner_selector"
android:gravity="center_vertical"
android:paddingLeft="5dp"
android:textColor="@color/black"
android:textSize="@dimen/text_size_xlarge"
android:visibility="gone" >
</TextView>

<LinearLayout

android:id="@+id/ly_split_01"
style="@style/train_query_hor_split_style"
android:layout_below="@+id/rl_02"
android:orientation="vertical" />
<!-- 到达城市 -->

<TextView

android:id="@+id/rl_03"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:layout_below="@+id/ly_split_01"
android:layout_marginLeft="10dp"
android:gravity="center_vertical"
android:text="@string/to_station_hint"
android:textColor="@color/font_title"
android:textSize="@dimen/text_size_normal" />

<TextView

android:id="@+id/choose_toStation"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_below="@+id/ly_split_01"
android:layout_marginLeft="5dp"
android:layout_toRightOf="@id/rl_03"
android:background="@drawable/not_corner_selector"
android:gravity="center_vertical"
android:paddingLeft="5dp"
android:text="上海"
android:textColor="@color/black"
android:textSize="@dimen/text_size_xlarge" >
</TextView>

<TextView

android:id="@+id/_choose_toStation"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_below="@+id/ly_split_01"
android:layout_marginLeft="5dp"
android:layout_toRightOf="@id/rl_03"
android:background="@drawable/not_corner_selector"
android:gravity="center_vertical"
android:paddingLeft="5dp"
android:textColor="@color/black"
android:textSize="@dimen/text_size_xlarge"
android:visibility="gone" >
</TextView>
</RelativeLayout>

 

private void changeStationAnim() {

_txtFromStation.setText(fromStation);
_txtToStation.setText(toStation);

String temp = fromStation;

fromStation = toStation;
toStation = temp;

_txtFromStation.setVisibility(View.VISIBLE);

_txtToStation.setVisibility(View.VISIBLE);
txtFromStation.setVisibility(View.GONE);
txtToStation.setVisibility(View.GONE);

txtFromStation.setText(fromStation);

txtToStation.setText(toStation);

int move = PubFun.dip2px(TrainQueryActivity.this, 40);

slideview(_txtFromStation, 0, move);
slideview(_txtToStation, 0, -move);
}

 

public void slideview(final View view, final float p1, final float p2) {

TranslateAnimation animation = new TranslateAnimation(0, 0, p1, p2);
animation.setInterpolator(new OvershootInterpolator());
animation.setDuration(1000);
animation.setStartOffset(300);
animation.setAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {

}

@Override

public void onAnimationRepeat(Animation animation) {
}

@Override

public void onAnimationEnd(Animation animation) {
_txtToStation.setVisibility(View.GONE);
_txtFromStation.setVisibility(View.GONE);
txtToStation.setVisibility(View.VISIBLE);
txtFromStation.setVisibility(View.VISIBLE);
// int left = view.getLeft();
// int top = view.getTop() + (int) (p2 - p1);
// int width = view.getWidth();
// int height = view.getHeight();
// view.clearAnimation();
// view.layout(left, top, left + width, top + height);
}
});
view.startAnimation(animation);
}

 

转载于:https://www.cnblogs.com/feelaway/p/3503214.html

你可能感兴趣的文章
【VMCloud云平台】SCAP(一)规划
查看>>
Exchange 2016集成ADRMS系列-12:域内outlook 2010客户端测试
查看>>
【VMCloud云平台】拥抱Docker(六)关于DockerFile(1)
查看>>
庆祝教师节,李宁老师课程优惠劵疯抢中、会员卡优惠中,先到先得
查看>>
为Windows Server 2012 R2指定授权服务器
查看>>
Server 2008 R2 AD RMS完整部署:AD部署篇
查看>>
靠能力赚大钱,是最最可笑的谎言
查看>>
Azure运维系列 4:安装和使用Azure PowerShell管理云
查看>>
python写的监控mysql主从的app
查看>>
部署Windows Server Update Services 4.0
查看>>
财务自由之路——为什么选择淘宝(下)
查看>>
物联网概念升级,万物互联来袭
查看>>
Webpack4干货分享(二),使用loader处理scss,图片以及转换JS
查看>>
[转载]C 指针
查看>>
社交网站与网民隐私安全报告(2009)
查看>>
linux命令行抓取网页快照-(xvfb+CutyCapt)
查看>>
Adobe Dreamweaver 添加库、标签和属性
查看>>
深入Django(1): 通用视图 (generic views)
查看>>
dos2unix整个目录
查看>>
CentOS下python-mysqldb安装
查看>>