Android图片的旋转、暂停与音乐的播放

布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:gravity="center_horizontal">

        <RelativeLayout
            android:layout_width="334dp"
            android:layout_height="350dp"
            android:layout_marginTop="136dp">

            <ImageView
                android:layout_width="276dp"
                android:layout_height="276dp"
                android:layout_centerHorizontal="true"
                android:layout_marginTop="45dp"
                android:background="@drawable/icon_projection" />

            <ImageView
                android:id="@+id/iv"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:background="@drawable/icon_audio_record" />
        </RelativeLayout>
    </LinearLayout>

    <ImageView
        android:id="@+id/iv_pause"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:layout_gravity="center_horizontal"
        android:layout_marginBottom="40dp"
        android:background="@drawable/iv_start" />

</LinearLayout>

java代码:

package com.shanjing.animation;

import android.animation.ObjectAnimator;
import android.media.MediaPlayer;
import android.os.Build;
import android.support.annotation.RequiresApi;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.LinearInterpolator;
import android.widget.ImageView;

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

    private ImageView iv_pause, iv;
    private ObjectAnimator mAnimator;
    private MediaPlayer mPlayer;

    @RequiresApi(api = Build.VERSION_CODES.KITKAT)
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        initAnimator();//进入页面加载动画
        initPlayer();//进入页面加载音乐
    }

    private void initPlayer() {
        mPlayer = MediaPlayer.create(this, R.raw.wanwusheng);
        mPlayer.setLooping(true);//设置为循环播放
        mPlayer.start();//开始播放音乐
        mPlayer.pause();//暂停播放音乐
    }

    @RequiresApi(api = Build.VERSION_CODES.KITKAT)
    private void initAnimator() {
        mAnimator = ObjectAnimator.ofFloat(iv, "rotation", 0.0f, 360.0f);
        mAnimator.setDuration(3000);//设定转一圈的时间
        mAnimator.setRepeatCount(Animation.INFINITE);//设定无限循环
        mAnimator.setRepeatMode(ObjectAnimator.RESTART);// 循环模式
        mAnimator.setInterpolator(new LinearInterpolator());// 匀速
        mAnimator.start();//动画开始
        mAnimator.pause();//动画暂停
    }

    private void initView() {
        iv_pause = findViewById(R.id.iv_pause);
        iv = findViewById(R.id.iv);
        iv_pause.setOnClickListener(this);
    }

    private boolean isPause = false;

    @RequiresApi(api = Build.VERSION_CODES.KITKAT)
    @Override
    public void onClick(View v) {
        int i = v.getId();
        if (i == R.id.iv_pause) {
            if (!isPause) {
                iv_pause.setBackgroundResource(R.drawable.iv_pause);
                mAnimator.resume();//动画继续
                mPlayer.start();//继续开始音乐播放
                isPause = true;
            } else {
                iv_pause.setBackgroundResource(R.drawable.iv_start);
                mAnimator.pause();//动画暂停
                mPlayer.pause();//暂停音乐播放
                isPause = false;
            }
        }
    }

    @Override
    protected void onDestroy() {//销毁
        super.onDestroy();
        mPlayer.stop();//停止播放音乐
    }
}

GitHub地址:https://github.com/cuiwenju2017/Animation

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

举儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值