Android实现客户端语音动弹界面实例代码

作者:mrr 时间:2023-03-04 08:27:04 

今天为大家介绍一下语音动弹界面的实现,新版本的客户端大家应该都看过了,这里我就只简单的介绍一下控件布局了。你可以在这里看到本控件的完整源码:http://git.oschina.net/oschina/android-app/blob/master/osc-android-app/src/net/oschina/app/widget/RecordButton.java

Android实现客户端语音动弹界面实例代码

首先,整体界面分三部分,最上层自定义ActionBar相信不需要我讲大家就能看出来了。

中间部分是文字动弹部分,主体就是一个设置了Padding(margin)的EditText,在EditText下面是一个剩余输入字数的描述。其实在“您还可以输入XX字”的左边还有一个用于显示录音图标的ImageView.

最下层是本文主要讲解的录音自定义控件的实现。

下面一整块整体都是自定义控件的区域,我将其命名为RecordButton,是一个继承自RelateiveLayout的ViewGroup。

在其中包括了左中右三个ImageView:试听与删除,中间的录音按钮。

在录音按钮的上下各有一个用于提示的TextView。

整体布局的载入可以通过调用 View.inflater(cxt, R.layout.xxx, null); 就行了。

同前一篇讲的一样,作为控件界面控制逻辑,我们主要看一下onTouchEvent方法:当手指按下的时候,初始化录音器。手指在屏幕上移动的时候如果滑到按钮之上的时候,event.getY会返回一个负值(因为滑出控件了嘛)。这里我写的是-50主要是为了多一点缓冲,防止误操作。

先来看代码


@Override
public boolean onTouchEvent(MotionEvent event) {
 if (mAudioFile == null) {
  return false;
 }
 if (!mTouchInPlayButton) {
  return false;
 }
 switch (event.getAction()) {
 case MotionEvent.ACTION_DOWN:
  initBorderLine();
  break;
 case MotionEvent.ACTION_MOVE:
  if (event.getY() < 0) {
   viewToInit();
   break;
  }
  if (event.getX() > mRightButtonX) {
   mIsCancel = true;
   scaleView(mImgDelete, 1.5f);
  } else if (event.getX() < mLeftButtonX) {
   scaleView(mImgListen, 1.5f);
  } else {
   mIsCancel = false;
   viewToInit();
  }
  break;
 case MotionEvent.ACTION_UP:
  if (mIsCancel || event.getY() < -50) {
   cancelRecord();
  } else if (event.getX() < mLeftButtonX) {// 试听
   playRecord();
   finishRecord();
  } else if (event.getX() > mRightButtonX) {// 删除
   cancelRecord();
  } else {
   finishRecord();
  }
  viewToInit();
  bottomFlag.setVisibility(View.VISIBLE);
  topFlag.setVisibility(View.GONE);
  mIsCancel = false;
  mTouchInPlayButton = false;
  break;
 }
 return true;
}

其中录音相关的工具类还是和之前的一样,这就是把功能与视图分开的好处,随时用随时复制粘贴过来就用了。


/**
* {@link #RecordButton}需要的工具类
*
* @author kymjs(http://www.kymjs.com/)
*/
public class RecordButtonUtil {
public static final String AUDOI_DIR = Environment
  .getExternalStorageDirectory().getAbsolutePath() + "/oschina/audio"; // 录音音频保存根路径
private String mAudioPath; // 要播放的声音的路径
private boolean mIsRecording;// 是否正在录音
private boolean mIsPlaying;// 是否正在播放
private OnPlayListener listener;
// 初始化 录音器
private void initRecorder() {
 mRecorder = new MediaRecorder();
 mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
 mRecorder.setOutputFormat(MediaRecorder.OutputFormat.AMR_NB);
 mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
 mRecorder.setOutputFile(mAudioPath);
 mIsRecording = true;
}
/** 开始录音,并保存到文件中 */
public void recordAudio() {
 initRecorder();
 try {
  mRecorder.prepare();
 } catch (IOException e) {
  e.printStackTrace();
 }
 mRecorder.start();
}
/** 获取音量值,只是针对录音音量 */
public int getVolumn() {
 int volumn = 0;
 // 录音
 if (mRecorder != null && mIsRecording) {
  volumn = mRecorder.getMaxAmplitude();
  if (volumn != 0)
   volumn = (int) (10 * Math.log(volumn) / Math.log(10)) / 7;
 }
 return volumn;
}
/** 停止录音 */
public void stopRecord() {
 if (mRecorder != null) {
  mRecorder.stop();
  mRecorder.release();
  mRecorder = null;
  mIsRecording = false;
 }
}
public void startPlay(String audioPath) {
 if (!mIsPlaying) {
  if (!StringUtils.isEmpty(audioPath)) {
   mPlayer = new MediaPlayer();
   try {
    mPlayer.setDataSource(audioPath);
    mPlayer.prepare();
    mPlayer.start();
    if (listener != null) {
     listener.starPlay();
    }
    mIsPlaying = true;
    mPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
     @Override
     public void onCompletion(MediaPlayer mp) {
      if (listener != null) {
       listener.stopPlay();
      }
      mp.release();
      mPlayer = null;
      mIsPlaying = false;
     }
    });
   } catch (Exception e) {
    e.printStackTrace();
   }
  } else {
   AppContext.showToastShort(R.string.record_sound_notfound);
  }
 } // end playing
}
public interface OnPlayListener {
 /** 播放声音结束时调用 */
 void stopPlay();
 /** 播放声音开始时调用 */
 void starPlay();
}
}

如果细心,你会发现左右两个圆形按钮,会随着手指移动到上面的时候放大,这其实也是一个通过监听ontouch事件,对两个圆形按钮设置动画产生的效果,和谐带人就是下面这句了。(注,setScaleX和setScaleY方法只有在API10,也就是3.0以上的版本才能调用):


if (event.getX() > mRightButtonX) {
mIsCancel = true;scaleView(mImgDelete, 1.5f);
} else if (event.getX() < mLeftButtonX) {
scaleView(mImgListen, 1.5f);
} else {
mIsCancel = false;viewToInit();
}
private void scaleView(View view, float scaleXY) {
if (android.os.Build.VERSION.SDK_INT > 10) {
 view.setScaleX(scaleXY);
 view.setScaleY(scaleXY);
}
}

总结

以上所述是小编给大家介绍的Android实现客户端语音动弹界面实例代码网站的支持!

来源:https://my.oschina.net/kymjs/blog/424455

标签:android,客户端语音,语音,动弹
0
投稿

猜你喜欢

  • Spring Cloud 配置中心内容加密的配置方法

    2023-02-11 09:05:15
  • Android 使用gradle打包Assets目录的案例

    2023-08-05 22:29:45
  • Mybatis利用OGNL表达式处理动态sql的方法教程

    2022-11-26 22:22:02
  • RestTemplate自定义请求失败异常处理示例解析

    2021-12-03 22:13:17
  • SpringBoot 多任务并行+线程池处理的实现

    2023-04-02 01:16:25
  • C#实现简单的点餐系统

    2023-02-09 19:25:03
  • Spring Boot2中如何优雅地个性化定制Jackson实现示例

    2021-09-27 12:21:15
  • Android 自动补全提示输入AutoCompleteTextView、 MultiAutoCompleteTextView

    2022-12-30 12:18:05
  • android仿支付宝密码输入框效果

    2021-08-06 12:14:01
  • Spring Boot深入排查 java.lang.ArrayStoreException异常

    2023-07-11 16:31:27
  • 详解Winform里面的缓存使用

    2022-07-22 21:16:32
  • 浅谈C#中Process类的使用详解

    2022-11-13 01:42:44
  • 值得Java开发者关注的7款新工具

    2023-11-02 23:05:31
  • 怎么把本地jar包放入本地maven仓库和远程私服仓库

    2023-12-05 20:13:00
  • Android ListView实现上拉加载下拉刷新和滑动删除功能

    2021-09-24 19:08:04
  • 实现一个Android锁屏App功能的难点总结

    2022-07-21 03:03:19
  • c#操作ftp类分享

    2023-02-27 12:50:17
  • C# 静态变量与静态方法实例研究

    2023-04-23 04:26:00
  • 实例详解MyBatis-plus自动填充功能

    2023-06-17 14:14:36
  • Android程序美化之自定义ListView背景的方法

    2023-12-13 17:52:57
  • asp之家 软件编程 m.aspxhome.com