今天用到了ScrollView scrollTo方法 发现还是有一些地方需要注意 它是瞬间完成的,这里使用了一些方法实现慢慢移动的动画效果,所以记录一下。
效果图:
有点大。。。。
打开程序 会计算第一个Textview的高度 这里使用了ViewTreeObserver来得到view的高度,因为这个监听是在view计算出大小之后首先调用的方法,所以我们可以避免getWidth getHeight等于0的状况。
献上布局文件看下:
<?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/sv_menu" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@drawable/notifacation_background" android:scrollbars="none" > <LinearLayout android:id="@+id/ll_tt" android:layout_width="fill_parent" android:layout_height="wrap_content" android:gravity="center_horizontal" android:orientation="vertical" > <TextView android:id="@+id/tv_01" android:layout_width="250dip" android:layout_height="250dip" android:layout_marginTop="10px" android:background="@drawable/notifacation_background" android:text="一去二三里" android:textColor="#000000" android:textSize="22sp" android:textStyle="bold" android:gravity="center"/> <TextView android:layout_width="250dip" android:layout_height="250dip" android:layout_marginTop="10dip" android:background="@drawable/notifacation_background" android:text="烟村四五家" android:textColor="#000000" android:textSize="22sp" android:textStyle="bold" android:gravity="center" /> <TextView android:layout_width="250dip" android:layout_height="250dip" android:layout_marginTop="10px" android:background="@drawable/notifacation_background" android:text="亭台六七座" android:textColor="#000000" android:textSize="22sp" android:textStyle="bold" android:gravity="center" /> <TextView android:layout_width="250dip" android:layout_height="250dip" android:layout_marginTop="10px" android:background="@drawable/notifacation_background" android:text="八九十枝花" android:textColor="#000000" android:textSize="22sp" android:textStyle="bold" android:gravity="center" /> </LinearLayout> </ScrollView>很简单, 不过写的不是很规范。。。
实现的Activity就很简单的 不过注意的点都在这里了:
import android.app.Activity;
import android.os.Bundle;
import android.os.CountDownTimer;
import android.view.ViewGroup;
import android.view.ViewTreeObserver.OnPreDrawListener;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.TextView;
public class AActivity extends Activity {
private ScrollView svMenu; //需要滚动
private TextView tv01; //我们要用到它的高度信息
private boolean isScroll = false; // OnPreDrawListener是多次调用的 只要拖动都会有调用 所以得到值后加标记
private int scrollY = 0; // 不用多说了 滚动的距离
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
super.setContentView(R.layout.new_activity);
svMenu = (ScrollView) findViewById(R.id.sv_menu);
tv01 = (TextView) findViewById(R.id.tv_01);
//注册监听器
tv01.getViewTreeObserver().addOnPreDrawListener(preDrawListener);
}
private OnPreDrawListener preDrawListener = new OnPreDrawListener() {
@Override
public boolean onPreDraw() {
if (!isScroll) {
isScroll = true;
// 这里我有margin 所以得到margin
ViewGroup.LayoutParams p = tv01.getLayoutParams();
if (p != null && p instanceof LinearLayout.LayoutParams) {
LinearLayout.LayoutParams lp = (LinearLayout.LayoutParams) p;
scrollY = tv01.getHeight() + lp.topMargin;
}
System.out.println("高度: " + scrollY);
// 这个timer执行scrollY毫秒 每1毫秒回调一次
new CountDownTimer(scrollY, 1) {
public void onTick(long millisUntilFinished) {
System.out.println("finished: " + millisUntilFinished);
svMenu.scrollTo(0,
(int) (scrollY - millisUntilFinished));
}
public void onFinish() {
System.out.println("done!");
svMenu.scrollTo(0, scrollY);
}
}.start();
// remove 必须重新得到 之前用了ViewTreeObserver的对象 remove会报错
tv01.getViewTreeObserver().removeOnPreDrawListener(
preDrawListener);
}
return true;
}
};
}
源地址:http://751401909.iteye.com/admin/blogs/1920553
这样具有动画效果的ScrollView scrollTo 就完成了。如果大家有什么好的建议或者方法 提出来大家一起研究。