运用手机多媒体
01 通知
案例
//创建通知管理
manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
//创建通道渠道
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O){
NotificationChannel channel = new NotificationChannel(
"vashon","测试通知",NotificationManager.IMPORTANCE_HIGH);
manager.createNotificationChannel(channel);
}
//我的消息具体内容
Intent intent = new Intent(this, NotificationActivity.class);//自定义的notificationActivity
PendingIntent pendingIntent = PendingIntent.getActivity(
this,0,intent,0);
//创建通知
notification = new NotificationCompat.Builder(this,"vashon")
.setContentTitle("我的通知")
.setContentText("这是通知内容")
.setSmallIcon(R.drawable.ic_launcher_background)//不能是RGB图
.setLargeIcon(BitmapFactory.decodeResource(getResources(),R.drawable.ic_launcher_background))//大图标
.setColor(Color.parseColor("#ff0000")) //小图标颜色
.setAutoCancel(true) //点击后取消
.setContentIntent(pendingIntent) //通知具体信息
.build();
manager.notify(1,notification);
.setVibrate(new long[]{1000,1000,1000,1000}) //设置震动 设置震动时需要修改manifest.xml文件
.setLights(Color.GREEN,1000,1000) //设置led灯闪烁
.setSound(Uri.fromFile(new File("/system/media..."))) //通知声音
.setDefaults(NotificationCompat.DEFAULT_ALL) //默认设置
<uses-permission android:name="android.permission.VIBRATE" /> <!--允许震动-->
.setSytle
.setStyle(new NotificationCompat.BigTextStyle().bigText("这个setStyle可以展示文本的所有内容,内容过长时不会用省略号.")) //当setContentText存在时不会起效
.setStyle(new NotificationCompat.BigPictureStyle().bigPicture(BitmapFactory.decodeResource(getResources(),R.drawable.studio))) //设置大图片. studio是png文件
02 调用摄像头和相册
代码实例:
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
private static final int TAKE_PHOTO = 1;
private ImageView picture;
private Uri imageUri;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//00 获得按钮和imageView,并设置button的点击事件
Button button = (Button) findViewById(R.id.button);
button.setOnClickListener(this);
picture = (ImageView) findViewById(R.id.imageView);
}
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.button:
//01 创建File对象,用于接收拍摄之后获得的图片,这里将图片命名为output_image.jpg
//01_1 getExternalCacheDir()用于获得SD卡存放当前应用缓存数据的位置.具体路径:
///sdcard/Android/data/<package name>/cache.
File outputImage = new File(getExternalCacheDir(),"output_image.jpg");
try {
if (outputImage.exists()){
outputImage.delete();
}
outputImage.createNewFile();
}catch (IOException e){
e.printStackTrace();
}
//02 将File对象转换成Uri对象.
if (Build.VERSION.SDK_INT >= 24){
//FileProvider是特殊的内容提供器,使用了和内容提供器类似的机制来对数据进行保护,
// 可以选择性的将封装过的Uri共享给外部.提高了应用的安全性
imageUri = FileProvider.getUriForFile(MainActivity.this,
"com.example.multimedia.fileprovider",outputImage);
}else{
//手机系统版本低于Android 7.0
imageUri = Uri.fromFile(outputImage);
}
//03 启动相机程序
Intent intent = new Intent("android.media.action.IMAGE_CAPTURE");
//03_1 指定照片输出地址.
intent.putExtra(MediaStore.EXTRA_OUTPUT,imageUri);
//03_2 开启相机,并会有结果返回.
startActivityForResult(intent,TAKE_PHOTO);
break;
default:
break;
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
switch (requestCode){
//04 拍照之后照片存储到imageView
case TAKE_PHOTO:
if (resultCode == RESULT_OK){
try {
Bitmap bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(imageUri));
picture.setImageBitmap(bitmap);
}catch (FileNotFoundException e){
e.printStackTrace();
}
}
break;
default:
break;
}
super.onActivityResult(requestCode, resultCode, data);
}
}
注册内容提供器
<!-- 内容提供器注册 -->
<!-- name随便,但是需要和刚getUriForFile()文件中的一致 meta-data表示uri共享的具体路径 -->
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="com.example.multimedia.fileprovider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths" />
</provider>
<!--res目录下新建xml目录,新建file_paths.xml文件-->
<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<!--name随便填.path是集体共享路径,为空表示整个sd卡进行共享 -->
<external-path name="my_images" path="/" />
</paths>
03 从相册中选择照片
在manifest中注册权限
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
申请查看图库的权限
case R.id.button2:
//05 检查是否有相册权限,没有则申请
if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.WRITE_EXTERNAL_STORAGE)
!= PackageManager.PERMISSION_GRANTED){
//05_1申请权限
ActivityCompat.requestPermissions(MainActivity.this,
new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},1);
}else{
openAlbum();
}
break;
// 05_2 申请查看照片权限之后
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
switch (requestCode){
case 1:
if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){
openAlbum();
}else{
Toast.makeText(this,"You denied the permission",
Toast.LENGTH_SHORT).show();
}
break;
default:
break;
}
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
}
打开图库,在图库中选择照片
//06 打开相册,从相册中选取图片
private void openAlbum() {
Intent intent = new Intent("android.intent.action.GET_CONTENT");
intent.setType("image/*");
//打开相册
startActivityForResult(intent,CHOOSE_PHOTO);
}
选取图片之后对图片进行处理
//07 选取照片之后,回到主界面.照片存储到imageView
case CHOOSE_PHOTO:
if (resultCode == RESULT_OK){
// 4.4及以上系统使用这个方法处理图片
if (Build.VERSION.SDK_INT >= 19){
handleImageOnKitKat(data);
}else{
//4.4以下系统
handleImageBeforeKitKat(data);
}
}
break;
// 07_1 4.4以上系统使用这个方法处理图片
private void handleImageOnKitKat(Intent data) {
String imagePath = null;
Uri uri = data.getData();
if (DocumentsContract.isDocumentUri(this,uri)){
//如果是document类型的Uri,则通过document id 处理
String docId = DocumentsContract.getDocumentId(uri);
if ("com.android.providers.media.documents".equals(uri.getAuthority())){
//解析出数字格式的id
String id = docId.split(":")[1];
String selection = MediaStore.Images.Media._ID +"=" + id;
//通过Uri和selection获取真实图片路径
imagePath = getImagePath(MediaStore.Images.Media.EXTERNAL_CONTENT_URI,selection);
}else if ("com.android.providers.downloads.documents".
equals(uri.getAuthority())){
Uri contentUri = ContentUris.withAppendedId(
Uri.parse("content://downloads/public_downloads"),Long.valueOf(docId));
imagePath = getImagePath(contentUri,null);
}
}else if("content".equalsIgnoreCase(uri.getScheme())){
//如果是content类型的Uri,则使用普通方式处理
imagePath = getImagePath(uri,null);
}else if ("file".equalsIgnoreCase(uri.getScheme())){
//如果是file类型的Uri,直接获取图片路径即可.
imagePath = uri.getPath();
}
//根据图片路径显示图片
displayImage(imagePath);
}
// 07_2 4.4以下系统使用这个方法处理图片
private void handleImageBeforeKitKat(Intent data) {
Uri uri = data.getData();
String imagePath = getImagePath(uri,null);
displayImage(imagePath);
}
//通过Uri和selection获取真实图片路径
private String getImagePath(Uri externalContentUri, String selection) {
String path = null;
Cursor cursor = getContentResolver().query(externalContentUri,null,selection,null,null);
if (cursor !=null){
if (cursor.moveToFirst()){
path = cursor.getString(cursor.getColumnIndex(MediaStore.Images.Media.DATA));
}
}
cursor.close();
return path;
}
//根据图片路径显示图片
private void displayImage(String imagePath) {
if (imagePath != null){
Bitmap bitmap = BitmapFactory.decodeFile(imagePath);
picture.setImageBitmap(bitmap);
}else{
Toast.makeText(this,"failed to get image",
Toast.LENGTH_SHORT).show();
}
}
04 播放音频
MediaPlayer类中常用的控制方法
方法名 | 功能描述 |
---|---|
setDataSource() | 设置要播放的音频文件的位置 |
prepare() | 在开始播放之前调用,以完成准备工作 |
start() | 开始或继续播放音频 |
pause() | 暂停播放音频 |
reset() | 将MediaPlayer对象重置到刚刚创建的状态 |
seekTo() | 从指定的位置开始播放音频 |
stop() | 停止播放音频。调用后的MediaPlayer对象无法再播放音频 |
release() | 释放与MediaPlayer对象相关的资源 |
isPlaying() | 判断当前MediaPlayer是否正在播放音频 |
getDuration() | 获取载入的音频文件的时长 |
//在assets目录下放置MP3音频
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
private MediaPlayer mediaPlayer = new MediaPlayer();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button button1 = (Button) findViewById(R.id.button1);
Button button2 = (Button) findViewById(R.id.button2);
Button button3 = (Button) findViewById(R.id.button3);
button1.setOnClickListener(this);
button2.setOnClickListener(this);
button3.setOnClickListener(this);
VideoView videoView = (VideoView) findViewById(R.id.videoView);
AssetManager assetManager = this.getAssets();
try {
AssetFileDescriptor assetFileDescriptor = assetManager.openFd("music.mp3");
mediaPlayer.setDataSource(assetFileDescriptor.getFileDescriptor(),assetFileDescriptor.getStartOffset(),assetFileDescriptor.getLength());
mediaPlayer.prepare();
} catch (IOException e) {
e.printStackTrace();
}
}
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.button1:
//播放
if (!mediaPlayer.isPlaying()){
mediaPlayer.start();
}
break;
case R.id.button2:
//暂停
if (mediaPlayer.isPlaying()){
mediaPlayer.pause();
}
break;
case R.id.button3:
//重新播放
if (mediaPlayer.isPlaying()){
mediaPlayer.reset();
}
break;
default:
break;
}
}
}
05 播放视频
和播放音频一样.做出如下变化
在res文件下建立raw目录放置视频
VideoView videoView = (VideoView) findViewById(R.id.videoView);
Uri uri = Uri.parse("android.resource://" + getPackageName() + "/" + R.raw.music;)
videoView.setVideoURI(uri);