300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > Android 三种方式实现自定义圆形页面加载中效果的进度条

Android 三种方式实现自定义圆形页面加载中效果的进度条

时间:2022-04-11 20:41:07

相关推荐

Android 三种方式实现自定义圆形页面加载中效果的进度条

转载:/forum.php?mod=viewthread&tid=76872

一、通过动画实现

定义res/anim/loading.xml如下:

[java]view plaincopy<?xmlversion="1.0"encoding="UTF-8"?><animation-listandroid:oneshot="false"xmlns:android="/apk/res/android"><itemandroid:duration="150"android:drawable="@drawable/loading_01"/><itemandroid:duration="150"android:drawable="@drawable/loading_02"/><itemandroid:duration="150"android:drawable="@drawable/loading_03"/><itemandroid:duration="150"android:drawable="@drawable/loading_04"/><itemandroid:duration="150"android:drawable="@drawable/loading_05"/><itemandroid:duration="150"android:drawable="@drawable/loading_06"/><itemandroid:duration="150"android:drawable="@drawable/loading_07"/></animation-list>

在layout文件中引用如下:

[java]view plaincopy<ProgressBarandroid:id="@+id/loading_process_dialog_progressBar"android:layout_width="wrap_content"android:layout_height="wrap_content"android:indeterminate="false"android:indeterminateDrawable="@anim/loading"/>

二、通过自定义颜色实现

定义res/drawable/dialog_style_xml_color.xml如下:

[java]view plaincopy<?xmlversion="1.0"encoding="utf-8"?><rotatexmlns:android="/apk/res/android"android:pivotX="50%"android:pivotY="50%"android:fromDegrees="0"android:toDegrees="360"><shapeandroid:shape="ring"android:innerRadiusRatio="3"android:thicknessRatio="8"android:useLevel="false"><gradientandroid:type="sweep"android:useLevel="false"android:startColor="#FFFFFF"android:centerColor="#FFDC35"android:centerY="0.50"android:endColor="#CE0000"/></shape></rotate>

在layout文件中引用如下:

[java]view plaincopy<ProgressBarandroid:id="@+id/loading_process_dialog_progressBar"android:layout_width="wrap_content"android:layout_height="wrap_content"android:indeterminate="false"android:indeterminateDrawable="@drawable/dialog_style_xml_color"/>

三、使用一张图片进行自定义

定义res/drawable/dialog_style_xml_icon.xml如下:

[java]view plaincopy<?xmlversion="1.0"encoding="utf-8"?><layer-listxmlns:android="/apk/res/android"><item><rotateandroid:drawable="@drawable/dialog_progress_round"android:fromDegrees="0.0"android:toDegrees="360.0"android:pivotX="50.0%"android:pivotY="50.0%"/></item></layer-list>

在layout文件中引用如下:

[html]view plaincopy <ProgressBarandroid:id="@+id/loading_process_dialog_progressBar"android:layout_width="wrap_content"android:layout_height="wrap_content"android:indeterminate="false"android:indeterminateDrawable="@drawable/dialog_style_xml_icon"/>

main.xml如下:

[html]view plaincopy <?xmlversion="1.0"encoding="utf-8"?><LinearLayoutxmlns:android="/apk/res/android"android:orientation="vertical"android:layout_width="fill_parent"android:layout_height="fill_parent"android:gravity="center"android:background="#FFF"><Buttonandroid:text="@string/anim"android:id="@+id/anim"android:layout_width="120dip"android:layout_height="wrap_content"/><Buttonandroid:text="@string/color"android:id="@+id/color"android:layout_width="120dip"android:layout_height="wrap_content"/><Buttonandroid:text="@string/icon"android:id="@+id/icon"android:layout_width="120dip"android:layout_height="wrap_content"/></LinearLayout>

之后通过三个按钮将ProgressBar 放在对话框中显示出来就完成了。

AnimRoundProcessDialog.rar

截图如下:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。