Android项目中使用自定义进度加载Dialog
2015-04-25 15:03
387 查看
Android项目中使用自定义进度加载Dialog
效果图一:
项目中使用的效果图二:
直接运行之后的效果即如上图一中所示!
但无法达到在项目中使用的便捷性,不可能每一个需要用到此Dialog的地方都需要在相应的xml文件中定义该ProgressBar的控件吧,如果开发中界面使用多层次的FrameLayout和多层次的布局,这就是个麻烦问题了。
下文将改 ProgressBar 单独定义为一个xml,并通过定义单独方法动态将其加入布局中,使用时直接通过基类的Activity初始化便可以在整个应用程序中调用。
注:此处为父布局添加 android:background="@android:color/transparent" 属性,使布局透明。
注:此方法中设置了 loadingDialog.setCancelable(false); 即:不可以用"返回键"取消,若不需要可注释掉。
BaseActivity
MainActivity
源码下载:http://download.csdn.net/download/gao_chun/8631127
转载请注明出处.
效果图一:
项目中使用的效果图二:
1.首先定义动画文件
<?xml version="1.0" encoding="utf-8"?> <animated-rotate xmlns:android="http://schemas.android.com/apk/res/android" android:drawable="@drawable/loading2" android:fromDegrees="0.0" android:pivotX="50.0%" android:pivotY="50.0%" android:toDegrees="360.0" />
2.在main.xml文件中直接定义ProgressBar便可显示
<?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:orientation="vertical" android:gravity="center"> <ProgressBar android:id="@+id/progress" style="?android:attr/progressBarStyleSmall" android:layout_width="25dip" android:layout_height="30dip" android:indeterminateDrawable="@anim/progress_bar" /> </LinearLayout>
直接运行之后的效果即如上图一中所示!
但无法达到在项目中使用的便捷性,不可能每一个需要用到此Dialog的地方都需要在相应的xml文件中定义该ProgressBar的控件吧,如果开发中界面使用多层次的FrameLayout和多层次的布局,这就是个麻烦问题了。
下文将改 ProgressBar 单独定义为一个xml,并通过定义单独方法动态将其加入布局中,使用时直接通过基类的Activity初始化便可以在整个应用程序中调用。
第一步:
定义单独的 layout_loading_dialog.xml 文件<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/dialog_view" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@android:color/transparent" android:gravity="center_vertical|center" > <ProgressBar style="?android:attr/progressBarStyleSmall" android:layout_width="25dip" android:layout_height="30dip" android:indeterminateDrawable="@anim/progress_bar" /> </LinearLayout>
注:此处为父布局添加 android:background="@android:color/transparent" 属性,使布局透明。
第二步:
定义方法加载创建 Dialog/** * 创建自定义ProgressDialog * * @param context * @return */ public static Dialog createLoadingDialog(Context context) { LayoutInflater inflater = LayoutInflater.from(context); View v = inflater.inflate(R.layout.layout_loading_dialog, null); // 得到加载view LinearLayout layout = (LinearLayout) v.findViewById(R.id.dialog_view); // 加载布局 Dialog loadingDialog = new Dialog(context, R.style.loading_dialog); // 创建自定义样式dialog loadingDialog.setCancelable(false); // 不可以用"返回键"取消 loadingDialog.setContentView(layout, new LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT)); return loadingDialog; }
注:此方法中设置了 loadingDialog.setCancelable(false); 即:不可以用"返回键"取消,若不需要可注释掉。
第三步:
在调用时先在基类的BaseActiviy中初始化,然后在开始Request数据的回调方法中直接调用mLoading.show()BaseActivity
package org.gaochun.ui; import android.app.Activity; import android.app.Dialog; import android.os.Bundle; /** * @author gao_chun * 该类为Activity基类 */ public class BaseActivity extends Activity { public static final String TAG = "gao_chun"; //在基类中初始化Dialog public Dialog mLoading; /* (non-Javadoc) * @see android.app.Activity#onCreate(android.os.Bundle) */ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); /*if (!ValidateUtils.isNetworkAvailable(this)){ DialogUtils.showToast(this,R.string.text_network_unavailable); }*/ mLoading = DialogUtils.createLoadingDialog(this); } }
MainActivity
package org.gaochun.ui; import android.os.Bundle; import org.gaochun.R; public class MainActivity extends BaseActivity { @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setUpViews(); } private void setUpViews(){ setContentView(R.layout.main); /**************************************** * 只需要在此处调用show()方法 * 注:可在访问网络开始时的回调方法中调用 * 在访问结束后再 mLoading.dismiss(); **************************************/ mLoading.show(); } }
源码下载:http://download.csdn.net/download/gao_chun/8631127
转载请注明出处.
相关文章推荐
- Android项目中使用自定义进度加载Dialog
- Android提高篇之自定义dialog实现processDialog“正在加载”效果、使用Animation实现图片旋转
- Android提高篇之自定义dialog实现processDialog“正在加载”效果、使用Animation实现图片旋转
- 【Android自定义View实战】之自定义项目通用的加载等待对话框LoadingDialog
- Android 之自定义加载Dialog
- Android自定义View之仿微信小视频加载进度条
- Android Webview使用自定义字体加载网页
- Android自定义之仿支付宝支付成功、失败状态的加载进度
- 【Android开源项目分析】自定义圆形头像CircleImageView的使用和源码分析
- android中dialog(自定义dialog)的使用方法!!!
- Android 使用DisplayImageOptions加载头像 自定义圆形头像
- 简单实现的自定义圆环进度条,可使用于文件的上传下载图片加载等地方.
- Android 自定义加载框dialog
- Android使用DialogFragment,自定义对话框
- Android项目使用Dcloud架构处理极光推送跳转以及加载JS回调方法
- 使用Gradle构建Android项目的一些自定义配置
- android自定义加载数据动画dialog和简单的timer计时器
- 【Android UI】自定义圆形SeekBar和自定义Dialog的结合使用
- android之自定义webView之头部进度加载效果
- 【Android开源项目分析】自定义圆形头像CircleImageView的使用和源码分析