返回顶部
首页 > 资讯 > 精选 >Android如何实现客户端语音动弹界面
  • 567
分享到

Android如何实现客户端语音动弹界面

android 2023-05-30 17:05:48 567人浏览 独家记忆
摘要

这篇文章主要介绍Android如何实现客户端语音动弹界面,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下:首先,整体界面分三部分,最上层自定义ActionBar相信不需要我讲大家就能看出来了。中间部分是文字

这篇文章主要介绍Android如何实现客户端语音动弹界面,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

具体内容如下:

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; }

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

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如何实现客户端语音动弹界面”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Android如何实现客户端语音动弹界面

本文链接: https://lsjlt.com/news/220184.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android如何实现客户端语音动弹界面
    这篇文章主要介绍Android如何实现客户端语音动弹界面,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下:首先,整体界面分三部分,最上层自定义ActionBar相信不需要我讲大家就能看出来了。中间部分是文字...
    99+
    2023-05-30
    android
  • 如何在Android界面中实现一个回弹效果
    这篇文章给大家介绍如何在Android界面中实现一个回弹效果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。具体代码如下所示:public class MyScrollView extends ScrollView { ...
    99+
    2023-05-31
    android roi %d
  • 微信小程序中如何调起客户端扫码界面
    这篇“微信小程序中如何调起客户端扫码界面”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“微信小程序中如何调起客户端扫码界面”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢理解,接下来...
    99+
    2023-06-26
  • 小程序开发中如何调起客户端扫码界面
    这篇文章主要为大家展示了小程序开发中如何调起客户端扫码界面,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“小程序开发中如何调起客户端扫码界面”这篇文章吧。调起客户端扫码界面,扫码成功后返回对应的结果...
    99+
    2023-06-26
  • python中如何实现客户端通信
    这篇文章将为大家详细讲解有关python中如何实现客户端通信,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、实现流程创建一套接字。用connect()函数连接到服务器。使用sendall()向服务器发送...
    99+
    2023-06-15
  • Java中Socket如何实现Redis客户端
    小编给大家分享一下Java中Socket如何实现Redis客户端,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!Redis是最常见的缓存服务中间件,在java开发中,一般使用 jedis 来实现。Redis的命令协议:$参数...
    99+
    2023-06-15
  • android聊天界面如何实现
    要实现一个Android聊天界面,可以按照以下步骤进行:1. 创建一个聊天界面的布局文件,可以使用LinearLayout或者Rel...
    99+
    2023-09-18
    android
  • Android socket实现原理详解 服务端和客户端如何搭建
    本文实例为大家分享了Android socket的实现原理,供大家参考,具体内容如下Socket套接字 是网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字。socket实现的原理机制:通信的两端都有Socket...
    99+
    2023-05-30
    android socket roi
  • 如何实现C#服务端与客户端连接
    今天就跟大家聊聊有关如何实现C#服务端与客户端连接,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C#服务端与客户端连接实现的时间性:当服务器开始对端口侦听之后,便可以创建客户端与它建...
    99+
    2023-06-17
  • Python如何实现MySQL客户端操作库
    这篇文章主要介绍了Python如何实现MySQL客户端操作库,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。PyMySQL 是一个纯 Python...
    99+
    2024-04-02
  • 如何在HTML5中实现客户端存储
    如何在HTML5中实现客户端存储?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。离线检测要知道设备是否在线还是离线,HTML5 定义了一个 navigator.o...
    99+
    2023-06-09
  • C#中如何实现服务端与客户端通信
    这篇文章将为大家详细讲解有关C#中如何实现服务端与客户端通信,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。C#服务端与客户端通信实现实例:class Server {&n...
    99+
    2023-06-17
  • android 仿微信demo——微信消息界面实现(移动端)
    目录移动端微信消息页实现总结移动端微信消息页实现 在上一篇中主界面实现说过微信四个页面中间都是是fragment的,并且四个fragment的布局都还没实现,所以这一篇主要实现微信...
    99+
    2024-04-02
  • vue如何实现网易云音乐纯界面
    这篇“vue如何实现网易云音乐纯界面”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue如何实现网易云音乐纯界面”文章吧。项...
    99+
    2023-07-02
  • PostgreSQL数据库如何实现客户端验证
    这篇文章将为大家详细讲解有关PostgreSQL数据库如何实现客户端验证,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。身份验证是数据库服务器建立客户端身份的过程,并通过扩...
    99+
    2024-04-02
  • Golang如何实现 pipeline 模式的 redis 客户端
    这篇文章主要介绍“Golang如何实现 pipeline 模式的 redis 客户端”,在日常操作中,相信很多人在Golang如何实现 pipeline 模式的 redis 客户端问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
    99+
    2023-06-20
  • 如何使用java实现客户端与服务器
    小编给大家分享一下如何使用java实现客户端与服务器,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Java可以用来干什么Java主要应用于:1. web开发;2....
    99+
    2023-06-14
  • java中如何实现WebSocket客户端断线重连
    这篇文章给大家分享的是有关java中如何实现WebSocket客户端断线重连的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Maven依赖<dependency>   &n...
    99+
    2023-06-25
  • Android中如何实现移动端页面强制竖屏
    小编给大家分享一下Android中如何实现移动端页面强制竖屏,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!最近工作中写了一个移动端的页面,本来是没什么的,但是有一...
    99+
    2023-06-08
  • php如何实现用户注册登录界面
    今天小编给大家分享一下php如何实现用户注册登录界面的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。php实现用户注册登录界面...
    99+
    2023-07-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作