Android应用开发之简易、大气音乐播放器实现专辑倒影效果_Android

今天要实现的功能是实现专辑倒影效果,这个功能已经属于图像处理方面的了,对图像处理我不怎么在行,等一下会介绍一个很实用的工具类,专门用来进行图像处理的。这个工具类不是我写的,我只是拿来用到自己的项目当中,这已经足够了,我已经完美实现我想要的效果。

效果图:

<

一个很有用的工具类

/SimpleBeautyMusicPlayer/src/com/wwj/sb/utils/ImageUtil.java

package com.wwj.sb.utils;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Bitmap.CompressFormat;
import android.graphics.Bitmap.Config;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.ColorMatrix;
import android.graphics.ColorMatrixColorFilter;
import android.graphics.LinearGradient;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.PorterDuff;
import android.graphics.PorterDuff.Mode;
import android.graphics.PorterDuffXfermode;
import android.graphics.Rect;
import android.graphics.RectF;
import android.graphics.Shader;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
/**
 * 图片工具类
 * @author wwj
 * 2013/7/3
 */
public class ImageUtil {
  /**图片的八个位置**/
  public static final int TOP = 0;      //上
  public static final int BOTTOM = 1;     //下
  public static final int LEFT = 2;      //左
  public static final int RIGHT = 3;     //右
  public static final int LEFT_TOP = 4;    //左上
  public static final int LEFT_BOTTOM = 5;  //左下
  public static final int RIGHT_TOP = 6;   //右上
  public static final int RIGHT_BOTTOM = 7;  //右下
  /**
   * 图像的放大缩小方法
   * @param src    源位图对象
   * @param scaleX  宽度比例系数
   * @param scaleY  高度比例系数
   * @return 返回位图对象
   */
  public static Bitmap zoomBitmap(Bitmap src, float scaleX, float scaleY) {
    Matrix matrix = new Matrix();
    matrix.setScale(scaleX, scaleY);
    Bitmap t_bitmap = Bitmap.createBitmap(src, 0, 0, src.getWidth(), src.getHeight(), matrix, true);
    return t_bitmap;
  }
  /**
   * 图像放大缩小--根据宽度和高度
   * @param src
   * @param width
   * @param height
   * @return
   */
  public static Bitmap zoomBimtap(Bitmap src, int width, int height) {
    return Bitmap.createScaledBitmap(src, width, height, true);
  }
  /**
   * 将Drawable转为Bitmap对象
   * @param drawable
   * @return
   */
  public static Bitmap drawableToBitmap(Drawable drawable) {
    return ((BitmapDrawable)drawable).getBitmap();
  }
  /**
   * 将Bitmap转换为Drawable对象
   * @param bitmap
   * @return
   */
  public static Drawable bitmapToDrawable(Bitmap bitmap) {
    Drawable drawable = new BitmapDrawable(bitmap);
    return drawable;
  }
  /**
   * Bitmap转byte[]
   * @param bitmap
   * @return
   */
  public static byte[] bitmapToByte(Bitmap bitmap) {
    ByteArrayOutputStream out = new ByteArrayOutputStream();
    bitmap.compress(Bitmap.CompressFormat.PNG, 100, out);
    return out.toByteArray();
  }
  /**
   * byte[]转Bitmap
   * @param data
   * @return
   */
  public static Bitmap byteToBitmap(byte[] data) {
    if(data.length != 0) {
      return BitmapFactory.decodeByteArray(data, 0, data.length);
    }
    return null;
  }
  /**
   * 绘制带圆角的图像
   * @param src
   * @param radius
   * @return
   */
  public static Bitmap createRoundedCornerBitmap(Bitmap src, int radius) {
    final int w = src.getWidth();
    final int h = src.getHeight();
    // 高清量32位图
    Bitmap bitmap = Bitmap.createBitmap(w, h, Config.ARGB_8888);
    Paint paint = new Paint();
    Canvas canvas = new Canvas(bitmap);
    canvas.drawARGB(0, 0, 0, 0);
    paint.setColor(0xff424242);
    // 防止边缘的锯齿
    paint.setFilterBitmap(true);
    Rect rect = new Rect(0, 0, w, h);
    RectF rectf = new RectF(rect);
    // 绘制带圆角的矩形
    canvas.drawRoundRect(rectf, radius, radius, paint);
    // 取两层绘制交集,显示上层
    paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
    // 绘制图像
    canvas.drawBitmap(src, rect, rect, paint);
    return bitmap;
  }
  /**
   * 创建选中带提示图片
   * @param context
   * @param srcId
   * @param tipId
   * @return
   */
  public static Drawable createSelectedTip(Context context, int srcId, int tipId) {
    Bitmap src = BitmapFactory.decodeResource(context.getResources(), srcId);
    Bitmap tip = BitmapFactory.decodeResource(context.getResources(), tipId);
    final int w = src.getWidth();
    final int h = src.getHeight();
    Bitmap bitmap = Bitmap.createBitmap(w, h, Config.ARGB_8888);
    Paint paint = new Paint();
    Canvas canvas = new Canvas(bitmap);
    //绘制原图
    canvas.drawBitmap(src, 0, 0, paint);
    //绘制提示图片
    canvas.drawBitmap(tip, (w - tip.getWidth()), 0, paint);
    return bitmapToDrawable(bitmap);
  }
  /**
   * 带倒影的图像
   * @param src
   * @return
   */
  public static Bitmap createReflectionBitmap(Bitmap src) {
    // 两个图像间的空隙
    final int spacing = 4;
    final int w = src.getWidth();
    final int h = src.getHeight();
    // 绘制高质量32位图
    Bitmap bitmap = Bitmap.createBitmap(w, h + h / 2 + spacing, Config.ARGB_8888);
    // 创建燕X轴的倒影图像
    Matrix m = new Matrix();
    m.setScale(1, -1);
    Bitmap t_bitmap = Bitmap.createBitmap(src, 0, h / 2, w, h / 2, m, true);
    Canvas canvas = new Canvas(bitmap);
    Paint paint = new Paint();
    // 绘制原图像
    canvas.drawBitmap(src, 0, 0, paint);
    // 绘制倒影图像
    canvas.drawBitmap(t_bitmap, 0, h + spacing, paint);
    // 线性渲染-沿Y轴高到低渲染
    Shader shader = new LinearGradient(0, h + spacing, 0, h + spacing + h / 2, 0x70ffffff, 0x00ffffff, Shader.TileMode.MIRROR);
    paint.setShader(shader);
    // 取两层绘制交集,显示下层。
    paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN));
    // 绘制渲染倒影的矩形
    canvas.drawRect(0, h + spacing, w, h + h / 2 + spacing, paint);
    return bitmap;
  }
  /**
   * 独立的倒影图像
   * @param src
   * @return
   */
  public static Bitmap createReflectionBitmapForSingle(Bitmap src) {
    final int w = src.getWidth();
    final int h = src.getHeight();
    // 绘制高质量32位图
    Bitmap bitmap = Bitmap.createBitmap(w, h / 2, Config.ARGB_8888);
    // 创建沿X轴的倒影图像
    Matrix m = new Matrix();
    m.setScale(1, -1);
    Bitmap t_bitmap = Bitmap.createBitmap(src, 0, h / 2, w, h / 2, m, true);
    Canvas canvas = new Canvas(bitmap);
    Paint paint = new Paint();
    // 绘制倒影图像
    canvas.drawBitmap(t_bitmap, 0, 0, paint);
    // 线性渲染-沿Y轴高到低渲染
    Shader shader = new LinearGradient(0, 0, 0, h / 2, 0x70ffffff,
        0x00ffffff, Shader.TileMode.MIRROR);
    paint.setShader(shader);
    // 取两层绘制交集。显示下层。
    paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN));
    // 绘制渲染倒影的矩形
    canvas.drawRect(0, 0, w, h / 2, paint);
    return bitmap;
  }
  public static Bitmap createGreyBitmap(Bitmap src) {
    final int w = src.getWidth();
    final int h = src.getHeight();
    Bitmap bitmap = Bitmap.createBitmap(w, h, Config.ARGB_8888);
    Canvas canvas = new Canvas(bitmap);
    Paint paint = new Paint();
    // 颜色变换的矩阵
    ColorMatrix matrix = new ColorMatrix();
    // saturation 饱和度值,最小可设为0,此时对应的是灰度图;为1表示饱和度不变,设置大于1,就显示过饱和
    matrix.setSaturation(0);
    ColorMatrixColorFilter filter = new ColorMatrixColorFilter(matrix);
    paint.setColorFilter(filter);
    canvas.drawBitmap(src, 0, 0, paint);
    return bitmap;
  }
  /**
   * 保存图片
   * @param src
   * @param filepath
   * @param format:[Bitmap.CompressFormat.PNG,Bitmap.CompressFormat.JPEG]
   * @return
   */
  public static boolean saveImage(Bitmap src, String filepath, CompressFormat format) {
    boolean rs = false;
    File file = new File(filepath);
    try {
      FileOutputStream out = new FileOutputStream(file);
      if(src.compress(format, 100, out)) {
        out.flush();  //写入流
      }
      out.close();
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
    return rs;
  }
  /**
   * 添加水印效果
   * @param src    源位图
   * @param watermark 水印
   * @param direction 方向
   * @param spacing 间距
   * @return
   */
  public static Bitmap createWatermark(Bitmap src, Bitmap watermark, int direction, int spacing) {
    final int w = src.getWidth();
    final int h = src.getHeight();
    Bitmap bitmap = Bitmap.createBitmap(w, h, Config.ARGB_8888);
    Canvas canvas = new Canvas(bitmap);
    canvas.drawBitmap(src, 0, 0, null);
    if(direction == LEFT_TOP) {
      canvas.drawBitmap(watermark, spacing, spacing, null);
    } else if(direction == LEFT_BOTTOM){
      canvas.drawBitmap(watermark, spacing, h - watermark.getHeight() - spacing, null);
    } else if(direction == RIGHT_TOP) {
      canvas.drawBitmap(watermark, w - watermark.getWidth() - spacing, spacing, null);
    } else if(direction == RIGHT_BOTTOM) {
      canvas.drawBitmap(watermark, w - watermark.getWidth() - spacing, h - watermark.getHeight() - spacing, null);
    }
    return bitmap;
  }
  /**
   * 合成图像
   * @param direction
   * @param bitmaps
   * @return
   */
  public static Bitmap composeBitmap(int direction, Bitmap... bitmaps) {
    if(bitmaps.length < 2) {
      return null;
    }
    Bitmap firstBitmap = bitmaps[0];
    for (int i = 0; i < bitmaps.length; i++) {
      firstBitmap = composeBitmap(firstBitmap, bitmaps[i], direction);
    }
    return firstBitmap;
  }
  /**
   * 合成两张图像
   * @param firstBitmap
   * @param secondBitmap
   * @param direction
   * @return
   */
  private static Bitmap composeBitmap(Bitmap firstBitmap, Bitmap secondBitmap,
      int direction) {
    if(firstBitmap == null) {
      return null;
    }
    if(secondBitmap == null) {
      return firstBitmap;
    }
    final int fw = firstBitmap.getWidth();
    final int fh = firstBitmap.getHeight();
    final int sw = secondBitmap.getWidth();
    final int sh = secondBitmap.getHeight();
    Bitmap bitmap = null;
    Canvas canvas = null;
    if(direction == TOP) {
      bitmap = Bitmap.createBitmap(sw > fw ? sw : fw, fh + sh, Config.ARGB_8888);
      canvas = new Canvas(bitmap);
      canvas.drawBitmap(secondBitmap, 0, 0, null);
      canvas.drawBitmap(firstBitmap, 0, sh, null);
    } else if(direction == BOTTOM) {
      bitmap = Bitmap.createBitmap(fw > sw ? fw : sw, fh + sh, Config.ARGB_8888);
      canvas = new Canvas(bitmap);
      canvas.drawBitmap(firstBitmap, 0, 0, null);
      canvas.drawBitmap(secondBitmap, 0, fh, null);
    } else if(direction == LEFT) {
      bitmap = Bitmap.createBitmap(fw + sw, sh > fh ? sh : fh, Config.ARGB_8888);
      canvas = new Canvas(bitmap);
      canvas.drawBitmap(secondBitmap, 0, 0, null);
      canvas.drawBitmap(firstBitmap, sw, 0, null);
    } else if(direction == RIGHT) {
      bitmap = Bitmap.createBitmap(fw + sw, fh > sh ? fh : sh,
          Config.ARGB_8888);
      canvas = new Canvas(bitmap);
      canvas.drawBitmap(firstBitmap, 0, 0, null);
      canvas.drawBitmap(secondBitmap, fw, 0, null);
    }
    return bitmap;
  }
}

在简、大气音乐播放器程序中的体现

我就定义了一个方法,就把专辑倒影的效果完美实现出来了。

/**
   * 显示专辑封面
   */
  private void showArtwork(Mp3Info mp3Info) {
    Bitmap bm = MediaUtil.getArtwork(this, mp3Info.getId(), mp3Info.getAlbumId(), true, false);
    //切换播放时候专辑图片出现透明效果
    Animation albumanim = AnimationUtils.loadAnimation(PlayerActivity.this, R.anim.album_replace);
    //开始播放动画效果
    musicAlbum.startAnimation(albumanim);
    if(bm != null) {
      musicAlbum.setImageBitmap(bm); //显示专辑封面图片
      musicAblumReflection.setImageBitmap(ImageUtil.createReflectionBitmapForSingle(bm)); //显示倒影
    } else {
      bm = MediaUtil.getDefaultArtwork(this, false);
      musicAlbum.setImageBitmap(bm); //显示专辑封面图片
      musicAblumReflection.setImageBitmap(ImageUtil.createReflectionBitmapForSingle(bm)); //显示倒影
    }
  } 

以上内容是Android应用开发之简单、大气音乐播放器实现专辑倒影效果的全部教程,希望大家喜欢。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索Android音乐播放器
, android简易播放器
android播放器
简易音乐播放器源码、简易音乐播放器、安卓简易音乐播放器、简易音乐播放器代码、html5 简易音乐播放器,以便于您获取更多的相关知识。

时间: 2024-08-04 04:11:58

Android应用开发之简易、大气音乐播放器实现专辑倒影效果_Android的相关文章

java-求教各位Java程序语言大神,用Java语言编写一个能在Eclipse开发工具运行的音乐播放器

问题描述 求教各位Java程序语言大神,用Java语言编写一个能在Eclipse开发工具运行的音乐播放器 这个音乐播放器要有基本的功能,例如(这几个播放方式最好有图标)开始播放.停止播放.两三个播放模式:音乐播放的进度条:播放列表:有歌手的背景图. 最后一个要求:编程能在Eclipse开发工具了运行. 本人新手,对Java语言很多不懂,所以如果可以的话,可以在某些关键的代码后面注释,谢谢! 也可以发到我邮箱:sxl2860@163.com,如果是发到我邮箱的,请大神们说一声! 如果做得好的话,及

【Android开发】媒体之音乐播放器

可以对音乐文件实现播放.暂停.重播和停止功能.退出应用和回到桌面时音乐停止. 主界面:   主界面配置文件mian.xml: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/container" android:lay

混音也多彩:Splyce音乐播放器

<Splyce>全名<Splyce-fancymusicplayerwithaudioandvisualmagicalpowers>,是InQBarna开发的一款音乐播放器,同时它也是一款DJ混音器,软件的亮点在于配合iOS7而设计的彩色扁平风界面,简洁大方.和普通的DJ应用不同,<Splyce>没有太复杂的设置,只要你随手改变一下参数图标,就能调出多彩的混音歌曲.第一次进入<Splyce>的时候会显示快速简单的教程.通过这个教程,用户可以快速熟悉如何使用这

Android 音乐播放器的开发实例详解_Android

   本文将引导大家做一个音乐播放器,在做这个Android开发实例的过程中,能够帮助大家进一步熟悉和掌握学过的ListView和其他一些组件.为了有更好的学习效果,其中很多功能我们手动实现,例如音乐播放的快进快退等.        先欣赏下本实例完成后运行的界面效果:         首先我们建立项目,我使用的SDK是Android2.2的,然后在XML中进行布局.        上方是一个ListView用来显示我们的音乐列表,中间是一个SeekBar可以拖动当前音乐的播放进度,之所以用Se

android虚拟机-android开发 音乐播放器 把歌曲添加到我的最爱列表

问题描述 android开发 音乐播放器 把歌曲添加到我的最爱列表 歌曲在数据库,能播放 , ,不知道怎样把它添加到我的最爱列表里 , ,求代码说明 解决方案 1.首先要知道你那个列表是什么控件 2.把歌曲信息add进去 3.设置点击事件,若点击对应歌曲则将歌曲路径传入播放器

android音乐播放器开发

问题描述 android音乐播放器开发 怎么实现让mp3格式的音乐显示在列表上并单击播放我是新手可不可以说的详细点 解决方案 ? 之所以选择android音乐播放器开发,是因为这里面涉及到了android的四大核心核心组件:Activity,Service,ContentProvider,BroadCast Receiver.对于学习理解这几大组件有着非常实际意义,而且再加上网络歌曲的播放,网络部分也会涉及到,所以还是很全面的一个练手项目.? 先来分析一个手机音乐播放器应该具备的基础功能,1.显

android 音乐播放器-android开发音乐播放器

问题描述 android开发音乐播放器 android开发音乐播放器怎么把歌曲放到项目中,一起打包到apk中??? 解决方案 一般多媒体文件都是放在raw目录下的,但音乐播放器的话,不建议把歌曲打包到apk中,可以把歌曲放在SD卡中,通过扫描sd卡的方式获取歌曲 解决方案二: 音乐播放器中综合了以下内容: SeekBar.ListView.广播接收者(以代码的形式注册Receiver).系统服务.MediaPlayer 实现的功能: 1.暂停/播放.下一首/上一首,点击某一首时播放 2.支持拖动

Android编程开发音乐播放器实例_Android

本文实例讲述了Android编程开发音乐播放器,分享给大家供大家参考,具体如下: 音乐播放器中综合了以下内容: SeekBar.ListView.广播接收者(以代码的形式注册Receiver).系统服务.MediaPlayer 实现的功能: 1.暂停/播放.下一首/上一首,点击某一首时播放 2.支持拖动进度条快进 3.列表排序 4.来电话时,停止播放,挂断后继续播放 5.可在后台播放 效果图: 界面: main.xml: <?xml version="1.0" encoding=

Android编程开发音乐播放器实例

本文实例讲述了Android编程开发音乐播放器,分享给大家供大家参考,具体如下: 音乐播放器中综合了以下内容: SeekBar.ListView.广播接收者(以代码的形式注册Receiver).系统服务.MediaPlayer 实现的功能: 1.暂停/播放.下一首/上一首,点击某一首时播放 2.支持拖动进度条快进 3.列表排序 4.来电话时,停止播放,挂断后继续播放 5.可在后台播放 效果图: 界面: main.xml: <?xml version="1.0" encoding=