⑴ android里怎麼實現TextView裡面的文字一個一個逐漸顯示出來的動畫效果
在Android開發中,如果想要實現TextView中的文字一個一個逐漸顯示出來的動畫效果,可以採用自定義控制項的方式。具體實現步驟如下:
首先,需要創建一個自定義的View類,然後在該類中重寫onDraw()方法,以便於繪制文字。這一步是必要的,因為默認的TextView並不能滿足逐字顯示文字的需求。
接著,獲取需要顯示的文字內容。這部分代碼可以放在自定義View類的構造函數中,或者在外部調用時傳入需要顯示的文字。
為了實現逐字顯示文字的效果,可以使用Handler的postDelay()方法。這個方法可以實現延遲執行某個任務。通過設置適當的時間延遲,可以讓程序在指定的時間後執行顯示文字的任務。
在自定義View的onDraw()方法中,可以使用DrawText()方法來繪制文字。通過循環調用DrawText()方法,可以實現逐字顯示的效果。每次調用DrawText()時,只顯示一部分文字,然後通過Handler的postDelay()方法設定一定的時間延遲,讓程序在指定的時間後再次調用DrawText()方法,從而實現逐字顯示的效果。
值得注意的是,為了保證文字顯示的流暢性,可以適當調整postDelay()方法中的時間延遲值。如果時間間隔設置得太短,可能會導致文字顯示不夠流暢;而如果時間間隔設置得太長,則可能會使文字顯示效果過於緩慢。
通過這種方式,可以在Android應用中實現TextView中的文字一個一個逐漸顯示出來的動畫效果。這種方式不僅能夠增強界面的美觀性,還可以提高用戶體驗。
⑵ 如何通過android實現alpha漸變動畫效果
Android動畫分為四種:alpha(漸變透明度),scale(漸變尺寸伸縮),translate(畫面轉換位置移動),rotate(畫面轉移旋轉);今天先寫第一個動畫alpha。
動畫效果有兩種實現:
一、在xml中定義:
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<!-- 透明度控制動畫效果 alpha
浮點型值:
fromAlpha 屬性為動畫起始時透明度
toAlpha 屬性為動畫結束時透明度
說明:
0.0表示完全透明
1.0表示完全不透明
以上值取0.0-1.0之間的float數據類型的數字
長整型值:
ration 屬性為動畫持續時間
說明:
時間以毫秒為單位
-->
<alpha
android:fromAlpha="0.1"
android:toAlpha="1.0"
android:ration="5000"
/>
</set>
二、在頁面Activity中聲明:
Animation animation = new AlphaAnimation(0.1f, 1.0f);
animation.setDuration(5000);
完成動畫漸變透明度的參數設定後,我們就要開始在應用中使用它:
public class SplashActivity extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.welcome);
View view = View.inflate(SplashActivity.this, R.layout.welcome, null);
setContentView(view);
//動畫效果參數直接定義
Animation animation = new AlphaAnimation(0.1f, 1.0f);
animation.setDuration(5000);
//動畫效果從XMl文件中定義
// Animation animation = AnimationUtils.loadAnimation(this, R.anim.alpha);
view.setAnimation(animation);
}
}
這樣我們就完成了預定的動畫效果,但是我們的最終目的是動畫效果完畢以後跳轉到相應的頁面,所以我們對動畫添加了監聽:
animation.setAnimationListener(new AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
// TODO Auto-generated method stub
}
@Override
public void onAnimationRepeat(Animation animation) {
// TODO Auto-generated method stub
}
@Override
public void onAnimationEnd(Animation animation) {
// TODO Auto-generated method stub
Intent intent = new Intent(SplashActivity.this,MainActivity.class);
startActivity(intent);
}
});
這樣的話,我們在動畫的持續時間中預載入我們的資源,當動畫結束以後跳轉到我們的主頁面;
詳細步驟和完整源碼可以參考:http://www.cnblogs.com/sishuiliuyun/p/3167581.html