Android实现网易云推荐歌单界面
作者:计蒙不吃鱼 发布时间:2022-01-15 16:36:48
标签:Android,网易云
先来看看网易云APP的效果:
前言
关于网易云音乐推荐歌单界面的实现
一、实现
1.自定义一个圆角图片控件(也可直接使用第三方框架)
由于是一些简单的绘制,就不一一介绍了,直接上代码。
public class MellowImageView extends ImageView {
private Paint paint;
public MellowImageView(Context context) {
super(context);
}
public MellowImageView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
}
public MellowImageView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
paint=new Paint();
}
/**
* 绘制圆角矩形图片
* @author jimeng
*/
@Override
protected void onDraw(Canvas canvas) {
Drawable drawable = getDrawable();
if (null != drawable) {
Bitmap bitmap = getBitmapFromDrawable(drawable);
Bitmap b = getRoundBitmapByShader(bitmap,getWidth(),getHeight(), 20,0);
final Rect rectSrc = new Rect(0, 0, b.getWidth(), b.getHeight());
final Rect rectDest = new Rect(0,0,getWidth(),getHeight());
canvas.drawBitmap(b, rectSrc, rectDest, paint);
} else {
super.onDraw(canvas);
}
}
/**
* 把图片转换成Bitmap
* @param drawable
* 资源图片
* @return 位图
*/
public static Bitmap getBitmapFromDrawable(Drawable drawable) {
int width = drawable.getIntrinsicWidth();
int height = drawable.getIntrinsicHeight();
Bitmap bitmap = Bitmap.createBitmap(width, height, drawable
.getOpacity() != PixelFormat.OPAQUE ? Bitmap.Config.ARGB_8888
: Bitmap.Config.RGB_565);
Canvas canvas = new Canvas(bitmap);
drawable.draw(canvas);
return bitmap;
}
public static Bitmap getRoundBitmapByShader(Bitmap bitmap, int outWidth, int outHeight, int radius, int boarder) {
if (bitmap == null) {
return null;
}
int width = bitmap.getWidth();
int height = bitmap.getHeight();
float widthScale = outWidth * 1f / width;
float heightScale = outHeight * 1f / height;
Matrix matrix = new Matrix();
matrix.setScale(widthScale, heightScale);
//创建需要输出的bitmap
Bitmap desBitmap = Bitmap.createBitmap(outWidth, outHeight, Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(desBitmap);
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
//着色器
BitmapShader bitmapShader = new BitmapShader(bitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);
//给着色器配置matrix
bitmapShader.setLocalMatrix(matrix);
paint.setShader(bitmapShader);
//创建矩形区域并且预留出border
RectF rect = new RectF(boarder, boarder, outWidth - boarder, outHeight - boarder);
//把传入的bitmap绘制到圆角矩形区域内
canvas.drawRoundRect(rect, radius, radius, paint);
return desBitmap;
}
}
效果图如下:
时间原因,一些简单的细节没有画上去。
2.进行布局摆设
将整个布局放在HorizontalScrollView中使其可以左右滑动,以一个item为例。
<HorizontalScrollView
xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="none"
android:orientation="horizontal"
>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:orientation="horizontal">
<!-- 美化,并无其他作用-->
<RelativeLayout
android:layout_width="@dimen/jimeng_dp_16"
android:layout_height="@dimen/jimeng_dp_135"/>
<RelativeLayout
android:layout_width="@dimen/jimeng_dp_130"
android:layout_height="@dimen/jimeng_dp_135"
>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/like_icon2"
android:layout_centerHorizontal="true"
android:text="计蒙不吃鱼"
android:maxLines="1"
android:ellipsize="end"
android:textColor="@color/jimeng_black"
android:textSize="12.0dip" />
<com.shenzhen.jimeng.jmhnzsb.View.MellowImageView
android:id="@+id/like_icon2"
android:layout_width="120.0dip"
android:layout_height="120.0dip"
android:layout_centerHorizontal="true"
android:scaleType="centerCrop"
android:src="@drawable/yf1" />
</RelativeLayout>
</LinearLayout>
</HorizontalScrollView >
3.图片切换动画效果
博主使用的是ViewFlipper。
XML代码如下
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ViewFlipper
android:id="@+id/viewFlipper"
android:layout_width="120.0dip"
android:layout_height="120.0dip"
android:flipInterval="3000"
android:inAnimation="@anim/anim_marquee_in"
android:outAnimation="@anim/anim_marquee_out" />
</RelativeLayout>
划重点:两个动画文件,计蒙调试的将近30分钟才调试成类似效果
anim_marquee_in:
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate
android:duration="500"
android:fromYDelta="120%p"
android:toYDelta="0"/>
<scale
android:duration="500"
android:fromXScale="0.8"
android:fromYScale="0.8"
android:toXScale="1"
android:toYScale="1"
android:pivotY="50%"
android:pivotX="50%"/>
</set>
anim_marquee_out:
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate
android:duration="500"
android:fromYDelta="0"
android:toYDelta="-120%p"/>
<scale
android:duration="500"
android:fromXScale="1"
android:fromYScale="1"
android:toXScale="0.8"
android:toYScale="0.8"
android:pivotY="50%"
android:pivotX="50%">
</scale>
</set
在Java文件中为ViewFlipper添加view:
private ViewFlipper viewFlipper;
//---------------------------------
viewFlipper.removeAllViews();
View view = View.inflate(getContext(), R.layout.home_rebroadcast_item, null);
MellowImageView carouselImageView=view.findViewById(R.id.carousel_item_iv);
View view1 = View.inflate(getContext(), R.layout.home_rebroadcast_item1, null);
MellowImageView carouselImageView1=view.findViewById(R.id.carousel_item_iv);
// 循环滚动图片的点击事件
// iv.setOnClickListener(new ....);
//添加view
viewFlipper.addView(view);
viewFlipper.addView(view1);
二、实现效果展示
三、总结
效果其实比较好实现,但是很多地方需要设置一些判断。
来源:https://blog.csdn.net/qq_42761395/article/details/122885290
0
投稿
猜你喜欢
- Remote Debug 综述当我们的后台项目部署到服务器上时,由于环境和本地不同,有时候也会有一些奇奇怪怪的问题出现。只依赖服务器上的日志
- Springboot根据配置文件动态注入接口实现类需求最近在做一个Springboot项目,需要面向不同需求的客户,但是为了方便管理分支,需
- 前言Spring 的 JDBC Templet 是 Spring 对 JDBC 使用的一个基本的封装。他主要是帮助程序员实现了数据库连接的管
- 本文实例为大家分享了Java实现多任务执行助手的具体代码,供大家参考,具体内容如下1.多线程执行任务类package com.visy.th
- 1、什么是反射?在java开发中有一个非常重要的概念就是java反射机制,也是java的重要特征之一。反射的概念是由Smith在1982年首
- 在页面提交到tomcat乱码 解决方法是在tomcat/conf/server.xml中进行配置以tomcat6.0.32为例,需将以下代码
- 在前面的文章<Mybatis配置之<properties>属性配置元素详述>,我们讲述了<properties
- 我就废话不多说了,大家还是直接看代码吧~package com.cloudtech.web.util; import java.io.Buf
- 今天记录一下验证码的实现,希望能够帮助到大家!首先我们看一下实现的效果:此验证码的实现没有用到太多的插件,话不多说直接上代码,大家拿过去就可
- 本文实例讲述了C#判断页面中的多个文本框输入值是否有重复的实现方法,分享给大家供大家参考。具体实现方法如下:List<string&g
- iText介绍和说明因为项目需要生成PDF文件,所以去找了一下能够生成PDF的Java工具,看到了iText可以说好评如潮。如果你想通过ja
- 本文实例讲述了Java实现矩阵加减乘除及转制等运算功能。分享给大家供大家参考,具体如下:Java初学,编写矩阵预算程序,当做工具,以便以后写
- PathVariable 映射 URL 绑定的占位符带占位符的 URL 是 Spring3.0 新增的功能,该功能在SpringMVC 向
- 本文实例讲述了C#实现文件断点续传下载的方法。分享给大家供大家参考。具体实现方法如下:using System;using System.D
- 最可怕的不是犯错而是一直都没发现错误,直到现在我才知道自己对类变量的理解有问题。大概可能也许是因为不常用类变量的原因吧,一直没有发现这个问题
- 一、基本回收算法 1. 引用计数(Reference Counting) 比较古老的回收算法。原理是此对象有一个引用,即增加一个计数,删除一
- 前言Date 类Date 类表示系统特定的时间戳,可以精确到毫秒。Date 对象表示时间的默认顺序是星期、月、日、小时、分、秒、年。构造方法
- 相信大家都见到了微信图标颜色渐变的过程,是不是感觉很牛逼?不得不说微信团队确实是很厉害的团队,不管是从设计还是开发人员。今天我带大家来看看,
- 1.使用java.util.Properties类的load()方法示例:Java代码InputStream in = lnew Buffe
- maven打包指定jdk的版本问题今天遇到个问题,项目中新写了一个接口,其中用到了lambda表达式,本地跑是没问题的,但提交到gitLab