当前位置 主页 > 网站技术 > 代码类 >

    Android实现加载对话框

    栏目:代码类 时间:2020-01-30 15:05

    本文实例为大家分享了Android实现加载对话框的具体代码,供大家参考,具体内容如下

    这里简单说一下两种实现加载对话框的方式:1.使用动画让一个图片旋转 2.使用progressbar。

    感觉简单来说,dialog就是一个弹出的window,把自己定义的布局放置到window里面就可以了,加载对话框就是有个加载的动画,核心的地方就是实现这个动画,所所以方法  可以有,对图片添加动画,或者使用progressbar。

    第一种方式:使用动画让一个图片旋转

    先看一下布局:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:andro
     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:
      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,并对图片添加旋转动画:

    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() {//对图片添加旋转动画
     // 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:andro >
     
     <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:andro >
     
     <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>