日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網(wǎng)站首頁 編程語言 正文

Android實現(xiàn)多張圖片合成加載動畫_Android

作者:hello_1s ? 更新時間: 2022-09-19 編程語言

本文實例為大家分享了Android實現(xiàn)多張圖片合成加載動畫的具體代碼,供大家參考,具體內(nèi)容如下

1、自定義ProgressDialog

public class MyProgressDialog extends ProgressDialog {
? ? private int procressLoadRes;
? ? private ImageView mImageView;
? ? private AnimationDrawable animationDrawable;

? ? public MyProgressDialog(Context context,int procressLoadRes) {
? ? ? ? super(context);
? ? ? ? this.procressLoadRes = procressLoadRes;
? ? }

? ? public MyProgressDialog(Context context, int theme, int procressLoadRes) {
? ? ? ? super(context, theme);
? ? ? ? this.procressLoadRes = procressLoadRes;
? ? }

? ? @Override
? ? protected void onCreate(Bundle savedInstanceState) {
? ? ? ? super.onCreate(savedInstanceState);
? ? ? ? setContentView(R.layout.layout_progress);
? ? ? ? mImageView = (ImageView) findViewById(R.id.image);
? ? ? ? //設置動畫背景
? ? ? ? mImageView.setBackgroundResource(procressLoadRes);
? ? ? ? //獲取動畫對象,必須在上一步之后
? ? ? ? animationDrawable = (AnimationDrawable) mImageView.getBackground();
? ? ? ? mImageView.post(new Runnable() {
? ? ? ? ? ? @Override
? ? ? ? ? ? public void run() {
? ? ? ? ? ? ? ? //啟動動畫
? ? ? ? ? ? ? ? animationDrawable.start();
? ? ? ? ? ? }
? ? ? ? });
? ? }
}

2、MyProgressDialog對應的布局layout_progress.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
? ? android:orientation="vertical"
? ? android:layout_width="match_parent"
? ? android:layout_height="match_parent"
? ? android:gravity="center"
? ? android:background="@null">

? ? <ImageView
? ? ? ? android:id="@+id/image"
? ? ? ? android:layout_width="wrap_content"
? ? ? ? android:layout_height="wrap_content" />
</LinearLayout>

3、使用自定義的MyProgressDialog

public class MainActivity extends AppCompatActivity {

? ? private Button button;
? ? private MyProgressDialog progressDialog;
? ? @Override
? ? protected void onCreate(Bundle savedInstanceState) {
? ? ? ? super.onCreate(savedInstanceState);
? ? ? ? setContentView(R.layout.activity_main);
? ? ? ? button = (Button) findViewById(R.id.button);
? ? ? ? //傳入style和anim文件
? ? ? ? progressDialog = new MyProgressDialog(this,R.style.dialog,R.anim.loading);

? ? ? ? button.setOnClickListener(new View.OnClickListener() {
? ? ? ? ? ? @Override
? ? ? ? ? ? public void onClick(View view) {
? ? ? ? ? ? ? ? progressDialog.show();
? ? ? ? ? ? }
? ? ? ? });
? ? }
}

4、使用時需要一個style文件和一個anim文件

style.xml

<style name="dialog" parent="@android:style/Theme.Dialog">
? ? ? ? <!--邊框-->
? ? ? ? <item name="android:windowFrame">@null</item>
? ? ? ? <!--是否浮現(xiàn)在activity之上-->
? ? ? ? <item name="android:windowIsFloating">true</item>
? ? ? ? <!--半透明-->
? ? ? ? <item name="android:windowIsTranslucent">false</item>
? ? ? ? <!--無標題-->
? ? ? ? <item name="android:windowNoTitle">true</item>
? ? ? ? <!--背景透明去掉背景色邊框也就去掉了 -->
? ? ? ? <item name="android:windowBackground">@color/transparent</item>?
? ? ? ? <!--模糊-->
? ? ? ? <item name="android:backgroundDimEnabled">false</item>
? ? </style>

anim文件夾下的loading.xml文件

<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android">
? ? <item android:drawable="@mipmap/loading1" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading2" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading3" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading4" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading5" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading6" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading7" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading8" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading9" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading10" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading11" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading12" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading13" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading14" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading15" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading16" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading17" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading18" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading19" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading20" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading21" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading22" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading23" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading24" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading25" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading26" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading27" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading30" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading31" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading32" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading33" android:duration="100"/>
? ? <item android:drawable="@mipmap/loading34" android:duration="100"/>
</animation-list>

在color.xml文件中添加

<color name="transparent">#00ffffff</color>

原文鏈接:https://blog.csdn.net/hello_1s/article/details/51889596

欄目分類
最近更新