zoukankan      html  css  js  c++  java
  • dialog实现自定义动画progress

    上章写了一个dialog实现自定义静态图的demo,现在来现实播放自定义动画的进度条

    一.先导入动画,这边是不可以直接加载gif动态图片的,所以要把它打散,我使用了工具Easy GIF Animator

     导入gif 图片

    然后右击任何一张图片,有个select all frame , 全选之后,在工具栏上有一个frame--export selected frames  就导出了所有帧图片

    二.在工程中res文件夹新建一个drawable文件夹,把图片导入,再建一个animal_pro.xml

    animal_pro.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <animation-list android:oneshot="false"
        xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:duration="20" android:drawable="@drawable/car00" />
        
        <item android:duration="20" android:drawable="@drawable/car01" />
        <item android:duration="20" android:drawable="@drawable/car02" />
        <item android:duration="20" android:drawable="@drawable/car03" />
        <item android:duration="20" android:drawable="@drawable/car04" />
        <item android:duration="20" android:drawable="@drawable/car05" />
        
         <item android:duration="20" android:drawable="@drawable/car06" />
        <item android:duration="20" android:drawable="@drawable/car07" />
        <item android:duration="20" android:drawable="@drawable/car08" />
        <item android:duration="20" android:drawable="@drawable/car09" />
        <item android:duration="20" android:drawable="@drawable/car10" />
        
         <item android:duration="20" android:drawable="@drawable/car11" />
        <item android:duration="20" android:drawable="@drawable/car12" />
        <item android:duration="20" android:drawable="@drawable/car13" />
        <item android:duration="20" android:drawable="@drawable/car14" />
        <item android:duration="20" android:drawable="@drawable/car15" />
        
         <item android:duration="20" android:drawable="@drawable/car16" />
        <item android:duration="20" android:drawable="@drawable/car17" />
        <item android:duration="20" android:drawable="@drawable/car18" />
        <item android:duration="20" android:drawable="@drawable/car19" />
        <item android:duration="20" android:drawable="@drawable/car20" />
        
         <item android:duration="20" android:drawable="@drawable/car21" />
        <item android:duration="20" android:drawable="@drawable/car22" />
        <item android:duration="20" android:drawable="@drawable/car23" />
        <item android:duration="20" android:drawable="@drawable/car24" />
        <item android:duration="20" android:drawable="@drawable/car25" />
        
         <item android:duration="20" android:drawable="@drawable/car26" />
        <item android:duration="20" android:drawable="@drawable/car27" />
        <item android:duration="20" android:drawable="@drawable/car28" />
        <item android:duration="20" android:drawable="@drawable/car29" />
        <item android:duration="20" android:drawable="@drawable/car30" />
        
        <item android:duration="20" android:drawable="@drawable/car31" />
        <item android:duration="20" android:drawable="@drawable/car32" />
        <item android:duration="20" android:drawable="@drawable/car33" />
        <item android:duration="20" android:drawable="@drawable/car34" />
        
    </animation-list> 

    三.建立一个dialog的view..progress.xml

    <?xml version="1.0" encoding="utf-8"?>
     
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
     android:orientation="vertical" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content"
     android:id="@+id/progress_img"
        >
        
        <ImageView 
            android:id="@+id/animal_img"
            android:layout_width="wrap_content" 
            android:layout_height="wrap_content"
            android:src="@drawable/ic_mytce"
            />
        
      </RelativeLayout>


    java代码

    四.先建一个dialog加载动画视图

          //进程图片加载框
          public   AlertDialog.Builder dialog_progress()
          {
               AlertDialog.Builder builder = new Builder(LinkMap.this);
               View view =super.getLayoutInflater().inflate(R.layout.progress,(ViewGroup) findViewById(R.id.progress_img)); 
              final  ImageView iv=(ImageView)view.findViewById(R.id.animal_img);
               iv.setImageResource(R.drawable.animal_pro);//绑定数据源
              //启动 动画,因为如果没有启动方法,它没办法自己启动
              iv.post(new Runnable() {
                    
                    @Override
                    public void run() {
                        // TODO Auto-generated method stub
                    AnimationDrawable  animationDrawable=(AnimationDrawable)iv.getDrawable();//获取imageview绘画
                    animationDrawable.start();//开始绘画
                    
                    }
                });
            
              
              
    //           new Thread(new Runnable() {
    //            
    //            @Override
    //            public void run() {
    //                // TODO Auto-generated method stub
    //            AnimationDrawable  animationDrawable=(AnimationDrawable)iv.getDrawable();//获取imageview绘画
    //            animationDrawable.start();//开始绘画
    //            
    //            }
    //        }).start();//同一个mt,但是在Thread中就不可以,如果用同一
              
               builder.setView(view);
               return builder;
               
          }


    五.初始时显示进度条

      public void onCreate(Bundle savedInstanceState) {
    	      
    		 super.onCreate(savedInstanceState);
    	         setContentView(R.layout.map);
    	          
    	 	  
    	        //进程加载
    	          dialog_pro=dialog_progress().create();
    	          dialog_pro.show();
    
    }

      

     效果如下:

    Crazy Cherry:everything is possible!
  • 相关阅读:
    立方和等式 考虑方程式:a^3 + b^3 = c^3 + d^3 其中:“^”表示乘方。a、b、c、d是互不相同的小于30的正整数。
    iOS 响应链
    Android驱动使用JNI调用
    [置顶] OGG01091 Unable to open file (error 89, Invalid file system control data detected)
    Unix 系统信号集与编程
    跟我一起玩Win32开发(23):渐变颜色填充
    android webservice 简单应用
    lisk之初发布
    美妙的微机原理2013/4/22
    android 腾讯微博登录小demo
  • 原文地址:https://www.cnblogs.com/userbibi/p/2467845.html
Copyright © 2011-2022 走看看