类似有道云笔记那种,每条笔记可以插入音频文件,在ListView中呈现。
1、音频文件的显示使用自定义组合控件InsertAudioView,并通过自定义接口audioClickListener,对外暴露一个设置监听的方法setOnAudioClickListener,在该控件的初始化操作中为其设置点击事件。
public void setOnAudioViewClickListener(audioViewClickListener listener) {
this.mListener = listener;
}
public interface audioViewClickListener {
void onAudioViewClick();
}
public void setInsertAudioViewText(String string) {
mTextView.setText(string);
}
//设置插入的音频文件名称
public void setInsertAudioViewTextSize(int size) {
mTextView.setTextSize(TypedValue.COMPLEX_UNIT_SP, size);
}
setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
mListener.onAudioViewClick();
}
});
2、音频播放
adapter扩展于BaseAdapter,在getView方法中,通过ViewHolder获取到item布局和所有控件,点击选择某个item的音频文件后,使用MediaPlayer进行播放,此处需要注意,为保证整个ListView中只有一个MediaPlayer,最后使用单例模式,考虑线程安全,我用的饿汉式。当然如果没有使用单例模式也是可以的,除了第一次播放,以后每次播放MediaPlayer在setDataResource之前都要reset一下,原因参考MediaPlayer的状态转化图:
点击播放后,音频布局要变成播放进度条这样的:
而其他未被点击的,或者点击了未播放完的item中的音频布局还是最初的自定义控件显示。
3、因此,播放音频之前,重置所有item中的音频布局。在getView方法之外,写一个重置布局的方法,遍历ListView中所有的item:
/**
* 重置所有的item音频显示布局
*/
private void resetSoundView() {
for (int i = 0; i < mListView.getChildCount(); i ++){
View childView= mListView.getChildAt(i);
InsertAudioView insertAudioView = (InsertAudioView) childView.findViewById(R.id.diary_item_sound);
LinearLayout play_audio_view = (LinearLayout) childView.findViewById(R.id.diary_item_sound_play);
insertAudioView.setVisibility(View.VISIBLE);
play_audio_view.setVisibility(View.INVISIBLE);
}
}
大功告成~~