Android 实现歌词同步
歌词同步的原理其实很简单:
歌词显示是一个线程, 音乐播放时一个线程,通过播放时间将歌词显示进度与播放进度同步起来。
网络标准的歌词格式是LRC. 我们看下一个LRC文档,其格式就一目了然了.
[ti:爱]
[ar:小虎队]
[al:华纳国语情浓13首]
[by:爱上你了音乐网]
[02:08.00][00:38.00]把你的心、我的心串一串
[02:11.00][00:41.00]串一株幸运草、串一?同心圆
[02:16.00][00:46.00]让所有期待未?的呼唤
[02:19.00][00:49.00]趁青春做?伴
[03:16.00][02:24.00][00:53.00]?让年轻越长大越孤单
[03:19.00][02:27.00][00:56.00]把我的幸运草种在你的梦田
[03:23.00][02:31.00][01:01.00]让地球随我?的同心圆
….
LRC 格式为 [歌词显示起始时间][歌词显示结束时间]歌词内容。
了解歌词同步原理,我们可以想到要做如下工作:
1. LRC 解析
2. LRC 歌词显示
3. 歌词与播放音乐同步
4. 歌词的获取
一 LRC解析
这边我推荐YOYOPlayer 音乐播放开源项目. 源代码已经非常好的支持了LRC解析. 我拿过来就用了.
过程大概如此: 把LRC文件读到内存里面,用 sentence数据结构存放. Sentence里面有 Fromtime, Totime, content三个成员变量。显示的时候需要这些数据。
二. LRC歌词显示
歌词的绘制通过重写 OnDraw方法.
绘制的代码贴出来:
long t = tempTime;
int index = getNowSentenceIndex(t);
if (index == -1) {
return;
}
Sentence now = list.get(index);
float f = (t - now.getFromTime()) * 1.0f
/ (now.getToTime() - now.getFromTime());
if (f > 0.98f) {
f = 0.98f;
}
Shader shader = new LinearGradient(0, 0,
now.getContentWidth(mTxtPaint), 0, new int[] { Color.RED,
Color.BLUE }, new float[] { f, f + 0.01f },
TileMode.CLAMP);
mTxtPaint.setShader(shader);
canvas.drawText(now.getContent(), 0, 20, mTxtPaint);
上面的代码很简单,关键一个函数是getNowSentenceIndex(t). 通过播放时间来获得歌词的索引. 我们看下getNowSentenceIndex()如何实现.
/**
* 得到当前正在播放的那一句的下标 不可能找不到,因为最开头要加一句 自己的句子 ,所以加了以后就不可能找不到了
*
* @return 下标
*/
private int getNowSentenceIndex(long t) {
for (int i = 0; i < list.size(); i++) {
if (list.get(i).isInTime(t)) {
return i;
}
}
// throw new RuntimeException("竟然出现了找不到的情况!");
return -1;
}
还有一个歌词渐变的效果,其关键代码在与对画笔的设置,如下.
Shader shader = new LinearGradient(0, 0,
now.getContentWidth(mTxtPaint), 0, new int[] { Color.RED,
Color.BLUE }, new float[] { f, f + 0.01f },
TileMode.CLAMP);
mTxtPaint.setShader(shader);
三. 歌词与播放音乐同步
音乐播放的时候,同时启动歌词显示线程. 将音乐播放的时间设置到歌词View的成员变量中, 以达到同步的目的。
private class MyHandler extends Handler {
@Override
public void handleMessage(Message msg) {
// Log.v("#################hahah", "" + mp.getCurrentPosition());
// 重画
lrcView.mLyric.setTime(mp.getCurrentPosition());
lrcView.invalidate();
}
}
四. 歌词的获取
歌词的获取是通过百度搜索出来的. 具体代码如下,很好看懂,关键代码如下:
GetMethod get = new GetMethod("http://www.baidu.com/s?wd=" + URLEncoder.encode("filetype:lrc " + key, "GBK"));
get.addRequestHeader("Host", "www.baidu.com");
get.addRequestHeader("User-Agent", "Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.8.1.11) Gecko/20071127 Firefox/2.0.0.11");
get.addRequestHeader("Accept", "text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5");
get.addRequestHeader("Accept-Language", "zh-cn,zh;q=0.5");
get.addRequestHeader("Keep-Alive", "300");
get.addRequestHeader("Referer", "http://www.baidu.com/");
get.addRequestHeader("Connection", "keep-alive");
int i = http.executeMethod(get);
返回的结果是歌词的xml格式转化字符串就可以了,这个太简单了,懒得说了.
分享到:
相关推荐
openkrc是android手机歌词同步显示应用 功能: 1.krc歌词解密、解压、解析 2.歌词逐字同步显示 demo使用说明: 1.将apk安装到手机 2.在sd卡新建openkrc文件夹,并将openkrc_下的文件拷贝到openkrc文件夹 3.运行app ...
在Android平台上开发一款音乐播放器并实现歌词同步是一项复杂但有趣的技术挑战。在这个项目中,开发者需要处理音频播放、UI设计、数据加载以及歌词与音乐的精确匹配等多个方面。以下是一些关键的知识点: 1. **...
1、实现歌词同步滚动的功能,即歌曲播放到哪句歌词,就高亮地显示出正在播放的这个歌词; 2、实现上下拖动歌词时候,可以拖动播放器的进度。即可以不停地上下拖动歌词,当手指离开屏幕时候 即从当前拖动到的歌词...
本文将深入探讨如何在Android应用中实现歌词同步这一技术。 首先,我们需要理解歌词同步的基本原理。歌词同步通常基于LRC格式,这是一种用于存储歌词的时间轴信息的文本文件。LRC文件包含了一系列的时间标签和对应...
在Android平台上开发一款网络音乐播放应用,实现歌词同步功能,是一项技术挑战但也充满乐趣。这里我们探讨的关键知识点包括Android应用程序开发、网络数据获取、JSON解析、音频播放以及歌词同步技术。 首先,...
总的来说,这个压缩包提供了关于如何在Android中使用TextView实现歌词同步的示例代码,对理解和实践这一功能有很好的指导价值。通过阅读和研究源码,开发者可以更好地掌握TextView的自定义和动态更新文本的技巧。
### Android自定义歌词同步控件知识点详解 #### 一、概述 在开发Android音乐播放应用时,实现歌词的同步显示是一项常见的需求。本篇将详细解析如何通过自定义控件来实现这一功能。该控件主要包括两个核心部分:`...
在Android平台上,播放MP3音乐并实现歌词同步是一项常见的需求,尤其对于音乐应用开发者来说,这是一个必不可少的功能。本文将深入探讨如何在Android中处理这个问题,包括解析LRC歌词文件、同步歌词显示以及与音乐...
在Android平台上,歌词同步是一项常见的功能,特别是在音乐播放应用中,它可以为用户提供更好的听歌体验。...通过这个DEMO,开发者可以学习到如何在Android应用中实现歌词的实时同步显示,为用户带来更好的音乐体验。
这个项目“android音乐播放器歌词同步”旨在实现从SD卡中加载歌曲及其对应的歌词文件,并在播放音乐时实现歌词与旋律的实时同步显示。这里我们将深入探讨实现这一功能所需的关键技术和步骤。 首先,我们需要了解...
Android通过自定义View来实现解析lrc歌词并同步滚动、上下拖动、缩放歌词的功能,具体中实现下述功能:1、实现歌词同步滚动的功能,即歌曲播放到哪句歌词,就高亮地显示出正在播放的这个歌词; 2、实现上下拖动...
这个压缩包文件“安卓音乐播放器相关-利用TextView实现歌词同步显示.rar”显然是一个示例项目,它提供了如何在Android应用中使用TextView来实现歌词随着音乐播放而滚动的教程。以下是对这个知识点的详细讲解: 1. *...
这个“安卓Android源码——卡拉OK,歌词同步程序”压缩包包含了一个实现歌词显示与音乐播放同步的示例项目,这对于想要在音乐应用中集成这一功能的开发者具有很高的学习价值。 首先,我们要理解歌词同步的基本原理...
在Android应用中实现歌词同步,通常需要以下几个步骤:1) 获取LRC格式的歌词文件,这是一种时间戳与歌词对应关系的文本文件;2) 解析LRC文件,将时间戳和对应的歌词内容存储到数据结构中,如List或Map;3) 在播放...
本项目中,我们探讨的是一个实现了歌词同步功能的小型卡拉OK应用,它巧妙地结合了XML解析技术和Android的Handler监听回调机制。下面,我们将深入剖析这两个关键技术点。 首先,XML解析是程序中的核心组件之一。XML...
本项目为基于Java的Android平台开发的自定义歌词同步滚动与交互设计源码,集成了67个文件,涵盖19个XML布局文件、9个PNG图片资源、8个Java源代码文件、5个动画GIF文件、4个属性文件、4个二进制文件、3个IDE配置文件...
我们需要读取以上歌词文件的每一行转换成成一个个歌词实体: 代码如下: public class ...在UI线程中另起线程,通过回调函数 onDraw() 每隔100ms重新绘制屏幕,实现歌词平滑滚动的动画效果。MainActivity代码如下: 代码
要实现歌词同步显示,我们需要使用歌词解析结果和当前时间来确定当前展示的歌词。在 LyricView 组件中,我们可以使用以下代码来实现歌词同步显示: ```java private void init() { ... list = mLyric.list; ... ...
本教程将详细介绍标题中提到的三个类:HttpGet、GetLrc和LrcGet,以及如何使用它们来实现歌词下载。 首先,HttpGet类是用于执行HTTP GET请求的工具类,通常基于Apache的HttpClient库或者OkHttp库实现。在Android中...