我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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();    }        @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 rectclass="lazy" data-src = new Rect(0, 0, b.getWidth(), b.getHeight());            final Rect rectDest = new Rect(0,0,getWidth(),getHeight());            canvas.drawBitmap(b, rectclass="lazy" data-src, rectDest, paint);        } else {            super.onDraw(canvas);        }    }        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;    }}

效果图如下:

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

时间原因,一些简单的细节没有画上去。

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:class="lazy" data-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);

二、实现效果展示

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

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

这篇文章主要介绍“Android怎么实现网易云推荐歌单界面”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android怎么实现网易云推荐歌单界面”文章能帮助大家解决问题。一、实现1.自定义一个圆角图
2023-06-29

怎么使用Python爬取网易云歌曲评论实现词云图

这篇文章主要讲解了“怎么使用Python爬取网易云歌曲评论实现词云图”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用Python爬取网易云歌曲评论实现词云图”吧!环境使用Python
2023-06-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录