2019独角兽企业重金招聘Python工程师标准>>> hot3.png

Android自定义类似ProgressDialog效果的Dialog.

方法如下:

1.首先准备两张自己要定义成哪样子的效果的图片和背景图片(也可以不要背景)。

如我要的效果:

2.定义loading_dialog.xml布局文件(这里你也可以按自己的布局效果定义,关键是要有个imageView):

[html] view plaincopy

<EMBED id=ZeroClipboardMovie_1 height=18 name=ZeroClipboardMovie_1 type=application/x-shockwave-flash align=middle pluginspage=http://www.macromedia.com/go/getflashplayer width=18 src=http://static.blog.csdn.net/scripts/ZeroClipboard/ZeroClipboard.swf wmode="transparent" flashvars="id=1&width=18&height=18" allowfullscreen="false" allowscriptaccess="always" bgcolor="#ffffff" quality="best" menu="false" loop="false">

  1. <?xmlversion="1.0"encoding="utf-8"?>

  2. <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"

  3. android:id="@+id/dialog_view"

  4. android:orientation="vertical"

  5. android:layout_width="fill_parent"

  6. android:layout_height="fill_parent"

  7. android:minHeight="60dp"

  8. android:minWidth="180dp"

  9. android:gravity="center"

  10. android:padding="10dp"

  11. android:background="@drawable/loading_bg">

  12. <ImageView

  13. android:id="@+id/img"

  14. android:layout_width="wrap_content"

  15. android:layout_height="wrap_content"

  16. android:src="@drawable/publicloading"

  17. />

  18. <TextView

  19. android:id="@+id/tipTextView"

  20. android:layout_width="wrap_content"

  21. android:layout_height="wrap_content"

  22. android:layout_marginLeft="10dp"

  23. android:text="数据加载中……"/>

  24. </LinearLayout>

3.定义一个loadingDialog中imageView转动的动画:loading_animation.xml

[html] view plaincopy

<EMBED id=ZeroClipboardMovie_2 height=18 name=ZeroClipboardMovie_2 type=application/x-shockwave-flash align=middle pluginspage=http://www.macromedia.com/go/getflashplayer width=18 src=http://static.blog.csdn.net/scripts/ZeroClipboard/ZeroClipboard.swf wmode="transparent" flashvars="id=2&width=18&height=18" allowfullscreen="false" allowscriptaccess="always" bgcolor="#ffffff" quality="best" menu="false" loop="false">

  1. <?xmlversion="1.0"encoding="utf-8"?>

  2. <setandroid:shareInterpolator="false"xmlns:android="http://schemas.android.com/apk/res/android">

  3. <rotate

  4. android:interpolator="@android:anim/linear_interpolator"

  5. android:pivotX="50%"

  6. android:pivotY="50%"

  7. android:fromDegrees="0"

  8. android:toDegrees="+360"

  9. android:duration="1500"

  10. android:startOffset="-1"

  11. android:repeatMode="restart"

  12. android:repeatCount="-1"/>

  13. </set>

4.定义dialog的style.

[java] view plaincopy

<EMBED id=ZeroClipboardMovie_3 height=18 name=ZeroClipboardMovie_3 type=application/x-shockwave-flash align=middle pluginspage=http://www.macromedia.com/go/getflashplayer width=18 src=http://static.blog.csdn.net/scripts/ZeroClipboard/ZeroClipboard.swf wmode="transparent" flashvars="id=3&width=18&height=18" allowfullscreen="false" allowscriptaccess="always" bgcolor="#ffffff" quality="best" menu="false" loop="false">

  1. <!-- 自定义loading dialog -->

  2. <style name="loading_dialog"parent="android:style/Theme.Dialog">

  3. <item name="android:windowFrame">@null</item>

  4. <item name="android:windowNoTitle">true</item>

  5. <item name="android:windowBackground">@drawable/loading_bg</item>

  6. <item name="android:windowIsFloating">true</item>

  7. <item name="android:windowContentOverlay">@null</item>

  8. </style>

5.写点创建Dialog的代码,你可以自己封装成一个方法。

[java] view plaincopy

<EMBED id=ZeroClipboardMovie_4 height=18 name=ZeroClipboardMovie_4 type=application/x-shockwave-flash align=middle pluginspage=http://www.macromedia.com/go/getflashplayer width=18 src=http://static.blog.csdn.net/scripts/ZeroClipboard/ZeroClipboard.swf wmode="transparent" flashvars="id=4&width=18&height=18" allowfullscreen="false" allowscriptaccess="always" bgcolor="#ffffff" quality="best" menu="false" loop="false">

  1. /**

  2. * 得到自定义的progressDialog

  3. * @param context

  4. * @param msg

  5. * @return

  6. */

  7. publicstaticDialog createLoadingDialog(Context context, String msg) {

  8. LayoutInflater inflater = LayoutInflater.from(context);

  9. View v = inflater.inflate(R.layout.loading_dialog, null);// 得到加载view

  10. LinearLayout layout = (LinearLayout) v.findViewById(R.id.dialog_view);// 加载布局

  11. // main.xml中的ImageView

  12. ImageView spaceshipImage = (ImageView) v.findViewById(R.id.img);

  13. TextView tipTextView = (TextView) v.findViewById(R.id.tipTextView);// 提示文字

  14. // 加载动画

  15. Animation hyperspaceJumpAnimation = AnimationUtils.loadAnimation(

  16. context, R.anim.load_animation);

  17. // 使用ImageView显示动画

  18. spaceshipImage.startAnimation(hyperspaceJumpAnimation);

  19. tipTextView.setText(msg);// 设置加载信息

  20. Dialog loadingDialog = newDialog(context, R.style.loading_dialog);// 创建自定义样式dialog

  21. loadingDialog.setCancelable(false);// 不可以用“返回键”取消

  22. loadingDialog.setContentView(layout, newLinearLayout.LayoutParams(

  23. LinearLayout.LayoutParams.FILL_PARENT,

  24. LinearLayout.LayoutParams.FILL_PARENT));// 设置布局

  25. returnloadingDialog;

  26. }

最后来张整体的效果图:

转载于:https://my.oschina.net/rainy123/blog/293153

Android自定义类似ProgressDialog效果的Dialog相关推荐

  1. Android自定义底部带有动画的Dialog

    Android自定义底部带有动画的Dialog 效果图 先看效果图,是不是你想要的呢 自定义Dialog package --.view;import android.app.Dialog; impo ...

  2. Android自定义底部弹出窗-dialog(2种实现分析+源码)

    Android自定义底部弹出窗-dialog(2种实现分析+源码) 上线项目功能抽取,在项目开发中,我们会在许多地方会用到底部自定义弹窗,比如设置:个人账户退出,切换,照片的拍照或者相册的调出,或者一 ...

  3. [Android]自定义View带效果的滚动数字

    [Android]自定义View带效果的滚动数字 @Author GQ 2016年07月29日 一个可以让数字滚动的View,可以自定义参数,是想要的那种效果! 原文github地址 效果图 Andr ...

  4. 自定义实现ProgressDialog样式的Dialog

    1.  建立一个my_progress_dialog.xml布局文件 <?xml version="1.0" encoding="utf-8"?> ...

  5. android 自定义view 动画效果,Android自定义view实现阻尼效果的加载动画

    效果: 需要知识: 1. 二次贝塞尔曲线 2. 动画知识 3. 基础自定义view知识 先来解释下什么叫阻尼运动 阻尼振动是指,由于振动系统受到摩擦和介质阻力或其他能耗而使振幅随时间逐渐衰减的振动,又 ...

  6. Android 自定义View 时钟效果

    Android 自定义时钟浅析 最有趣,最好玩的东西,一定是高度灵活的东西,今天我们以自定义View的方式来实现一个表盘样式的时钟,并自动设置为当前时间,因为感觉网上的直接能运行的代码很少,思路也很麻 ...

  7. android 自定义透明progressdialog,在android中自定义progressdialog动态创建

    我动态地在asynctask中创建了progressdialog.我为我的应用程序使用自定义样式.当我这样做,我的progressdialog风格改为白色我需要我的黑色默认风格与白色文本. 我的jav ...

  8. android 自定义view 动画效果,Android自定义view----音乐播放动画

    先给大家看一下效果,因为我也不知道这个东西具体叫什么,标题上面写的是"音乐播放动画",可能描述的不太准确. 效果图.gif 前言 最近项目中做了一个音频播放的功能,播放条上需要一个 ...

  9. Android自定义实现点赞效果!

    前言 今天朋友看了HenCoder的自定义View后说,HenCoder对自定义View讲的不错.实践中仿写即刻的点赞你有思路吗,你不实现一下?二话不说,看了朋友手机效果,对他说:实现不难,用到了位移 ...

最新文章

  1. 64位oracle客户端_开发小记-golang连接Oracle数据库配置
  2. EveryNote使用说明,好用的文件备注搜索工具
  3. 用Heartbeat实现web服务器高可用
  4. java流程控制if_java程序流程控制(分支结构之 if-else)
  5. 大数据可视化的价值体现在哪
  6. FRR -- CLI简要分析
  7. 科沃斯扫地机器人电路原理图_科沃斯扫地机器人不工作故障维修(CEN550)
  8. Android实现友盟分享小程序
  9. linux下c语言读写文件操作,Linux下C语言之文件操作
  10. python openpyxl冻结首行单元格
  11. linux 设置mail
  12. python PIL使用记录
  13. 三年级计算机怎么进入到游戏,三年级开始,带孩子玩7个游戏训练成“最强大脑”...
  14. Android逆向:去除RE管理器4.41及车来了广告
  15. Java中的四种XML解析方式(一)
  16. “杏”运有你!共赏这乡美景
  17. 基于ODBC的MFC与sql_server2008r2连接教程和错误解决方法
  18. 鸿蒙系统用什么用,【图片】华为鸿蒙系统的厉害之处在于 你可能非用不可 !【手机吧】_百度贴吧...
  19. 浙江计算机二级考哪些专业好,浙江省计算机二级都考什么
  20. 万年历java课程设计报告_java《万年历系统》课程设计报告附源码.doc

热门文章

  1. vs2008编写第一个Windows程序
  2. 在线字符串长度计算,字符串统计工具
  3. 实体类 接口_Java 语言基础编程题 (二维数组, 五子棋游戏, 实体类和接口)
  4. 《空中交通管理基础》-潘卫军主编-第三章-航空器和飞行高度层
  5. 64. 合并排序数组 II
  6. tp中url地址大小写问题
  7. highCharts图表入门简介
  8. 设计模式 - Prototype模式(原型模式)
  9. ASP.net报错汇总: This application is currently offline.
  10. 使用某些 DOCTYPE 时会导致 document.body.scrollTop 失效