android音乐在线播放Demo 播放时间 缓冲进度和播放进度

  次阅读 来源:互联网(转载协议) 2015-09-29 10:25 我要评论(0)

本事例的界面很简单,一个按钮用来开始缓冲音乐,一个进度条用来显示音乐的缓冲进度和播放进度,后面是一个文本用来显示音乐的播放时间,还有一个图片按钮用来播放和暂停音乐。

在main.xml中的代码如下;

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:orientation="vertical" android:layout_width="fill_parent"

android:layout_height="fill_parent" android:padding="10px"

android:background="@drawable/back">

<TextView android:id="@+id/text_kb_streamed"

android:layout_width="fill_parent" android:layout_height="wrap_content"

android:textStyle="bold" android:text="流媒体测试" />

<Button android:id="@+id/button_stream" android:layout_width="wrap_content"

android:layout_height="wrap_content" android:layout_marginTop="10px"

style="?android:attr/buttonStyleSmall" android:text="开始缓冲" />

<RelativeLayout android:layout_width="wrap_content"

android:layout_height="wrap_content">

<SeekBar android:id="@+id/progress_bar" android:layout_height="wrap_content"

android:layout_width="200px" style="?android:attr/progressBarStyleHorizontal" />

<TextView android:id="@+id/playTime" android:layout_width="wrap_content"

android:layout_height="wrap_content" android:layout_toRightOf="@id/progress_bar"

android:text="00:00"></TextView>

</RelativeLayout>

<RelativeLayout android:layout_width="wrap_content"

android:layout_height="wrap_content">

<ImageButton android:id="@+id/button_play"

android:layout_width="wrap_content" android:layout_height="wrap_content"

android:layout_marginTop="5px" style="?android:attr/buttonStyleSmall"

android:src="@drawable/button_pause" />

</RelativeLayout>

</LinearLayout>

流媒体类

新建流媒体类StreamingMediaPlayer。

1. 构造函数StreamingMediaPlayerStreamingMediaPlayer(Contextcontext, ImageButtonplayButton, ButtonstreamButton, SeekBarprogressBar,TextView playTime)传递context(上下文)和主界面UI元素,以便在程序中更新界面。代码如下;

public StreamingMediaPlayer(Contextcontext, ImageButtonplayButton, ButtonstreamButton, SeekBarprogressBar,TextView playTime)

{

this.context = context;

this.playButton = playButton;

this.playTime=playTime; //播放的进度时刻

this.progressBar = progressBar;

}

2. startStreaming(final String mediaUrl, long mediaLengthInKb, longmediaLengthInSeconds)方法,传递音频的URL以及在更新进度条中使用的两个元素。在startStreaming()中开启一个线 程,然后调用downloadAudioIncrement()方法。

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 汤晓鸥:人工智能的中国式文艺复兴

    汤晓鸥:人工智能的中国式文艺复兴

  • 区块链最近太火,但A股多家公司明确表态不考虑涉足

    区块链最近太火,但A股多家公司明确表态不考虑涉足

  • 全球陷入"区块链狂热"潮,大规模应用还需等待

    全球陷入"区块链狂热"潮,大规模应用还需等待

  • 马云的新零售?张近东的智慧零售?抑或是刘强东的第四次零售革命?

    马云的新零售?张近东的智慧零售?抑或是刘强东的第四次零售革命?

网友点评网友点评
阅读推荐阅读推荐

算法 任何一个入门的软件开发人员都会听到这句话:算法是软件的灵魂!近年来大火的机器学习即是在算法在人工智能上的集中体现。今日头条通...

据《日本经济新闻》报道,日本东京大学教授稻叶雅幸等人开发出再现日本人骨骼肌肉构造的机器人。机器人各部位的肌肉和骨骼长度与日本人的平...

以奥黛丽-赫本为原型打造的人形机器人索菲娅首次拜访了印度。索菲娅是世界上首位获得公民身份的机器人,她在12月30日出现在了印度理工学院...

在查获现场,代售点电脑旁的一台机器人通过敲击电脑键盘抢票。 广州日报惠州讯 (全媒体记者秦仲阳 通讯员张中铃摄影报道)2018年春运售票已...