Android 实现旋转木马的音乐效果


一、百度在线音乐旋转木马效果

就上面那个,当音乐在播放的时候,那个光碟轮子在转,就想旋转木马一般。感觉好好玩啊。
碰巧想起前阵子做音乐播放器,哎,那这个也可以做在手机的音乐播放器上,这样就代替了进度条了。
一想到,就兴奋,于是,首先画圆形,然后放置背景图片,然后使用动画旋转。当音乐播放时,同时
开始播放圆形图片的动画,当音乐暂停时,暂停旋转;当音乐停止播放时,就停止动画,图片回到原点。

二、效果

三、实现代码

(1)MainActivity  

<span style="font-size:18px;">public class MainActivity extends Activity {
  MediaPlayer m1;
  ImageView infoOperatingIV;
 
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    infoOperatingIV = (ImageView) findViewById(R.id.infoOperating);
 
    Button play = (Button) findViewById(R.id.play);
    Button stop = (Button) findViewById(R.id.stop);
 
    play.setOnClickListener(new OnClickListener() {
      @Override
      public void onClick(View v) {
        playMusic();
      }
    });
 
    stop.setOnClickListener(new OnClickListener() {
      @Override
      public void onClick(View v) {
        stopMusic();
      }
    });
 
  }
 
  private void playMusic() {
    m1 = MediaPlayer.create(this, R.raw.quiet);
    m1.start();
 
    Animation operatingAnim = AnimationUtils.loadAnimation(this, R.anim.tip);
    LinearInterpolator lin = new LinearInterpolator();
    operatingAnim.setInterpolator(lin);
    if (operatingAnim != null) {
      infoOperatingIV.startAnimation(operatingAnim);
    }
 
    m1.setOnCompletionListener(new OnCompletionListener() {
      @Override
      public void onCompletion(MediaPlayer mp) {
        mp.stop();
        infoOperatingIV.clearAnimation();
      }
    });
  }
 
  private void stopMusic() {
    m1.stop();
    infoOperatingIV.clearAnimation();
  }
 
}</span><span style="font-size: 16pt;">
</span>

(2)画圆的控件,这部分代码参考了网友的。

  <span style="font-size:18px;">public class RoundImageView extends ImageView {
  private int mBorderThickness = 0;
  private Context mContext;
  private int defaultColor = 0xFFFFFFFF;
  // 如果只有其中一个有值,则只画一个圆形边框
  private int mBorderOutsideColor = 0;
  private int mBorderInsideColor = 0;
  // 控件默认长、宽
  private int defaultWidth = 0;
  private int defaultHeight = 0;
 
  public RoundImageView(Context context) {
    super(context);
    mContext = context;
  }
 
  public RoundImageView(Context context, AttributeSet attrs) {
    super(context, attrs);
    mContext = context;
    setCustomAttributes(attrs);
  }
 
  public RoundImageView(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
    mContext = context;
    setCustomAttributes(attrs);
  }
 
  private void setCustomAttributes(AttributeSet attrs) {
    TypedArray a = mContext.obtainStyledAttributes(attrs, R.styleable.roundedimageview);
    mBorderThickness = a.getDimensionPixelSize(R.styleable.roundedimageview_border_thickness, 0);
    mBorderOutsideColor = a.getColor(R.styleable.roundedimageview_border_outside_color, defaultColor);
    mBorderInsideColor = a.getColor(R.styleable.roundedimageview_border_inside_color, defaultColor);
  }
 
  @Override
  protected void onDraw(Canvas canvas) {
    Drawable drawable = getDrawable();
    if (drawable == null) {
      return;
    }
 
    if (getWidth() == 0 || getHeight() == 0) {
      return;
    }
    this.measure(0, 0);
    if (drawable.getClass() == NinePatchDrawable.class)
      return;
    Bitmap b = ((BitmapDrawable) drawable).getBitmap();
    Bitmap bitmap = b.copy(Bitmap.Config.ARGB_8888, true);
    if (defaultWidth == 0) {
      defaultWidth = getWidth();
 
    }
    if (defaultHeight == 0) {
      defaultHeight = getHeight();
    }
    // 保证重新读取图片后不会因为图片大小而改变控件宽、高的大小(针对宽、高为wrap_content布局的imageview,但会导致margin无效)
    // if (defaultWidth != 0 && defaultHeight != 0) {
    // LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
    // defaultWidth, defaultHeight);
    // setLayoutParams(params);
    // }
    int radius = 0;
    if (mBorderInsideColor != defaultColor && mBorderOutsideColor != defaultColor) {// 定义画两个边框,分别为外圆边框和内圆边框
      radius = (defaultWidth < defaultHeight ? defaultWidth : defaultHeight) / 2 - 2 * mBorderThickness;
      // 画内圆
      drawCircleBorder(canvas, radius + mBorderThickness / 2, mBorderInsideColor);
      // 画外圆
      drawCircleBorder(canvas, radius + mBorderThickness + mBorderThickness / 2, mBorderOutsideColor);
    } else if (mBorderInsideColor != defaultColor && mBorderOutsideColor == defaultColor) {// 定义画一个边框
      radius = (defaultWidth < defaultHeight ? defaultWidth : defaultHeight) / 2 - mBorderThickness;
      drawCircleBorder(canvas, radius + mBorderThickness / 2, mBorderInsideColor);
    } else if (mBorderInsideColor == defaultColor && mBorderOutsideColor != defaultColor) {// 定义画一个边框
      radius = (defaultWidth < defaultHeight ? defaultWidth : defaultHeight) / 2 - mBorderThickness;
      drawCircleBorder(canvas, radius + mBorderThickness / 2, mBorderOutsideColor);
    } else {// 没有边框
      radius = (defaultWidth < defaultHeight ? defaultWidth : defaultHeight) / 2;
    }
    Bitmap roundBitmap = getCroppedRoundBitmap(bitmap, radius);
    canvas.drawBitmap(roundBitmap, defaultWidth / 2 - radius, defaultHeight / 2 - radius, null);
  }
 
  /**
   * 获取裁剪后的圆形图片
   *
   * @param radius
   *      半径
   */
  public Bitmap getCroppedRoundBitmap(Bitmap bmp, int radius) {
    Bitmap scaledSrcBmp;
    int diameter = radius * 2;
 
    // 为了防止宽高不相等,造成圆形图片变形,因此截取长方形中处于中间位置最大的正方形图片
    int bmpWidth = bmp.getWidth();
    int bmpHeight = bmp.getHeight();
    int squareWidth = 0, squareHeight = 0;
    int x = 0, y = 0;
    Bitmap squareBitmap;
    if (bmpHeight > bmpWidth) {// 高大于宽
      squareWidth = squareHeight = bmpWidth;
      x = 0;
      y = (bmpHeight - bmpWidth) / 2;
      // 截取正方形图片
      squareBitmap = Bitmap.createBitmap(bmp, x, y, squareWidth, squareHeight);
    } else if (bmpHeight < bmpWidth) {// 宽大于高
      squareWidth = squareHeight = bmpHeight;
      x = (bmpWidth - bmpHeight) / 2;
      y = 0;
      squareBitmap = Bitmap.createBitmap(bmp, x, y, squareWidth, squareHeight);
    } else {
      squareBitmap = bmp;
    }
 
    if (squareBitmap.getWidth() != diameter || squareBitmap.getHeight() != diameter) {
      scaledSrcBmp = Bitmap.createScaledBitmap(squareBitmap, diameter, diameter, true);
 
    } else {
      scaledSrcBmp = squareBitmap;
    }
    Bitmap output = Bitmap.createBitmap(scaledSrcBmp.getWidth(), scaledSrcBmp.getHeight(), Config.ARGB_8888);
    Canvas canvas = new Canvas(output);
 
    Paint paint = new Paint();
    Rect rect = new Rect(0, 0, scaledSrcBmp.getWidth(), scaledSrcBmp.getHeight());
 
    paint.setAntiAlias(true);
    paint.setFilterBitmap(true);
    paint.setDither(true);
    canvas.drawARGB(0, 0, 0, 0);
    canvas.drawCircle(scaledSrcBmp.getWidth() / 2, scaledSrcBmp.getHeight() / 2, scaledSrcBmp.getWidth() / 2, paint);
    paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
    canvas.drawBitmap(scaledSrcBmp, rect, rect, paint);
     
    bmp = null;
    squareBitmap = null;
    scaledSrcBmp = null;
    return output;
  }
 
  /**
   * 边缘画圆
   */
  private void drawCircleBorder(Canvas canvas, int radius, int color) {
    Paint paint = new Paint();
    /* 去锯齿 */
    paint.setAntiAlias(true);
    paint.setFilterBitmap(true);
    paint.setDither(true);
    paint.setColor(color);
    /* 设置paint的 style 为STROKE:空心 */
    paint.setStyle(Paint.Style.STROKE);
    /* 设置paint的外框宽度 */
    paint.setStrokeWidth(mBorderThickness);
    canvas.drawCircle(defaultWidth / 2, defaultHeight / 2, radius, paint);
  }
 
}</span><span style="font-size: 16pt;">
</span>

以上就是Android 实现旋转木马的音乐效果,有需要的朋友可以参考下。



相关阅读:
解决Windows 7下安装Oracle 11g相关问题的方法
C#实现两个窗体之间数值传送的方法
jquery实现input输入框实时输入触发事件代码
win10系统如何快速清理垃圾?win10清理系统垃圾方法介绍
C++设计模式编程中的观察者模式使用示例
jquery对dom节点的操作【推荐】
你不需要jQuery(三) 新AJAX方法fetch()
调用jQuery滑出效果时闪烁的解决方法
Win10 Mobile 10586.164中文版升级截图曝光
把js文件编译成dll供页面调用的方法
CentOS系统使用配置文件修改IP地址详细教程
Windows 7系统设置Aero毛玻璃特效后电脑出现反光该怎么办?
zf框架的数据库追踪器使用示例
WinForm实现关闭按钮不可用或隐藏的方法
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 任丘-晋州 秦皇岛-西柳 重庆北-融水 平遥古城-太谷西 万源-鄂尔多斯 宜兴-乐清 宜城-柳江 镇江-潜江 杭州东-昆山南 怀柔北-通州西 菏泽-辛集 保定东-咸宁北 三门峡-无锡 鄂州-汕头 广安-砀山 富裕-盘古 襄阳-临城 图们-辽阳 运城-赤壁 玉门-阿图什 邹城-烟台 佳木斯-鹤立 零陵-许昌 五原-杭锦旗 宣城-邵武 哈尔滨西-丹东 双城堡-南阳 哈达阳-四平 赣州-韶关东 金宝屯-苏家屯 平顶山西-开封 葫芦岛-阜新南 丹阳-阳澄湖 鲘门-普宁 邹城-常州 焦作-吉首 诸暨-五府山 锦州南-商丘南 新立镇-大口钦 永济北-保定东 绥中-镇江 八面城-铁岭 西安-汾阳 鹰潭-成都东 定州-绥中 赶水-樟树 闻喜-华山 龙岩-万源 萧县北-永州 福州南-赣州 菏泽-诸暨 白城-塔源 小扬气-塔源 锦州南-四平东 邵阳-广州南 桐城-玉屏 吉安-襄阳 柳园南-海东西 沙城-扎兰屯 弋阳-嵩明 田家沟-水泉 南芬北-抚顺北 包头-高家村 宁武-霍州 深州-兴城 张家界-吐鲁番 太谷-侯马 嘉兴南-天津南 秦皇岛-胜芳 铁佛寺-草河口 敦化-锦州南 梅河口-沧州 长春-济宁 上饶-鹿寨北 福州-华山北 宝龙山-高林屯 算王庄-长垣 乐昌-城固 伊春-大连北 海宁西-武夷山东 大连到赤峰长途客车汽车 多长时间到赤峰 就问多长时间能到地方
从江田到福州亭江中学的路线。
长沙高铁南站有直达常德澧县的汽车吗
西宁到拉萨的火车列车票好买吗
深圳宝安汽车客车站坐车到阳朔多少钱
从聊城去威海旅游找哪个旅行社
从牡丹江寄信到北京要多久
河北三河有到白沟的车吗
从吉林到赣州的列车火车
从德平路张扬路到上海南站的公交线路
K9062停辰溪?怀化的车票能在辰溪上吗》
从太原到临猗县怎么走?有没有直接到临猗的火车?还是要转汽车?
安康到清远自驾高速怎么坐车
请问:有直接从梅城开往常德的汽车吗
浙江省宁波市奉化高新技术开发区怎么走
上海的出租车有几大公司名称谢谢
金华到池州自驾车要怎么坐车
怀安柴沟堡汽车站到北京的长途车下午几点发车?
四窗岩漂流景区电话
珠海哪里坐车去深圳
自贡贡井区哪个地段最繁华
北京丽泽桥长途客车汽车站到清河大楼怎么去
火车列车票提前几天要买啊
齐齐哈尔至大庆客车车费在线等
怀化到隆回的客车票价多少春运时候怀化到邵阳的车卖到隆回
请问从武汉坐列车火车到西安再到兰州,敦煌一路玩到新疆,青海怎
温岭哪种电动车售后服务好
请问三明尤溪到白水洋7个人的自助游怎么坐车我们是学生,希望
绵阳西南科技大学外面租门面门面价格咋算的啊30到40平米的
洪山区到新洲区最近的乘车路线

Copyright © 2016 phpStudy |