当前位置:首页 > 谈天说地

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

34资源网2022-02-14462
目录
  • 前言
  • 一、实现
    • 1.自定义一个圆角图片控件(也可直接使用第三方框架)
    • 2.进行布局摆设
    • 3.图片切换动画效果
  • 二、实现效果展示
    • 三、总结

      先来看看网易云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);
      

      二、实现效果展示

      三、总结

      效果其实比较好实现,但是很多地方需要设置一些判断。

      到此这篇关于android实现网易云推荐歌单界面的文章就介绍到这了,更多相关android网易云歌单界面内容请搜索萬仟网以前的文章或继续浏览下面的相关文章希望大家以后多多支持萬仟网!

      看完文章,还可以扫描下面的二维码下载快手极速版领4元红包

      快手极速版二维码

      快手极速版新人见面礼

      除了扫码领红包之外,大家还可以在快手极速版做签到,看视频,做任务,参与抽奖,邀请好友赚钱)。

      邀请两个好友奖最高196元,如下图所示:

      快手极速版邀请好友奖励

      扫描二维码推送至手机访问。

      版权声明:本文由34楼发布,如需转载请注明出处。

      本文链接:https://www.34l.com/post/7666.html

      分享给朋友:

      相关文章

      网友分享:自媒体写作100天的得出的4条经验,希望对你有用

      网友分享:自媒体写作100天的得出的4条经验,希望对你有用

      要说到自媒体写作,那对于很多人来说还是相当难的,虽然说很难,不过总是会有人写的。这不,今天小编就摘录了一位网友自媒体写作100天的4条经验,希望对你有用。…

      智能电视和普通电视的区别,智能电视好还是普通电视好?

      智能电视和普通电视的区别,智能电视好还是普通电视好?

      好多人对智能电视和普通的区别还分不大清楚,今天小编就将智能电视和和普通电视做个简单明了的介绍,希望对大家有所帮助。简单的讲,就是智能电视可以看直播电视,也可以点播一些网络电视来看,这个就是最大的区别。当然,有些智能电视还有储存功能,比如,可…

      抖音传话筒项目(傻瓜式复制粘贴轻松月入3000+)

      抖音传话筒项目(傻瓜式复制粘贴轻松月入3000+)

      可能你觉得你写不出优秀的文案,可能你觉得你没办法配音,可能你觉得不好意思露脸,但又想通过抖音来赚钱,那么今天给大家来说说这个抖音传话筒项目,只需要复制粘贴,一个月轻松赚到3000+,无需露脸配音,更加不需要写文案。…

      逍遥手机模拟器怎么用(逍遥安卓模拟器详细使用教程)

      逍遥手机模拟器怎么用(逍遥安卓模拟器详细使用教程)

      真正的5V5公平竞技对战,传承端游纯正体验。人气英雄,经典还原;公平竞技,实力至上;峡谷传说,掌心再现。策略、战术、意识、配合,在移动端重现峡谷战场乐趣。 为了庆祝大家期待已久的中国区开服,官方也带来了五大福利活动,用户可免费参与,并获得十…