先看下效果吧 由于实现这个效果的重心是在于js,html 和 css 大家看代码就明白了 html 歌词滚动效果 <audio src="https.../assets/data.<em>js</em>"; console.log(lrc) 3....完整js代码 data.js var lrc = `[00:01.06]难念的经 [00:03.95]演唱:周华健 [00:06.78] [00:30.96]笑你我枉花光心计 [00:34.15].../assets/data.js"; /** * 将歌词字符 转换为对象的形式 * obj = {time:开始时间, words: 歌词内容} */ const parseLrc = ()
本文实例为大家分享了Android实现歌词滚动效果的具体代码,供大家参考,具体内容如下 自定义TextView public class VerticalScrollTextView extends TextView
最近在做Android 的MP3播放的项目,要实现歌词的自动滚动,以及同步显示。 lyric的歌词解析主要用yoyoplayer里面的,显示部分参考了这里 ,这里只是模拟MP3歌词的滚动。...先上一下效果图: ? 滚动实现的代码其实也简单。显示画出当前时间点的歌词,然后再分别画出改歌词后面和前面的歌词,前面的部分往上推移,后面的部分往下推移,这样就保持了当前时间歌词在中间。...mPaint.setTextSize(22); mPaint.setColor(Color.WHITE); mPaint.setTypeface(Typeface.SERIF); // 高亮部分 当前歌词...* * @return currentDunringTime 歌词只需的时间 */ public long updateIndex(long time) { // 歌词序号 index =...就是取出歌词的index,和该行歌词持续的时间进行sleep。
先看效果: 实现: 1.定义导航栏的文字标签: 北极光。...space-between; align-items: center; transition: 0.5s; } transition 过渡效果...: bold; color: rgb(28, 36, 148); text-decoration: none; } 6.当页面有滚动后导航栏的样式...} .bian .logo,.tou.bian a{ color: rgb(252, 247, 247); } 7.简单js...所以: 第一种js写法就是有滚动>0时就添加类.biao而实现渐变效果,当滚动<=0时就移除.biao类回到原来; 第二种就是布尔值判断,当滚动>0就强制添加.biao类,当滚动<=0就移除.biao
关于滚动的那些事,相信不少的小伙伴都知道,在做网页动态效果时,时常有需求是关于滚动效果的实现的。在360或搜狐等门户网站的首页中,我们也时常见到这种效果。...以上是从360导航中截取的,都是信息滚动效果。今天我们要来实现下面这个小例子。效果可以有两种,分别是无缝滚动和间歇性无缝滚动。 首先是无缝滚动的效果。 以下是我简单的介绍这个例子的主要思路。...这样就实现了可以一直滚动下去的效果了。 在开始前,我们要知道几个js的属性(很重要,要牢记!)...//返回 自身元素的高度+隐藏子元素的高度(注意,obj为滚动元素的父元素) 好了,开始码代码,首先是HTML结构和css样式: 效果如下: 接下来就是使用原生js让文字滚动起来了。...接着就设置一个setInterval函数了,来个50毫秒执行一次吧 这样,就实现了文字在box区域中的滚动效果了: 现在内容是在无缝滚动了,我们可以加个鼠标滑过时停止滚动,鼠标移出时继续滚动的效果。
根据信息滚动效果我们可以有很多的实现方式,但HTML自带的 marquee标签 是其中一个较简单的实现方式。下面记录一下,供日后查阅。...值alternate 表示在两端之间来回滚动; 值scroll 表示由一端重复滚动到另一端,为默认值; 值slide 表示由一端不重复地滚动到另一端。 direction , 滚动的方向。...loop ,滚动的次数。默认值-1表示一直滚动。 scrollAmount , 设置一次滚动的步长。默认值为6, 当设置为负数时将采用默认值进行滚动。..."> 滚动的消息 四、总结 当我们只需实现当条特别公告等简单信息滚动效果时,marquee标签是一个很不错的选择...(虽然HTML5中已经将其废除并建议使用CSS3动画效果代替)
本文实例为大家分享了SurfaceView播放视频发送弹幕,并实现滚动歌词,供大家参考,具体内容如下 SurfaceView使用步骤 使用SurfaceView的步骤: 首先要继承SurfaceView...,danMu.getX(),danMu.getY(),paint); } surfaceView_danmuHolder.unlockCanvasAndPost(canvas); } } } } 实现滚动歌词...要准备一个装有时间和歌词的集合,准备一个Timer计时器和一个该展示第几个歌词。...每隔一秒去拿该歌词的下一个歌词时间与进度匹配,如果进度 =该时间,那么就画该歌词在SurfaceView上;<则不画该歌词 一定要写SD卡读写权限!!!!!
视差滚动(Parallax Scrolling)是指让多层背景以不同的速度移动,形成立体的运动效果,带来非常出色的视觉体验。 作为网页设计的热点趋势,越来越多的网站应用了这项技术。...通常而言,滚动视差在前端需要辅助 Javascript 才能实现。当然,其实 CSS 在实现滚动视差效果方面,也有着不俗的能力。...下面就让我们来见识一二: background-attachment: fixed 话不多说,上效果 链接在这里 这种方法是将背景固定在了网页后边 ---- transform: translate3d...话不多说,上效果 链接在这里 原理: 1.给父元素给上perspective属性,3px效果最好 2.给父元素里面的子盒子加上浮动属性 3.给不同的元素设置不同的transform: translateZ...()属性,在设置完之后元素大小会发生变化,使用scale()属性将其变回来 4.给子元素设置了不同的translateZ(),子元素离摄像机的距离就越远,在滚动时候移动的上下距离相就越小,这就达到了滚动视差的效果
功能描述:锁屏歌曲信息、控制台远程控制音乐播放:暂停/播放、上一首/下一首、快进/快退、锁屏状态下列表菜单弹框和拖拽控制台的进度条调节进度(结合了QQ音乐和网易云音乐在锁屏状态下的效果)、歌词解析并随音乐滚动显示...总效果预览图.gif ---- 第一部分:锁屏效果包括:锁屏歌曲信息和远程控制音乐播放 ① 锁屏歌曲信息显示 ?...效果类似于网易云音乐锁屏时的效果 //添加喜欢按钮 MPFeedbackCommand *likeCommand = commandCenter.likeCommand;..., copy) NSString * lrc ; @end 接下来就是要让歌词随歌曲的进度来滚动显示,主要代码如下: self.tableView 显示歌词的 currentTime...当前播放时间点 self.currentRow 当前时间点歌词的位置 //歌词滚动显示 for ( int i = (int)(self.lrcArray.count
功能描述:锁屏歌曲信息、控制台远程控制音乐播放:暂停/播放、上一首/下一首、快进/快退、锁屏状态下列表菜单弹框和拖拽控制台的进度条调节进度(结合了QQ音乐和网易云音乐在锁屏状态下的效果)、歌词解析并随音乐滚动显示...[总效果预览图.gif] **** 第一部分:锁屏效果包括:锁屏歌曲信息和远程控制音乐播放 ① 锁屏歌曲信息显示 [iOS11以下锁屏信息预览] //展示锁屏歌曲信息:图片、歌词、进度、歌曲名、演唱者、...效果类似于网易云音乐锁屏时的效果 //添加喜欢按钮 MPFeedbackCommand *likeCommand = commandCenter.likeCommand;..., copy) NSString * lrc ; @end 接下来就是要让歌词随歌曲的进度来滚动显示,主要代码如下: self.tableView 显示歌词的 currentTime...当前播放时间点 self.currentRow 当前时间点歌词的位置 //歌词滚动显示 for ( int i = (int)(self.lrcArray.count
本文实例为大家分享了android实现滚动文本效果的具体代码,供大家参考,具体内容如下 效果图 ?...static class VirtualPos { public double x; public double y; public double z; public String text; } /** * 滚动的偏移值...可以根据需要改变自定view的改变滚动值的方法,就可以使滚轮滚动。...例如将滚动的角度和手指拖动相结合啥的 /** * 滚动的偏移值 * @param deviantAngle 最大为1 */ public void setDeviantAngle(float deviantAngle
我相信很久以前,大家在谈横向图片轮播是时候,优先会选择具有HorizontalScrollView效果和ViewPager来做,不过自从Google大会之后,系统为我们提供了另一个控件RecyclerView...今天就利用RecyclerView实现我们需要的相册效果。 先上一个图: ? 主要实现就是一个RecyclerView+RecyclerView.Adapter实现。...TextUtils.isEmpty(jsonString.toString())) { return new HashMap(); } String js...Gson(); Type type = new TypeToken(){ }.getType(); Map map = gson.fromJson(js
视差滚动是一种在网页设计和视频游戏中常见的视觉效果技术,它通过在不同速度上移动页面或屏幕上的多层图像,创造出深度感和动感。...实现方式 1、background-attachment 通过配置该 CSS 属性值为fixed可以达到背景图像的位置相对于视口固定,其他元素正常滚动的效果。...对于较远的层(如背景层),使用 scale() 进行放大,以补偿由于距离产生的视觉缩小效果。 当用户滚动页面时,由于各层位于不同的 Z 轴位置,它们会以不同的速度移动,从而产生视差效果。...3、ReactScrollParallax 想得到更炫酷的滚动视差效果,纯 CSS 的实现方式就会有些吃力。...如下是在 React 中实现示例,通过监听滚动事件,封装统一的视差组件,来达到多样的动画效果。
今天逛京东金融的时候发现他家网站首页的滚动效果看着很有意思,于是就做了一个,demo链接http://1.liwenyang.applinzi.com/index.html 大多数的视差滚动效果都是使用...js来实现的,实际上,如果你对兼容性要求不是很高,比方说忽略IE浏览器,则我们使用简单的几行CSS代码就可以实现视差滚动效果了。...css有一个background-attachment属性 作用是设置背景图像是否固定或者随着页面的其余部分滚动。...DOCTYPE html> css视差滚动 <link
我相信很久以前,大家在谈横向图片轮播是时候,优先会选择具有HorizontalScrollView效果和ViewPager来做,不过自从Google大会之后,系统为我们提供了另一个控件RecyclerView...今天就利用RecyclerView实现我们需要的相册效果。 先上一个图: 主要实现就是一个RecyclerView+RecyclerView.Adapter实现。...TextUtils.isEmpty(jsonString.toString())) { return new HashMap(); } String js...Gson(); Type type = new TypeToken(){ }.getType(); Map map = gson.fromJson(js
本文介绍了Android 基于RecyclerView实现的歌词滚动自定义控件,分享给大家,具体如下: 先来几张效果图: ? ?...((;′⌒`)) 接下来说一下实现原理: 该控件分为以下几个部分: 歌词自动滚动 歌词颜色字体变化 触碰屏幕歌词不滚动,高亮显示,离开时自动移动到当前歌词位置 触碰屏幕中间线条出现以及显示该歌词的时间...1.对于滚动,我们可以调用 RecyclerView.smoothScrollBy() 方法, 相对于 ScrollBy() 方法,该方法能够实现平滑滑动。 我设置了总共显示九句歌词。...mWordList); wordList.add(""); wordList.add(""); wordList.add(""); wordList.add(""); 由于歌词的滚自动滚动是根据歌词时间来进行移动的...所以我们需要需要使用 Runable 来执行滚动操作。而且为了避免内存泄漏。将 Runable 实现类修饰为 static 。所以歌词列表索引位置有所变化。
这两天有个任务,说是要写一个QQ音乐播放器歌词的那种效果,毕竟刚学自定义View,没有什么思路,然后就Google.写了一个歌词效果,效果图在后面,下面是我整理的代码。...首先实现这种效果有两种方式: 1.自定义View里重载onDraw方法,自己绘制歌词 2.用ScrollView实现 第一种方式比较精确,但要支持滑动之后跳转播放的话难度很大,所以我选择第二种,自定义ScrollView...));//将高度添加到对应的item位置 } }); lycicList.addView(textView); lyricItems.add(index,textView); } } } /** * 滚动到...oldindex) { editText.setText(""+index); lrc_index = index; System.out.println("===="+index+"======"); //滚动...handle不能放在这,因为,这是滚动监听事件,滚动到下一次,handle又会发送一次消息,出现意想不到的效果 } }); handler.sendEmptyMessageDelayed(1,4000)
fullPage超简易版本 1.知识点 JS 滚动监听事件 JS 移动端touch监听事件 函数节流 DOM操作 2.示例GIF ?...示例GIF 3.代码分析 1.CSS html, body设置 overflow 为 hidden, 让视图中只包括一个分页;设置滑动分页的长宽都是 100%; 外部容器设置 transition 过渡效果..., 并设置为相对定位, 滚动是修改外部容器的 Top 值, 实现滚动效果. html, body { padding: 0; margin: 0; overflow: hidden; } ....向下滚动时, 当 currentPosition 比 -整体分页高度 大的时候(绝对值相比小的时候), 向下滚动;向上滚动时, 当 currentPosition 大于 0 的时候, 向上滚动. /...滚动事件firefox与其他浏览器的事件不同, 所以需要进行判断. deltaY大于0的时候, 想下滚动; 反之, 向上滚动. var handlerWheel = throttle(scrollMove
innerHTML=demo1.innerHTML//克隆demo1为demo2 function Marquee(){ if(demo2.offsetHeight-demo.scrollTop<=0)//当滚动至...=setInterval(Marquee,speed)//设置定时器 demo.onmouseover=function() {clearInterval(MyMar)}//鼠标移上时清除定时器达到滚动停止的目的...//克隆demo1为demo2 function Marquee(){ console.log(‘调用’) if(demo2.offsetHeight-demo.scrollTop<=0)//当滚动至...=setInterval(Marquee,speed)//设置定时器 demo.onmouseover=function() {clearInterval(MyMar)}//鼠标移上时清除定时器达到滚动停止的目的
关于Android实现文字上下滚动这个功能,我目前有两种方法实现: 一个是在TextView 中加上翻转的动画效果,然后设置循环滚动;一种是改写ViewPager 的滚动方向,使它从下到上进行滚动,...并设置循环滚动; 首先介绍第一种方法: 实现思路:自定义TextView,在TextView中加上从下到上滚动的动画效果,然后设置循环播放; 创建一个AutoTextVieW使之继承TextView...在接下来的动画翻转效果中,根据这个高度设置TextView上下滚动的距离。...with(alpha); mAnimStart.setDuration(DURATION); mAnimStart.addListener(this); } /** * 从屏幕下面向上的动画效果...mAnimOver.setDuration(DURATION); } 接下来实现ObjectAnimator的监听事件,在onAnimationEnd 调用setText方法,在动画没结束一次更新文字,并且继续执行动画效果
领取专属 10元无门槛券
手把手带您无忧上云