千家信息网

Android怎么实现网易云推荐歌单界面

发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,这篇文章主要介绍"Android怎么实现网易云推荐歌单界面"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Android怎么实现网易云推荐歌单界面"文章能帮助大
千家信息网最后更新 2024年11月23日Android怎么实现网易云推荐歌单界面

这篇文章主要介绍"Android怎么实现网易云推荐歌单界面"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Android怎么实现网易云推荐歌单界面"文章能帮助大家解决问题。

一、实现

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为例。

                                         

3.图片切换动画效果

博主使用的是ViewFlipper。
XML代码如下

    

划重点:两个动画文件,计蒙调试的将近30分钟才调试成类似效果
anim_marquee_in:

                    

anim_marquee_out:

            

在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);

二、实现效果展示

关于"Android怎么实现网易云推荐歌单界面"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

0