Android仿网易云音乐播放界面

 更新时间:2020年11月19日 09:49:57   作者:huang小qing  
这篇文章主要为大家详细介绍了Android仿网易云音乐播放界面,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

现在很多的播放器的播放界面都是采用光盘的转动,下面是我仿造网易的播放界面。先上两张图:

第一张为播放前的界面,第二张为点击播放按钮的图片。布局文件如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:background="#ffffff" > 
 
 <LinearLayout 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" 
  android:orientation="vertical" > 
 
  <RelativeLayout 
   android:layout_width="fill_parent" 
   android:layout_height="48dp" 
   android:background="#222222" > 
 
   <ImageView 
    android:id="@+id/back_main_activity" 
    android:layout_width="40dp" 
    android:layout_height="40dp" 
    android:layout_centerVertical="true" 
    android:layout_marginLeft="5dp" 
    android:background="@drawable/back_main_view" /> 
 
   <TextView 
    android:id="@+id/play_music_name" 
    android:layout_width="wrap_content" 
    android:layout_height="40dp" 
    android:layout_centerInParent="true" 
    android:layout_marginLeft="10dp" 
    android:layout_toRightOf="@+id/back_main_activity" 
    android:paddingTop="5dp" 
    android:text="music" 
    android:textColor="#ffffff" 
    android:textSize="20dp" /> 
  </RelativeLayout> 
 
  <RelativeLayout 
   android:id="@+id/play_disc" 
   android:layout_width="fill_parent" 
   android:layout_height="wrap_content" 
   android:gravity="center|center_vertical" > 
  </RelativeLayout> 
 </LinearLayout> 
 
 <LinearLayout 
  android:layout_width="fill_parent" 
  android:layout_height="80dp" 
  android:layout_below="@+id/seekbarLayout" 
  android:background="#222222" 
  android:gravity="center_horizontal" 
  android:orientation="horizontal" 
  android:layout_alignParentBottom="true" > 
 
  <ImageView 
   android:id="@+id/music_paly_pause" 
   android:layout_width="80dp" 
   android:layout_height="fill_parent" 
   android:background="@drawable/play_btn_play" /> 
 </LinearLayout> 
 
</RelativeLayout> 

MainActivity的代码如下:

public class MainActivity extends Activity { 
private RelativeLayout playDisc; 
private MusicPlayDiscView musicPlayDiscView; 
//播放按钮 
private ImageView playMusic; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.activity_main); 

playDisc = (RelativeLayout) findViewById(R.id.play_disc); 
//加载光盘view 
musicPlayDiscView = new MusicPlayDiscView(this); 
playDisc.addView(musicPlayDiscView); 

playMusic = (ImageView) findViewById(R.id.music_paly_pause); 
//监听方法 
playMusic.setOnClickListener(new OnClickListener() { 

@Override 
public void onClick(View v) { 
switch (Constant.CurrentState) { 
case Constant.Pause: 
Constant.CurrentState = Constant.Play; 
playMusic.setBackgroundResource(R.drawable.play_btn_pause); 
break; 
case Constant.Play: 
Constant.CurrentState = Constant.Pause; 
playMusic.setBackgroundResource(R.drawable.play_btn_play); 
break; 

} 

} 
}); 
} 

}

光盘界面是自定义的view。MusicPlayDiscView,代码如下:

public class MusicPlayDiscView extends View { 
 
 Paint paint; 
 
 private Handler handler; 
 // 光盘图片 
 Bitmap bitmapDisc = BitmapFactory.decodeResource(getResources(), 
   R.drawable.play_disc); 
 // 专辑图片 
 Bitmap bitmapImage = BitmapFactory.decodeResource(getResources(), 
   R.drawable.music_play_people); 
 Bitmap bitmapCircularAblum, bitmapDiscCircular; 
 // 光盘指针图片 
 Bitmap bitmapNeedle = BitmapFactory.decodeResource(getResources(), 
   R.drawable.play_needle); 
 
 public MusicPlayDiscView(Context context) { 
  super(context); 
  //分别获得光盘和专辑的圆形图片 
  bitmapCircularAblum = getCircularBitmap(bitmapImage, 400); 
  bitmapDiscCircular = getCircularBitmap(bitmapDisc, 
    bitmapDisc.getWidth()); 
 
  paint = new Paint(); 
  handler = new Handler(); 
  handler.post(runnable); 
 } 
 
 /** 
  * 利用线程不断更新界面 
  */ 
 private Runnable runnable = new Runnable() { 
  public void run() { 
   postInvalidate(); 
   handler.postDelayed(runnable, 50); 
  } 
 }; 
 
 //状态标志: 
 int before = 0; 
 //角度标志 
 private int degreeFlag = 0; 
 
 @Override 
 protected void onDraw(Canvas canvas) { 
  super.onDraw(canvas); 
 
  /** 
   * 先画光盘与专辑图片 
   */ 
 
  if (Constant.CurrentState == Constant.Play) { 
   Constant.Degree++; 
   if (Constant.Degree > 360) 
    Constant.Degree = 0; 
 
   degreeFlag = Constant.Degree; 
 
   canvas.save(); 
   //360为屏幕的中间位置,手机是720的宽度 
   canvas.rotate(Constant.Degree, 360, 
     170 + bitmapDiscCircular.getHeight() / 2); 
   canvas.drawBitmap(bitmapCircularAblum, 
     360 - bitmapCircularAblum.getWidth() / 2, 200, paint); 
 
   canvas.drawBitmap(bitmapDisc, 
     360 - bitmapDiscCircular.getWidth() / 2, 170, paint); 
    
   canvas.restore(); 
 
  } else { 
   //before = 0; 
 
   canvas.save(); 
   canvas.rotate(degreeFlag, 360, 
     170 + bitmapDiscCircular.getHeight() / 2); 
   canvas.drawBitmap(bitmapCircularAblum, 
     360 - bitmapCircularAblum.getWidth() / 2, 200, paint); 
 
   canvas.drawBitmap(bitmapDisc, 
     360 - bitmapDiscCircular.getWidth() / 2, 170, paint); 
   canvas.restore(); 
 
  } 
 
  /** 
   * 再画光盘指针图片,三张图不能同时画 
   */ 
  if (Constant.CurrentState == Constant.Play ) { 
   canvas.drawBitmap(bitmapNeedle, 360 - bitmapNeedle.getWidth() / 2, 
     0, paint); 
 
  } else { 
   canvas.save(); 
   Matrix matrix = new Matrix(); 
   matrix.postRotate(-45); 
   paint.setAntiAlias(true); 
   //获得指针旋转后的图片 
   Bitmap bm = Bitmap.createBitmap(bitmapNeedle, 0, 0, 
     bitmapNeedle.getWidth(), bitmapNeedle.getHeight(), matrix, 
     true); 
   canvas.drawBitmap(bm, 360 - bitmapNeedle.getWidth() / 2 + 5, -60, 
     paint); 
    
    
   canvas.restore(); 
  } 
 
 } 
 
 /** 
  * 获得圆形图片的方法 
  * 
  */ 
 private Bitmap getCircularBitmap(Bitmap bitmap, int radius) { 
  Bitmap sbmp = Bitmap.createScaledBitmap(bitmap, radius, radius, false); 
 
  Bitmap output = Bitmap.createBitmap(sbmp.getWidth(), sbmp.getHeight(), 
    Config.ARGB_8888); 
  Canvas canvas = new Canvas(output); 
 
  Paint paint = new Paint(); 
  Rect rect = new Rect(0, 0, sbmp.getWidth(), sbmp.getHeight()); 
 
  paint.setAntiAlias(true); 
  paint.setFilterBitmap(true); 
  paint.setDither(true); 
  canvas.drawARGB(0, 0, 0, 0); 
  paint.setColor(Color.BLACK); 
  canvas.drawCircle(sbmp.getWidth() / 2, sbmp.getHeight() / 2, 
    sbmp.getWidth() / 2, paint); 
  paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN)); 
  canvas.drawBitmap(sbmp, rect, rect, paint); 
  return output; 
 } 
 
} 

Constant为常量类,定义了四个常量。都是int类型,分别为播放、暂停、播放状态与转动角度。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android中实现下载和解压zip文件功能代码分享

    Android中实现下载和解压zip文件功能代码分享

    这篇文章主要介绍了Android中实现下载和解压zip文件功能代码分享,本文直接给出了实现代码,需要的朋友可以参考下
    2015-03-03
  • android教程之把自己的应用加入到系统分享中

    android教程之把自己的应用加入到系统分享中

    在Android系统中打开相册中的某张图片, 点击右上角的分享按钮会弹出分享列表, 把自己的应用加入到里面来,下面是设置方法
    2014-02-02
  • Android  Service类与生命周期详细介绍

    Android Service类与生命周期详细介绍

    这篇文章主要介绍了Android Service类与生命周期详细介绍的相关资料,需要的朋友可以参考下
    2017-03-03
  • Android事件分发机制全面解析

    Android事件分发机制全面解析

    这篇文章主要介绍了Android事件分发机制全面解析,帮助大家更好的理解和学习使用Android开发,感兴趣的朋友可以了解下
    2021-03-03
  • Android应用中仿今日头条App制作ViewPager指示器

    Android应用中仿今日头条App制作ViewPager指示器

    这篇文章主要介绍了Android应用中仿今日头条App制作ViewPager指示器的例子,一般就是导航条在翻页时的动态字体变色效果,需要的朋友可以参考下
    2016-04-04
  • Android通知栏增加快捷开关的功能实现教程

    Android通知栏增加快捷开关的功能实现教程

    对于Android来说其中一项很方便的操作便是下拉菜单,下拉菜单栏可以快捷打开某项设置,这篇文章主要给大家介绍了关于Android通知栏增加快捷开关的功能实现,需要的朋友可以参考下
    2023-01-01
  • Android实现仿iOS菊花加载圈动画效果

    Android实现仿iOS菊花加载圈动画效果

    iOS上有一个UIActivityIndicator的控件,就是俗称转菊花的控件,一般UI设计师会按照iOS的风格来出设计稿,也要求使用这种Loading效果,本文将具体的讲述如何实现这种效果,感兴趣的朋友可以参考下
    2021-05-05
  • android ListView结合xutils3仿微信实现下拉加载更多

    android ListView结合xutils3仿微信实现下拉加载更多

    本篇文章主要介绍了android ListView结合xutils3仿微信实现下拉加载更多,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • 详解Flutter中的数据传递

    详解Flutter中的数据传递

    这篇文章主要介绍了Flutter中的数据传递的相关资料,帮助大家更好的理解和学习使用Flutter,感兴趣的朋友可以了解下
    2021-04-04
  • flutter开发的app项目 打包成web

    flutter开发的app项目 打包成web

    如果你的Flutter版本低于2.0,请先升级Flutter版本,创建一个web文件夹来存放web相关的资源,使用HTML渲染器打包,该渲染器提供的打开速度最快,并且具有良好的浏览器兼容性,使用默认设置进行打包,提供的打开速度为一般,但依然保持良好的浏览器兼容性
    2024-08-08

最新评论