当前位置: 首页 > news >正文

c 做网站设计哪家公司做网站

c 做网站设计,哪家公司做网站,做感恩网站的图片大全,北京大兴做网站公司思路#xff1a; 通过媒体录制器MediaRecorder实现#xff1a;MediaRecorder是Android自带的音频和视频录制工具#xff0c;它通过操纵摄像头和麦克风完成媒体录制#xff0c;既可录制视频#xff0c;又可单独录制音频。 MediaRecorder常用方法(录音与录像通用)#xf…思路 通过媒体录制器MediaRecorder实现MediaRecorder是Android自带的音频和视频录制工具它通过操纵摄像头和麦克风完成媒体录制既可录制视频又可单独录制音频。 MediaRecorder常用方法(录音与录像通用) reset重置录制资源。prepare准备录制。start开始录制。stop结束录制。release释放录制资源。setOnErrorListener设置错误监听器。可监听服务器异常和未知错误的事件。需要实现接口MediaRecorder.OnErrorListener的onError方法。setOnInfoListener设置信息监听器。可监听录制结束事件包括达到录制时长或达到录制大小。需要实现接口MediaRecorder.OnInfoListener的onInfo方法。setMaxDuration设置可录制的最大时长单位毫秒。setMaxFileSize设置可录制的最大文件大小单位字节。setOutputFile设置输出文件的路径。 setOutputFormat设置媒体输出格式OutputFormat类的输出格式格式分类扩展名格式说明AMR_NB音频.amr窄带格式AMR_WB音频.amr宽带格式AAC_ADTS音频.aac高级的音频传输流格式MPEG_4视频.mp4MPEG4格式THREE_GPP视频.3gp3GP格式 音频录制示例上代码 一.权限添加 uses-permission android:nameandroid.permission.READ_MEDIA_IMAGES /uses-permission android:nameandroid.permission.READ_MEDIA_AUDIO /uses-permission android:nameandroid.permission.READ_MEDIA_VIDEO /uses-permission android:nameandroid.permission.RECORD_AUDIO/uses-permission android:nameandroid.permission.READ_EXTERNAL_STORAGE android:maxSdkVersion32/uses-permission android:nameandroid.permission.WRITE_EXTERNAL_STORAGE android:maxSdkVersion32/ 权限区分版本33及以上和以下 动态权限请求 使用权限请求库在app的build.gradle添加 // 权限请求implementation com.guolindev.permissionx:permissionx:1.7.1 使用音频抖动动效 // https://github.com/xfans/VoiceWaveView implementation com.github.xfans:VoiceWaveView:1.0.2 /*** 请求视频、音频、图片权限*/private void requestPermission() {ArrayListString requestList new ArrayList();if (Build.VERSION.SDK_INT Build.VERSION_CODES.TIRAMISU) {requestList.add(Manifest.permission.READ_MEDIA_IMAGES);requestList.add(Manifest.permission.RECORD_AUDIO);requestList.add(Manifest.permission.READ_MEDIA_VIDEO);} else {requestList.add(Manifest.permission.WRITE_EXTERNAL_STORAGE);requestList.add(Manifest.permission.READ_EXTERNAL_STORAGE);requestList.add(Manifest.permission.RECORD_AUDIO);}PermissionX.init(this).permissions(requestList).onExplainRequestReason((scope, deniedList) - {scope.showRequestReasonDialog(deniedList, UiUtil.getString(R.string.toast_permission_request), UiUtil.getString(R.string.toast_permission_allow), UiUtil.getString(R.string.toast_permission_deny));}).request((allGranted, grantedList, deniedList) - {if (allGranted) {showVoiceAddDialog();LogUtil.i(TAG, 所有申请的权限都已通过);} else {LogUtil.i(TAG, 您拒绝了如下权限: deniedList);}});}/*** 判断是否有存储、音频权限* return */public boolean hasStoragePermissions() {boolean isStorage, isAudio, isVideo, isImages;if (Build.VERSION.SDK_INT Build.VERSION_CODES.TIRAMISU) {isImages ContextCompat.checkSelfPermission(MyApplication.getInstance(), Manifest.permission.READ_MEDIA_IMAGES) PackageManager.PERMISSION_GRANTED;isAudio ContextCompat.checkSelfPermission(MyApplication.getInstance(), Manifest.permission.RECORD_AUDIO) PackageManager.PERMISSION_GRANTED;isVideo ContextCompat.checkSelfPermission(MyApplication.getInstance(), Manifest.permission.READ_MEDIA_VIDEO) PackageManager.PERMISSION_GRANTED;return isImages isAudio isVideo;} else {isStorage ContextCompat.checkSelfPermission(MyApplication.getInstance(), Manifest.permission.WRITE_EXTERNAL_STORAGE) PackageManager.PERMISSION_GRANTED;isAudio ContextCompat.checkSelfPermission(MyApplication.getInstance(), Manifest.permission.RECORD_AUDIO) PackageManager.PERMISSION_GRANTED;return isStorage || isAudio;}} 二.录制代码 package com.calendar.master.gp.dialog;import android.app.AlertDialog; import android.app.Dialog; import android.media.MediaRecorder; import android.os.Bundle; import android.os.Environment; import android.os.Handler; import android.os.Looper; import android.os.Message; import android.text.format.DateFormat; import android.view.Gravity; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.view.Window; import android.view.WindowManager;import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.fragment.app.DialogFragment; import androidx.fragment.app.Fragment; import androidx.viewpager2.adapter.FragmentStateAdapter; import androidx.viewpager2.widget.ViewPager2;import com.calendar.master.gp.R; import com.calendar.master.gp.bean.NoteVoice; import com.calendar.master.gp.databinding.DialogAddVoiceBinding; import com.calendar.master.gp.databinding.DialogEmojiBinding; import com.calendar.master.gp.fragment.EmojiFragment; import com.calendar.master.gp.listener.IVoiceSaveListener; import com.google.android.material.tabs.TabLayout; import com.google.android.material.tabs.TabLayoutMediator; import com.oooppqqzzz.base.utils.LogUtil;import java.io.File; import java.io.IOException; import java.util.ArrayList; import java.util.List;import me.xfans.lib.voicewaveview.VoiceWaveView;/*** 描述* 作者 shawn* 时间 2023/4/2716:44*/ public class VoiceAddDialogFragment extends DialogFragment {private static final String TAG VoiceAddDialogFragment;private MediaRecorder mMediaRecorder;private String voicePath;private String outputFileName;private File fileVoice;private IVoiceSaveListener iVoiceSaveListener;private DialogAddVoiceBinding mBinding;private int recordingTime 0; // 记录录音时长秒private Handler handler new Handler(Looper.getMainLooper()) {Overridepublic void handleMessage(NonNull Message msg) {// 更新UI显示录音时长mBinding.tvVoiceTime.setText(getRecordTime(recordingTime));}};;Overridepublic void onStart() {super.onStart();setCustomStyle();}NullableOverridepublic View onCreateView(NonNull LayoutInflater inflater, Nullable ViewGroup container, Nullable Bundle savedInstanceState) {if (getDialog() null) {return super.onCreateView(inflater, container, savedInstanceState);}// 设置宽度为屏宽、靠近屏幕底部。final Window window getDialog().getWindow();window.setBackgroundDrawableResource(R.color.transparent);window.getDecorView().setPadding(0, 0, 0, 0);WindowManager.LayoutParams wlp window.getAttributes();wlp.gravity Gravity.BOTTOM;wlp.width WindowManager.LayoutParams.MATCH_PARENT;wlp.height WindowManager.LayoutParams.WRAP_CONTENT;window.setAttributes(wlp);return super.onCreateView(inflater, container, savedInstanceState);}NonNullOverridepublic Dialog onCreateDialog(Bundle savedInstanceState) {// 加载布局文件mBinding DialogAddVoiceBinding.inflate(getLayoutInflater());// 音频抖动控件VoiceWaveView voiceWaveView mBinding.vwvVoice;voiceWaveView.setDuration(100);voiceWaveView.addHeader(12).addHeader(14).addHeader(26);voiceWaveView.addBody(27).addBody(17).addBody(38).addBody(88).addBody(38).addBody(24).addBody(8).addBody(18).addBody(48).addBody(30).addBody(60).addBody(38);voiceWaveView.addFooter(24).addFooter(14).addFooter(8);mBinding.ivClose.setOnClickListener(v - {this.dismiss();});mBinding.ivVoiceEdit.setOnClickListener(new View.OnClickListener() {boolean isInput true;Overridepublic void onClick(View v) {if (isInput) {isInput false;voiceWaveView.start();mBinding.ivVoiceEdit.setBackgroundResource(R.mipmap.icon_voice_edit_stop);getPath();startRecord();} else {isInput true;voiceWaveView.stop();cancelRecord();// 移除定时任务handler.removeCallbacks(timerRunnable);voiceStop(true);}}});mBinding.ivVoiceCancel.setOnClickListener(v - {voiceStop(false);fileVoice.delete();recordingTime 0;mBinding.tvVoiceTime.setText(00:00);mBinding.ivVoiceEdit.setBackgroundResource(R.mipmap.icon_voice_edit_start);});mBinding.ivVoiceSave.setOnClickListener(v - {NoteVoice noteVoice new NoteVoice();noteVoice.setUrl(voicePath);noteVoice.setTime(getRecordTime(recordingTime));noteVoice.setFileName(outputFileName);if (iVoiceSaveListener ! null) {iVoiceSaveListener.save(noteVoice);}dismiss();});return new AlertDialog.Builder(getActivity()).setView(mBinding.getRoot()).create();}private void showAd(int selectIndex) {}private void voiceStop(boolean isStop) {if (isStop) {mBinding.ivVoiceCancel.setVisibility(View.VISIBLE);mBinding.ivVoiceSave.setVisibility(View.VISIBLE);mBinding.ivVoiceEdit.setVisibility(View.GONE);} else {mBinding.ivVoiceCancel.setVisibility(View.GONE);mBinding.ivVoiceSave.setVisibility(View.GONE);mBinding.ivVoiceEdit.setVisibility(View.VISIBLE);}}private void setCustomStyle() {// 设置主题这里只能通过xml方式设置主题不能通过Java代码处理因为这是getWindow还是null// 而且window的几乎所有属性都可以通过xml设置setStyle(STYLE_NORMAL, R.style.AddDialogTheme);}/*** 录制前创建一个空文件并获取路径*/private void getPath() {File appDir new File(Environment.getExternalStorageDirectory() File.separator Environment.DIRECTORY_MUSIC, NoteToVoice);if (!appDir.exists()) {appDir.mkdirs();}outputFileName System.currentTimeMillis() .amr;fileVoice new File(appDir, outputFileName);if (!fileVoice.exists()) {try {fileVoice.createNewFile();voicePath fileVoice.getPath();LogUtil.i(shawn, 音频保存路径 voicePath);} catch (IOException e) {e.printStackTrace();}}}/*** 开始录音*/private void startRecord() {// 充值录音时长recordingTime 0;//开始录音操作mMediaRecorder new MediaRecorder(); // 创建一个媒体录制器mMediaRecorder.setOnErrorListener(new MediaRecorder.OnErrorListener() {Overridepublic void onError(MediaRecorder mr, int what, int extra) {if (mr ! null) {mr.reset(); // 重置媒体录制器}}}); // 设置媒体录制器的错误监听器mMediaRecorder.setOnInfoListener(new MediaRecorder.OnInfoListener() {Overridepublic void onInfo(MediaRecorder mr, int what, int extra) {// 录制达到最大时长或者达到文件大小限制都停止录制if (what MediaRecorder.MEDIA_RECORDER_INFO_MAX_DURATION_REACHED|| what MediaRecorder.MEDIA_RECORDER_INFO_MAX_FILESIZE_REACHED) {cancelRecord();}}}); // 设置媒体录制器的信息监听器mMediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC); // 设置音频源为麦克风mMediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.AMR_NB); // 设置媒体的输出格式mMediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); // 设置媒体的音频编码器// mMediaRecorder.setAudioSamplingRate(8); // 设置媒体的音频采样率。可选// mMediaRecorder.setAudioChannels(2); // 设置媒体的音频声道数。可选// mMediaRecorder.setAudioEncodingBitRate(1024); // 设置音频每秒录制的字节数。可选mMediaRecorder.setMaxDuration(10 * 1000); // 设置媒体的最大录制时长// mMediaRecorder.setMaxFileSize(1024*1024*10); // 设置媒体的最大文件大小// setMaxFileSize与setMaxDuration设置其一即可mMediaRecorder.setOutputFile(voicePath); // 设置媒体文件的保存路径try {mMediaRecorder.prepare(); // 媒体录制器准备就绪mMediaRecorder.start(); // 媒体录制器开始录制startRecordingTimer();} catch (Exception e) {LogUtil.i(shawn, 录音出错 e.getMessage());e.printStackTrace();}}// 取消录制操作private void cancelRecord() {if (mMediaRecorder ! null) {mMediaRecorder.setOnErrorListener(null); // 错误监听器置空mMediaRecorder.setPreviewDisplay(null); // 预览界面置空try {LogUtil.i(shawn, 结束录音);mMediaRecorder.stop(); // 媒体录制器停止录制} catch (Exception e) {LogUtil.i(shawn, 结束录音出错 e.getMessage());e.printStackTrace();}mMediaRecorder.release(); // 媒体录制器释放资源mMediaRecorder null;}}Overridepublic void onDestroy() {super.onDestroy();// 移除定时任务handler.removeCallbacks(timerRunnable);}public void setVoiceSaveListener(IVoiceSaveListener iVoiceSaveListener) {this.iVoiceSaveListener iVoiceSaveListener;}private void startRecordingTimer() {handler.postDelayed(timerRunnable, 1000); // 每隔一秒执行一次}private Runnable timerRunnable new Runnable() {Overridepublic void run() {recordingTime;handler.sendEmptyMessage(0); // 通知UI更新startRecordingTimer(); // 继续下一次定时}};private String getRecordTime(int recordingTime) {StringBuilder stringBuilder new StringBuilder();if (recordingTime 10) {stringBuilder.append(00:0).append(recordingTime);} else if (recordingTime 60) {stringBuilder.append(00:).append(recordingTime);} else {int minutes recordingTime / 60;int seconds recordingTime % 60;if (minutes 10) {stringBuilder.append(0).append(minutes).append(:);} else {stringBuilder.append(minutes).append(:);}if (seconds 10) {stringBuilder.append(0).append(seconds);} else {stringBuilder.append(seconds);}}return stringBuilder.toString();} } 设置dialog样式在style.xml !-- 这里的parent必须是Theme.AppCompat.Dialog --style nameAddDialogTheme parentTheme.AppCompat.Dialog!-- 这两个属性对于一个常规的Dialog一般必须设置的--!-- 这两个属性按照下面的值设置之后确保了弹窗的实际显示效果跟你在layout文件中的定义效果是一样的 --item nameandroid:windowIsFloatingfalse/item !-- item nameandroid:windowBackgrounddrawable/radius_add_dialog_bg/item--/style
http://www.w-s-a.com/news/736849/

相关文章:

  • 网站管理助手v3历史上的今天 网站如何做
  • 网站建设与管理的就业方向网站开发前端模板
  • 对网站建设的维护深圳网络推广推荐
  • wordpress多站共享授权码wordpress数据库缓存插件
  • 建一个购物网站多少钱上海商标注册
  • 琪觅公司网站开发面点培训学校哪里有
  • 北京建设工程信息网站江苏企业网站建设
  • php电子商务网站建设wordpress新建的页面如何加xml
  • 去百度建网站外贸业务推广
  • 百度seo 站长工具网络营销课程个人总结3000字
  • 设计品牌网站wordpress商城 中文站
  • 公司网站要备案吗百度售后电话人工服务
  • 北京移动网站建设制作一个购物网站
  • 网站优化排名如何做网络开发工程师
  • 域名已有服务器也有怎么做网站pc 手机网站 微站
  • 鞍山网站设计制作网站最好的外贸网站建设
  • 百度手机模板网站新变更营业执照注册号查了发现之前有备案过网站了
  • 群晖个人网站建设建设网站主机免费版
  • 下载好了网站模板怎么开始做网站阿克苏网站建设价格
  • 有谁做彩票网站学会了vue 能搭建一个网站平台
  • 描述对于营销型网站建设很重要飘红效果更佳教育培训排行榜前十名
  • 国外网站有哪些推荐的网站按关键词显示广告图片
  • 互联网招聘网站排名手机网站系统
  • 网站与云平台区别企业网站建设有什么要求
  • wordpress福利网站源码高端网站设计培训机构
  • 网站建设找客户招标网免费
  • 东莞食品网站建设扬州市住房建设局网站
  • 网站色彩心理建设网站的主要功能有哪些
  • 营销型网站建设运营企业宣传网页设计
  • 建设银行官方网站网址sem搜索