我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android录制声音文件(音频)并播放

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android录制声音文件(音频)并播放

本文实例为大家分享了Android录制音频文件的具体代码,供大家参考,具体内容如下

1、这个demo中没有对多次点击同一个声音文件做详细处理,偶尔会有崩溃,用的时候需要注意。

2、按住录音按钮录音过程中,只对竖直方向处理了一下,水平方向没写;

3、没有做删除某个声音文件的操作,但是测试的时候实现了功能,需要用到的话,在MainActivity—>onItemClick中的TODO中有详细说明;

4、这只是个demo,如果要在项目中使用,先写出demo,没问题了,再引入项目,在写成demo后,在真机上运行的时候,如果出现获取录音权限,最好选择“允许”,如果拒绝,可能会崩溃。

记得打开手机运行录音的权限

先来效果图:

目录结构:

1、添加权限:


 <uses-permission android:name="android.permission.RECORD_AUDIO"/>
 <uses-permission android:name="android.permission.WAKE_LOCK"/>
 <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS"/>
 <uses-permission android:name="android.permission.VIBRATE"/>
 <uses-permission android:name="android.permission.WRITE_SETTINGS"/>
 <uses-permission android:name="android.permission.INTERACT_ACROSS_USERS_FULL"/>
 <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
 <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
 <uses-permission android:name="android.permission.CALL_PHONE"/>
 <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
 <uses-permission android:name="android.permission.INTERNET" />
 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
 <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />

2、新建MediaRecorderUtils,复制以下源码:


package com.chen.voicedemo;
import android.media.MediaRecorder;
import android.os.Handler;
import android.util.Log;
import android.widget.ImageView;
import java.io.File;

public class MediaRecorderUtils {
 private static MediaRecorder recorder;
 static MediaRecorderUtils mediaRecorderUtils;
 static ImageView mimageView;
 private String path;
 
 public static MediaRecorderUtils getInstence(ImageView imageView) {
  if (mediaRecorderUtils == null) {
   mediaRecorderUtils = new MediaRecorderUtils();
  }
  mimageView = imageView;
  return mediaRecorderUtils;
 }
 
 public String getPath() {
  return path;
 }
 
 private void init() {
  recorder = new MediaRecorder();// new出MediaRecorder对象
  recorder.setAudioSource(MediaRecorder.AudioSource.MIC);
  // 设置MediaRecorder的音频源为麦克风 
  recorder.setOutputFormat(MediaRecorder.OutputFormat.RAW_AMR);
  // 设置MediaRecorder录制的音频格式 
  recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
  // 设置MediaRecorder录制音频的编码为amr. 
  File file = new File(Utils.IMAGE_SDCARD_MADER);
  if (!file.exists()) {
   file.mkdirs();
  }
  path = Utils.IMAGE_SDCARD_MADER + Utils.getVoiceFileName() + "stock.amr";
  recorder.setOutputFile(path);
  // 设置录制好的音频文件保存路径 
  try {
   recorder.prepare();// 准备录制 
  } catch (Exception e) {
   e.printStackTrace();
  }
 }
 
 public void MediaRecorderStart() {
  init();
  try {
   recorder.start();
   flag = true;
   if (mimageView != null) {
    updateMicStatus();
   }
  } catch (Exception e) {
   e.printStackTrace();
   Log.e("chen", "录制失败");
  }
 }
 
 public void MediaRecorderStop() {
  try {
   recorder.stop();
   recorder.release(); //释放资源
   flag = false;
   mimageView = null;
   recorder = null;
  } catch (Exception e) {
   e.toString();
  }
 }
 
 public void MediaRecorderDelete() {
  File file = new File(path);
  if (file.isFile()) {
   file.delete();
  }
  file.exists();
 }
 ;
 private final Handler mHandler = new Handler();
 private Runnable mUpdateMicStatusTimer = new Runnable() {
  public void run() {
   updateMicStatus();
  }
 };
 private int BASE = 1;
 private int SPACE = 1000;// 间隔取样时间
 private boolean flag = true;
 
 private void updateMicStatus() {
  if (recorder != null) {
   double ratio = (double) recorder.getMaxAmplitude() / BASE;
   double db = 0;// 分贝
   if (ratio > 1) {
    db = 20 * Math.log10(ratio);
   }
   int i = (int) db / 10;
   switch (i) {
    case 1:
     mimageView.setImageResource(R.drawable.rc_ic_volume_1);
     break;
    case 2:
     mimageView.setImageResource(R.drawable.rc_ic_volume_2);
     break;
    case 3:
     mimageView.setImageResource(R.drawable.rc_ic_volume_3);
     break;
    case 4:
     mimageView.setImageResource(R.drawable.rc_ic_volume_4);
     break;
    case 5:
     mimageView.setImageResource(R.drawable.rc_ic_volume_5);
     break;
    case 6:
     mimageView.setImageResource(R.drawable.rc_ic_volume_6);
     break;
    case 7:
     mimageView.setImageResource(R.drawable.rc_ic_volume_7);
     break;
    case 8:
     mimageView.setImageResource(R.drawable.rc_ic_volume_8);
     break;
   }
   if (flag) {
    mHandler.postDelayed(mUpdateMicStatusTimer, SPACE);
   }
  }
 }
}

3、创建MyChronometer,复制以下代码


package com.chen.voicedemo;
import android.annotation.SuppressLint;
import android.content.Context;
import android.os.Handler;
import android.os.Message;
import android.os.SystemClock;
import android.util.AttributeSet;
import android.view.accessibility.AccessibilityEvent;
import android.view.accessibility.AccessibilityNodeInfo;
import android.widget.TextView;
public class MyChronometer extends TextView {
 private static final String TAG = "MyChronometer";
 
 public interface OnMyChronometerTickListener {
  
  void onMyChronometerTick(int time);
 }
 public interface OnMyChronometerTimeListener {
  
  void OnMyChronometerTimeListener(int time);
 }
 private OnMyChronometerTimeListener OnMyChronometerTimeListener;
 private long mBase;
 private boolean mVisible;
 private boolean mStarted;
 private boolean mRunning;
 private OnMyChronometerTickListener mOnMyChronometerTickListener;
 private long now_time;
 private static final int TICK_WHAT = 2;
 
 public MyChronometer(Context context) {
  this(context, null, 0);
 }
 
 public MyChronometer(Context context, AttributeSet attrs) {
  this(context, attrs, 0);
 }
 
 public MyChronometer(Context context, AttributeSet attrs, int defStyle) {
  super(context, attrs, defStyle);
  init();
 }
 private void init() {
  mBase = SystemClock.elapsedRealtime();
  updateText(mBase);
 }
 
 public void setBase(long base) {
  mBase = base;
  updateText(SystemClock.elapsedRealtime());
 }
 
 public void setOnMyChronometerTickListener(OnMyChronometerTickListener listener) {
  mOnMyChronometerTickListener = listener;
 }
 public void setOnMyChronometerTimeListener(OnMyChronometerTimeListener listener) {
  OnMyChronometerTimeListener = listener;
 }
 
 public void start() {
  mStarted = true;
  updateRunning();
 }
 
 public void stop() {
  mStarted = false;
  updateRunning();
  now_time /= 10;
  if (OnMyChronometerTimeListener != null) {
   OnMyChronometerTimeListener.OnMyChronometerTimeListener((int) now_time);
  }
 }
 @Override
 protected void onDetachedFromWindow() {
  super.onDetachedFromWindow();
  mVisible = false;
  updateRunning();
 }
 @Override
 protected void onWindowVisibilityChanged(int visibility) {
  super.onWindowVisibilityChanged(visibility);
  mVisible = visibility == VISIBLE;
  updateRunning();
 }
 private synchronized void updateText(long now) {
  long seconds = now - mBase;
  seconds /= 10;
  now_time = seconds;
  int time_m = (int) (seconds / 100);
  if (mOnMyChronometerTickListener != null) {
   mOnMyChronometerTickListener.onMyChronometerTick(time_m);
  }
  int time_s = (int) (seconds % 100);
  setText(time_m + "");
 }
 private void updateRunning() {
  boolean running = mVisible && mStarted;
  if (running != mRunning) {
   if (running) {
    updateText(SystemClock.elapsedRealtime());
    mHandler.sendMessageDelayed(Message.obtain(mHandler, TICK_WHAT), 1000);
   } else {
    mHandler.removeMessages(TICK_WHAT);
   }
   mRunning = running;
  }
 }
 private Handler mHandler = new Handler() {
  public void handleMessage(Message m) {
   if (mRunning) {
    updateText(SystemClock.elapsedRealtime());
    sendMessageDelayed(Message.obtain(this, TICK_WHAT), 1000);
   }
  }
 };
 @SuppressLint("NewApi")
 @Override
 public void onInitializeAccessibilityEvent(AccessibilityEvent event) {
  super.onInitializeAccessibilityEvent(event);
  event.setClassName(MyChronometer.class.getName());
 }
 @SuppressLint("NewApi")
 @Override
 public void onInitializeAccessibilityNodeInfo(AccessibilityNodeInfo info) {
  super.onInitializeAccessibilityNodeInfo(info);
  info.setClassName(MyChronometer.class.getName());
 }
}

4、创建工具类

package com.chen.voicedemo;


import android.Manifest;
import android.content.Context;
import android.content.pm.PackageManager;
import android.os.Environment;
import android.support.v4.content.ContextCompat;
import android.widget.Toast;
import java.io.File;
import java.text.SimpleDateFormat;
import java.util.ArrayList;

public class Utils {
 
 public static final String IMAGE_SDCARD_MADER = Environment
   .getExternalStorageDirectory()
   + "/chen/voice/";
 
 public static boolean checkVoice(Context context) {
  try {
   if (ContextCompat.checkSelfPermission(context, Manifest.permission.RECORD_AUDIO) != PackageManager.PERMISSION_GRANTED) {
    return false;
   } else {
    return true;
   }
  } catch (Exception e) {
   return true;
  }
 }
 private static Toast toast;
 
 public static void showToast(Context context, String msg) {
  if (toast == null) {
   toast = Toast.makeText(context, msg, Toast.LENGTH_SHORT);
  }
  toast.setText(msg);
  toast.show();
 }
 
 public static ArrayList<String> getVideoFiles(String root) {
  if (root == null || root == "")
   return null;
  ArrayList<String> list = new ArrayList<>();
  File file = new File(root);
  File[] fileList = file.listFiles();
  for (File f : fileList) {
   list.add(f.getPath());
  }
  return list;
 }
 
 public static String getVoiceFileName() {
  long getNowTimeLong = System.currentTimeMillis();
  SimpleDateFormat time = new SimpleDateFormat("yyyyMMddHHmmss");
  String result = time.format(getNowTimeLong);
  return result;
 }
}

5、MainActivity


package com.chen.voicedemo;
import android.app.Activity;
import android.graphics.drawable.AnimationDrawable;
import android.graphics.drawable.ColorDrawable;
import android.media.MediaPlayer;
import android.os.Bundle;
import android.os.SystemClock;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.PopupWindow;
import android.widget.TextView;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends Activity implements View.OnTouchListener, AdapterView.OnItemClickListener {
 
 private TextView voice;
 
 private TextView voice_popup;
 
 private TextView show_voice_list;
 
 private ListView show_voices_listview;
 private List<String> voiceList;
 
 private TextView stop_show_voice;
 
 private ImageView voice_anim;
 
 private MediaPlayer mediaPlayer;
 private Boolean flag = true;
 private float int_x = 0;
 private float int_y = 0;
 
 private int maxRecordTime = 60;
 
 private int oftenOperationTime = 500;
 private MyAdapter myAdapter;
 private AnimationDrawable animation;
 
 private PopupWindow voice_popupWindow;
 
 private ImageView voice_shengyin;
 
 private MyChronometer mychronometer;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  requestWindowFeature(Window.FEATURE_NO_TITLE);
  setContentView(R.layout.activity_main);
  voiceList = new ArrayList<String>();
  voice = (TextView) findViewById(R.id.voice);
  voice_popup = (TextView) findViewById(R.id.voice_popup);
  voice_anim = (ImageView) findViewById(R.id.voice_anim);
  voice_anim.setImageResource(R.drawable.lcs_voice_receive);
  show_voice_list = (TextView) findViewById(R.id.show_voice_list);
  show_voice_list.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    voiceList = Utils.getVideoFiles(Utils.IMAGE_SDCARD_MADER);
    if (voiceList.size()>0){
     myAdapter.notifyDataSetChanged();
    }else{
     Utils.showToast(MainActivity.this, "没有文件");
    }
   }
  });
  show_voices_listview = (ListView) findViewById(R.id.show_voices);
  show_voices_listview.setOnItemClickListener(this);
  myAdapter = new MyAdapter();
  stop_show_voice = (TextView) findViewById(R.id.stop_show_voice);
  
  stop_show_voice.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    Log.e("chen", "点击了停止播放按钮");
    if (mediaPlayer != null) {
     if (mediaPlayer.isPlaying()) {
      mediaPlayer.release();// 释放资源
     }
     mediaPlayer = null;
    }
    if (animation != null && animation.isRunning()) {
     animation.stop();
    }
    voice_anim.setImageResource(R.drawable.lcs_voice_receive);
   }
  });
  show_voices_listview.setAdapter(myAdapter);
  voice.setOnTouchListener(this);
 }
 
 @Override
 public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
  //TODO 以下4行,是用来做测试,点击item,手机SD卡上对应路径下的声音文件就会被删除。如果录制声音失败,或者不满足条件,可以把以下4行写成一个工具方法调用,删除不满意的文件。这里不做详细演示
  //File f_delete=new File(voiceList.get(position));
  //f_delete.delete();
  //voiceList.remove(voiceList.get(position));
  //myAdapter.notifyDataSetChanged();
  //TODO 以上4行,是用来做测试,点击item,手机SD卡上对应路径下的声音文件就会被删除。
  try {
   mediaPlayer = new MediaPlayer();
   
   mediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
    @Override
    public void onPrepared(MediaPlayer mp) {
     if (mp != null) {
      mp.start();
      voice_anim.setImageResource(R.drawable.voice_anim);
     }
    }
   });
   
   mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
    @Override
    public void onCompletion(MediaPlayer mp) {
     if (mp.isPlaying()) {
      mp.release();// 释放资源
     }
     animation = (AnimationDrawable) voice_anim.getDrawable();
     if (animation != null && animation.isRunning()) {
      animation.stop();
     }
     voice_anim.setImageResource(R.drawable.lcs_voice_receive);
    }
   });
   mediaPlayer.setDataSource(voiceList.get(position));
   // 缓冲
   mediaPlayer.prepare();
  } catch (Exception e) {
   Utils.showToast(MainActivity.this, "语音异常,加载失败");
  }
 }
 
 class MyAdapter extends BaseAdapter {
  @Override
  public int getCount() {
   return voiceList.size() == 0 ? 0 : voiceList.size();
  }
  @Override
  public Object getItem(int position) {
   return null;
  }
  @Override
  public long getItemId(int position) {
   return 0;
  }
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
   TextView tv = new TextView(MainActivity.this);
   tv.setText(voiceList.get(position));
   tv.setTextSize(20);
   return tv;
  }
 }
 
 @Override
 public boolean onTouch(View v, MotionEvent event) {
  if (v.getId() == R.id.voice) {
   //检查权限
   if (!Utils.checkVoice(this)) {
    if (event.getAction() == MotionEvent.ACTION_DOWN) {
     Utils.showToast(this, "录音权限未打开,请打开录音权限!");
    }
    return true;
   }
   //避免短时间里频繁操作
   if (!getTimeTF(SystemClock.elapsedRealtime()) && event.getAction() == MotionEvent.ACTION_DOWN) {
    Utils.showToast(this, "操作过于频繁");
    return true;
   }
   if (event.getAction() == MotionEvent.ACTION_DOWN) {
    setTime(SystemClock.elapsedRealtime());
   }
   switch (event.getAction()) {
    case MotionEvent.ACTION_DOWN:
     int_x = event.getRawX();
     int_y = event.getRawY();
     VoicePopupWindow();
     mychronometer.setBase(SystemClock.elapsedRealtime());
     mychronometer.start();
     MediaRecorderUtils.getInstence(voice_shengyin).MediaRecorderStart();
     flag = true;
     mychronometer.setOnMyChronometerTickListener(new MyChronometer.OnMyChronometerTickListener() {
      @Override
      public void onMyChronometerTick(int time) {
       if (time == maxRecordTime || time > maxRecordTime) {
        mychronometer.setText("60");
        setVoiceToUp();
       }
      }
     });
     break;
    case MotionEvent.ACTION_MOVE:
     if (flag) {
      if (Math.abs(int_y) - Math.abs(event.getRawY()) > 100.0 && flag) {
       voice_popupWindow.dismiss();
       mychronometer.stop();
       MediaRecorderUtils.getInstence(voice_shengyin).MediaRecorderStop();
       MediaRecorderUtils.getInstence(voice_shengyin).MediaRecorderDelete();
       flag = false;
      }
     }
     break;
    case MotionEvent.ACTION_CANCEL:
     if (flag) {
      voice_popupWindow.dismiss();
      mychronometer.stop();
      MediaRecorderUtils.getInstence(voice_shengyin).MediaRecorderStop();
     }
     break;
    case MotionEvent.ACTION_UP:
     if (flag) {
      setVoiceToUp();
     }
     break;
   }
   return true;
  }
  return false;
 }
 private long base_time = 0;
 private void setTime(long time) {
  base_time = time;
 }
 private boolean getTimeTF(long time) {
  int data = (int) (time - base_time) / oftenOperationTime;
  if (data > 1) {
   return true;
  } else {
   return false;
  }
 }
 
 public void VoicePopupWindow() {
  View view = LayoutInflater.from(this).inflate(R.layout.voice_popupwindow, null);
  voice_popupWindow = new PopupWindow(this);
  voice_popupWindow.setWidth(WindowManager.LayoutParams.MATCH_PARENT);
  voice_popupWindow.setHeight(WindowManager.LayoutParams.MATCH_PARENT);
  voice_shengyin = (ImageView) view.findViewById(R.id.voice_shengyin);
  mychronometer = (MyChronometer) view.findViewById(R.id.mychronometer);
  voice_popupWindow.setContentView(view);
  voice_popupWindow.setFocusable(true);
  ColorDrawable dw = new ColorDrawable(0x00000000);
  voice_popupWindow.setBackgroundDrawable(dw);
  voice_popupWindow.showAsDropDown(voice_popup);
 }
 private void setVoiceToUp() {
  flag = false;
  voice_popupWindow.dismiss();
  mychronometer.stop();
  MediaRecorderUtils.getInstence(voice_shengyin).MediaRecorderStop();
  int time = Integer.parseInt(mychronometer.getText().toString());
  if (time != 0) {
   File file = new File(MediaRecorderUtils.getInstence(voice_shengyin).getPath());
   if (file.length() > 0) {
    voiceList = Utils.getVideoFiles(Utils.IMAGE_SDCARD_MADER);
    myAdapter.notifyDataSetChanged();
   } else {
    Utils.showToast(this, "录音失败,请检查权限");
   }
  } else {
   Utils.showToast(this, "录音时间太短");
  }
 }
}

6、activity_main布局


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 >
 <TextView
  android:id="@+id/voice_popup"
  android:layout_width="match_parent"
  android:layout_height="1dip"/>
 <ListView
  android:id="@+id/show_voices"
  android:layout_width="match_parent"
  android:layout_height="0dp"
  android:layout_weight="1"/>
 <RelativeLayout
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="horizontal">
  <ImageView
   android:id="@+id/voice_anim"
   android:layout_width="60dp"
   android:layout_height="30dp"
   android:layout_centerVertical="true"
   android:layout_marginLeft="30dp"
   android:background="#00ff00"/>
  <TextView
   android:id="@+id/stop_show_voice"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_alignParentRight="true"
   android:layout_centerVertical="true"
   android:layout_gravity="center_horizontal"
   android:layout_marginBottom="20dp"
   android:layout_marginRight="20dp"
   android:background="#00ff00"
   android:padding="10dp"
   android:text="停止播放"
   android:textColor="#000000"
   android:textSize="20sp"
   />
  <TextView
   android:id="@+id/show_voice_list"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_centerVertical="true"
   android:layout_gravity="center_horizontal"
   android:layout_marginBottom="20dp"
   android:layout_marginRight="20dp"
   android:layout_toLeftOf="@id/stop_show_voice"
   android:background="#00ff00"
   android:padding="10dp"
   android:text="列表"
   android:textColor="#000000"
   android:textSize="20sp"
   />
 </RelativeLayout>
 <TextView
  android:id="@+id/voice"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_gravity="center_horizontal"
  android:background="#00ff00"
  android:padding="10dp"
  android:text="开始录音"
  android:textColor="#000000"
  android:textSize="25sp"/>
</LinearLayout>

7、voice_popupwindow布局代码:录音的时候,会出现以下图片中的popupwindow


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
 <LinearLayout
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_centerInParent="true"
  android:background="@android:color/black"
  android:orientation="vertical"
  android:paddingBottom="40dip"
  android:paddingLeft="60dip"
  android:paddingRight="60dip"
  android:paddingTop="40dip">
  <ImageView
   android:id="@+id/voice_shengyin"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_gravity="center_horizontal"
   android:class="lazy" data-src="@drawable/rc_ic_volume_1"/>
  <com.chen.voicedemo.MyChronometer
   android:id="@+id/mychronometer"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_centerHorizontal="true"
   android:layout_gravity="center_horizontal"
   android:textColor="@android:color/white"/>
 </LinearLayout>
</RelativeLayout>

8、还有一个动画布局,播放声音的时候,有个动画效果


<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/volume_animation"
    android:oneshot="false" >
 <item
  android:drawable="@drawable/rc_ic_voice_receive_play1"
  android:duration="100"/>
 <item
  android:drawable="@drawable/rc_ic_voice_receive_play2"
  android:duration="200"/>
 <item
  android:drawable="@drawable/rc_ic_voice_receive_play3"
  android:duration="300"/>
</animation-list>

附录:用到的图片资源说明:如果手上没有这样的图片,可以随便用其他图片代替,有效果,就算成功

您可能感兴趣的文章:Android MediaPlayer 音频倍速播放 调整播放速度问题Android MediaPlayer 播放音频的方式详解Android开发录音和播放音频的步骤(动态获取权限)Android使用SoundPool实现播放音频Android自定义View实现音频播放圆形进度条Android多媒体应用使用SoundPool播放音频Android多媒体应用使用MediaPlayer播放音频Android开发之MediaPlayer多媒体(音频,视频)播放工具类Android编程实现播放音频的方法示例Android音频处理之通过AudioRecord去保存PCM文件进行录制,播放,停止,删除功能Android App中使用AudioManager类来编写音频播放器Android提高之MediaPlayer播放网络音频的实现方法android实现小音频频繁播放


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android录制声音文件(音频)并播放

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android录制声音文件(音频)并播放

本文实例为大家分享了Android录制音频文件的具体代码,供大家参考,具体内容如下1、这个demo中没有对多次点击同一个声音文件做详细处理,偶尔会有崩溃,用的时候需要注意。 2、按住录音按钮录音过程中,只对竖直方向处理了一下,水平方向没写;
2022-06-06

Android实现音频录音与播放

这篇文章主要为大家详细介绍了Android实现音频录音与播放,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
2022-11-13

jquery如何播放音频文件

jQuery提供了一种简单有效的方法来播放音频文件。只需将音频文件添加到HTML中,使用jQuery的audio方法选择元素,然后使用play()方法播放即可。jQuery还提供了控制播放(暂停、恢复、停止)、设置音量、获取当前时间等功能。更高级的用法包括循环播放、自动播放和跨浏览器兼容性。通过使用jQuery的音频功能,您可以轻松地将音频集成到您的网站中,提升用户体验。
jquery如何播放音频文件
2024-04-02

【代码】Python播放MP3音频文件

按推荐顺序排列①使用playsound库from playsound import playsoundplaysound('xx.mp3')②使用pygame库from pygame import mixer import timemixe
2023-01-31

HTML5中怎么实现声音录制/播放功能

这篇文章主要介绍HTML5中怎么实现声音录制/播放功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!html代码:
2023-06-09

jquery如何播放音频文件类型

本文介绍了如何使用jQuery播放音频文件,提供了多种方法:HTML5音频元素、音频对象和jQueryMedia插件。此外,还讲解了如何监听音频播放器事件。通过阅读本文,开发者可以了解如何使用jQuery轻松控制音频播放。
jquery如何播放音频文件类型
2024-04-02

Android实现自制和播放录音程序

首先,让我们先看下实现的截图:当有录音文件存在时,会显示在下面的ListView当中。 下面给出实现的完整代码: 1.主程序代码package irdc.ex07_11; import java.io.File; import java.i
2022-06-06

WinForm中如何播放音频或视频文件

在WinForm中播放音频或视频文件可以使用Windows Media Player控件,以下是一个简单的示例代码:using System;using System.Windows.Forms;namespace AudioVideo
WinForm中如何播放音频或视频文件
2024-04-08

iOS使用音频处理框架The Amazing Audio Engine实现音频录制播放

iOS 第三方音频框架The Amazing Audio Engine使用,实现音频录制、播放,可设置配乐。 首先看一下效果图:下面贴上核心控制器代码:#import "ViewController.h" #import
2022-05-27

Android开发基础实现音频文件的播放详解

这篇文章主要为大家介绍了Android开发基础实现音频文件的播放详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-06

Android中Webview中解决H5音视频播放有声音无画面,页面关闭还有声音的问题

Webview中关于H5音视频有声音无画面的问题 android通过Webvoew加载一个H5页面,H5里面有一个视频,之前还好好的,突然发现,视频只有声音没有画面,好奇怪,最终找到解决方案,记录一下,方便以后用到 1,applicatio
2022-06-06

Android仿微信、录制音频并发送功能

MyRecorder(仿微信,录制音频并发送功能)①布局实现(activity_main.xml) 布局采用线性布局,上面使用的一个ListView,下面使用的是一个自定义的Button(会在下面进行介绍)2022-06-06

Android音频录制MediaRecorder之简易的录音软件实现代码

使用MediaRecorder的步骤:1、创建MediaRecorder对象2、调用MediRecorder对象的setAudioSource()方法设置声音的来源,一般传入MediaRecorder.MIC3、调用MediaRecorde
2022-06-06

Android蓝牙开发系列文章-AudioTrack播放PCM音频

终于迎来了蓝牙a2dp的第二篇:利用AudioTrack播放PCM音频数据。如想查看更多内容,请点击《Android蓝牙开发系列文章-策划篇》。 先回顾一下上一篇文章《Android蓝牙开发系列文章-蓝牙音箱连接》讲到的蓝牙音箱的完成配对、
2022-06-06

Android音频处理之通过AudioRecord去保存PCM文件进行录制,播放,停止,删除功能

音频这方面很博大精深,我这里肯定讲不了什么高级的东西,最多也只是一些基础类知识,首先,我们要介绍一下Android他提供的录音类,实际上他有两个,一个是MediaRecorder,还有一个就是我们今天要用到的AudioRecord,那他们有
2022-06-06

利用 GetUserMedia 和 MediaRecorder API 玩转音频录制、播放和下载

GetUserMedia​ 和 MediaRecorder 为网页端带来了强大的媒体处理能力。通过它们,现在我们可以方便地在网页中实现录音、音频效果处理以及实时语音通话等功能了。

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录