android--利用Animation.RELATIVE_TO_SELF做出個性化的動畫

在Android開發中,Animation是用來給控件製作效果的。大多數的控件都可以用這個類,這個類包含了4種基本動作,分別爲移動旋轉淡入淡出縮放

使用Animation的兩種方式:

方式一:在代碼中創建、設置以及啓動動畫(移動TranslateAnimation/旋轉RotateAnimation/淡入淡出AlphaAnimation/縮放ScaleAnimation),這樣的優點是可以方便調試程序效果;

方式二:在xml中對控件的屬性做設置,好處是代碼的重用性比較高,缺點是不方便調試。

下面我們重點針對代碼創建的方式來舉例:

在開始示例之前我們普及兩個非常重要的參考標準:Animation.RELATIVE_TO_SELF(相對於自身)、Animation.RELATIVE_TO_PARENT(相對於父控件(容器))。

1、imageView控件由完全透明到完全不透明變化,持續時間爲0.2s;

	private void toVisibleAnim(View view)
	{
		AlphaAnimation alphaAnimation = new AlphaAnimation(0.0f, 1.0f);
		alphaAnimation.setDuration(200);
		view.startAnimation(alphaAnimation);
	}

2、imageView控件由原來大小尺寸沿自身尺寸中心逐漸縮放到0,持續時間爲0.2s;

	private void toHideAnim(View view)
	{
		ScaleAnimation scaleAnimation = new ScaleAnimation(1.0f, 0.0f, 1.0f, 0.0f, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
		scaleAnimation.setDuration(200);
		view.startAnimation(scaleAnimation);
	}

3、imageView控件以自身中心爲圓心旋轉90度,持續時間爲0.2s;

	private void rotateAnim(View view)
	{
		view.setVisibility(View.VISIBLE);
		RotateAnimation rotateAnimation = new RotateAnimation(0, 90, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
		rotateAnimation.setDuration(200);
		view.startAnimation(rotateAnimation);
	}

4、imageView控件從自身位置的最右端開始向左水平滑動了自身的寬度,持續時間爲0.2s;

	private void showScrollAnim(View view) {
		view.setVisibility(View.VISIBLE);
		TranslateAnimation mShowAction = new TranslateAnimation(
				Animation.RELATIVE_TO_SELF, 1.0f, Animation.RELATIVE_TO_SELF,
				0.0f, Animation.RELATIVE_TO_SELF, 0.0f,
				Animation.RELATIVE_TO_SELF, 0.0f);
		mShowAction.setDuration(200);
		view.startAnimation(mShowAction);
	}

5、image控件從自身位置的最左端開始水平向右滑動隱藏動畫,持續時間0.2s

	private void hiddenScrollAnim(LinearLayout view) {
		view.setVisibility(View.GONE);
		TranslateAnimation mHiddenAction = new TranslateAnimation(
				Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
				1.0f, Animation.RELATIVE_TO_SELF, 0.0f,
				Animation.RELATIVE_TO_SELF, 0.0f);
		mHiddenAction.setDuration(200);
		view.startAnimation(mHiddenAction);
	}


發佈了105 篇原創文章 · 獲贊 18 · 訪問量 65萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章