Android實現(xiàn)加載對話框
本文實例為大家分享了Android實現(xiàn)加載對話框的具體代碼,供大家參考,具體內(nèi)容如下
這里簡單說一下兩種實現(xiàn)加載對話框的方式:1.使用動畫讓一個圖片旋轉(zhuǎn) 2.使用progressbar。
感覺簡單來說,dialog就是一個彈出的window,把自己定義的布局放置到window里面就可以了,加載對話框就是有個加載的動畫,核心的地方就是實現(xiàn)這個動畫,所所以方法 可以有,對圖片添加動畫,或者使用progressbar。
第一種方式:使用動畫讓一個圖片旋轉(zhuǎn)
先看一下布局:
<?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" android:background="@drawable/dialog_bg_while" android:orientation="vertical" > <ImageView android:layout_width="54dp" android:id="@+id/loading_dialog_pic" android:layout_height="54dp" android:layout_gravity="center_horizontal" android:layout_marginTop="15dp" android:background="@drawable/loading" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginTop="10dp" android:text="正在加載..." /> </LinearLayout>
然后自定義Alertdialog,并對圖片添加旋轉(zhuǎn)動畫:
public class LoadingDialog extends AlertDialog { private final String DEFAULT_TEXT="正在加載"; private ImageView mImageview; private TextView mTextView; private LinearLayout mLayout; private String mText; protected LoadingDialog(Context context) { super(context); // TODO Auto-generated constructor stub } @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); mLayout=(LinearLayout) LinearLayout.inflate(getContext(), R.layout.loading_dialog, null); mImageview=(ImageView) mLayout.findViewById(R.id.loading_dialog_pic); mTextView=(TextView) mLayout.findViewById(R.id.loading_dialog_text); loadanimation(); getWindow().setContentView(mLayout); } private void loadanimation() {//對圖片添加旋轉(zhuǎn)動畫 // TODO Auto-generated method stub Animation anim=AnimationUtils.loadAnimation(getContext(), R.anim.loading_dialog_anim); LinearInterpolator lin = new LinearInterpolator(); anim.setInterpolator(lin); mImageview.setAnimation(anim); } }
看一下xml的動畫:
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" > <rotate android:duration="1500" android:pivotX="50%" android:pivotY="50%" android:fromDegrees="0.0" android:repeatCount="infinite" android:toDegrees="-358" /> </set>
第二種方式:使用progressbar
首先是一個animation-list:
<?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" > <item android:drawable="@drawable/loading1" android:duration="100"/> <item android:drawable="@drawable/loading2" android:duration="100"/> <item android:drawable="@drawable/loading3" android:duration="100"/> <item android:drawable="@drawable/loading4" android:duration="100"/> <item android:drawable="@drawable/loading5" android:duration="100"/> <item android:drawable="@drawable/loading6" android:duration="100"/> <item android:drawable="@drawable/loading7" android:duration="100"/> <item android:drawable="@drawable/loading8" android:duration="100"/> </animation-list>
看一下布局的實現(xiàn):
<?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="wrap_content" android:background="@drawable/dialog_bg_while" android:orientation="vertical" > <ProgressBar style="@android:style/Widget.ProgressBar.Large" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginTop="10dp" android:indeterminateDrawable="@drawable/loading_animation_list" android:indeterminateDuration="1500" /> <View android:layout_width="match_parent" android:layout_height="1dp" android:background="#00BCD4" /> <TextView android:id="@+id/loading_dialog_text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginTop="10dp" android:text="正在加載..." /> </LinearLayout>
然后自定義一個alertdialog:
public class LoadingDialog extends AlertDialog { private final String DEFAULT_TEXT="正在加載"; private TextView mTextView; private LinearLayout mLayout; private String mText; protected LoadingDialog(Context context) { super(context); // TODO Auto-generated constructor stub } @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); mLayout=(LinearLayout) LinearLayout.inflate(getContext(), R.layout.loading_dialog, null); mTextView=(TextView) mLayout.findViewById(R.id.loading_dialog_text); WindowManager m=(WindowManager) getContext().getSystemService(getContext().WINDOW_SERVICE); int windowwith=m.getDefaultDisplay().getWidth(); int w=windowwith*3/5; int h=300; getWindow().setLayout(w, h);//設(shè)置對話框窗體大小 getWindow().setContentView(mLayout); } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
在AndroidManifest.xml中uses-sdk內(nèi)屬性意思
本文為大家講解下minSdkVersion、targetSdkVersion、maxSdkVersion、target API level四個數(shù)值的意思與區(qū)別,感興趣的朋友可以參考下哈2013-06-06Android開發(fā)工程中集成mob短信驗證碼功能的方法
這篇文章主要介紹了Android開發(fā)工程中集成mob短信驗證碼功能的方法,感興趣的小伙伴們可以參考一下2016-05-05FragmentTabHost FrameLayout實現(xiàn)底部導(dǎo)航欄
這篇文章主要為大家詳細(xì)介紹了FragmentTabHost和FrameLayout實現(xiàn)底部導(dǎo)航欄,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03Android安裝apk文件并適配Android 7.0詳解
這篇文章主要介紹了Android安裝apk文件并適配Android 7.0詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05