Android手机拍照或从本地相册选取图片设置头像-高版本适配

GitHub传送门

问题点

Android 7.0

  • 新增FileProvider

参考链接

  • 图片裁减需要的临时权限
intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);

Android 10

  • 只能读取自己APP目录下的文件
Unable to open '/storage/emulated/0/: Permission denied

可以添加requestLegacyExternalStorage解决

<applicationandroid:name=".application.MyApplication"android:requestLegacyExternalStorage="true"
>

Android 11

  • 需要通过MediaStore API 插入file

Android 13

  • 打开相册不再是READ_EXTERNAL_STORAGE而是 READ_MEDIA_IMAGES权限
android.permission.READ_MEDIA_IMAGES

根据Uri获取文件绝对路径,解决Android4.4以上版本Uri转换 兼容Android 10

package portrait.bala.portrait;import android.annotation.SuppressLint;
import android.content.ContentResolver;
import android.content.ContentUris;
import android.content.Context;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.net.Uri;
import android.os.Build;
import android.os.Environment;
import android.os.FileUtils;
import android.provider.DocumentsContract;
import android.provider.MediaStore;
import android.provider.OpenableColumns;
import android.text.TextUtils;import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;import androidx.annotation.RequiresApi;/*** Created by Administrator on 2017/7/12 0012.*/public class FileUtil {/*** 根据Uri获取文件绝对路径,解决Android4.4以上版本Uri转换 兼容Android 10** @param context* @param imageUri*/public static String getFileAbsolutePath(Context context, Uri imageUri) {if (context == null || imageUri == null) {return null;}//4.4以下的版本if (android.os.Build.VERSION.SDK_INT < android.os.Build.VERSION_CODES.KITKAT) {return getRealFilePath(context, imageUri);}//大于4.4,小于10if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.KITKAT && android.os.Build.VERSION.SDK_INT < Build.VERSION_CODES.Q && DocumentsContract.isDocumentUri(context, imageUri)) {if (isExternalStorageDocument(imageUri)) {String docId = DocumentsContract.getDocumentId(imageUri);String[] split = docId.split(":");String type = split[0];if ("primary".equalsIgnoreCase(type)) {return Environment.getExternalStorageDirectory() + "/" + split[1];}} else if (isDownloadsDocument(imageUri)) {String id = DocumentsContract.getDocumentId(imageUri);Uri contentUri = ContentUris.withAppendedId(Uri.parse("content://downloads" +"/public_downloads"), Long.valueOf(id));return getDataColumn(context, contentUri, null, null);} else if (isMediaDocument(imageUri)) {String docId = DocumentsContract.getDocumentId(imageUri);String[] split = docId.split(":");String type = split[0];Uri contentUri = null;if ("image".equals(type)) {contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;} else if ("video".equals(type)) {contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI;} else if ("audio".equals(type)) {contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;}String selection = MediaStore.Images.Media._ID + "=?";String[] selectionArgs = new String[]{split[1]};return getDataColumn(context, contentUri, selection, selectionArgs);}}// MediaStore (and general)  大于等于10if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {return uriToFileApiQ(context, imageUri);} else if ("content".equalsIgnoreCase(imageUri.getScheme())) {// Return the remote addressif (isGooglePhotosUri(imageUri)) {return imageUri.getLastPathSegment();}if (Build.VERSION.SDK_INT >= 24) {return getFilePathFromUri(context, imageUri); //content 类型} else {return getDataColumn(context, imageUri, null, null);}}// Fileelse if ("file".equalsIgnoreCase(imageUri.getScheme())) {return imageUri.getPath();}return null;}private static String getDataColumn(Context context, Uri uri, String selection,String[] selectionArgs) {Cursor cursor = null;String column = MediaStore.Images.Media.DATA;String[] projection = {column};try {cursor = context.getContentResolver().query(uri, projection, selection, selectionArgs, null);if (cursor != null && cursor.moveToFirst()) {int index = cursor.getColumnIndexOrThrow(column);return cursor.getString(index);}}catch (Exception E){E.printStackTrace();}finally {if (cursor != null) {cursor.close();}}return null;}private static String getRealFilePath(final Context context, final Uri uri) {if (null == uri) {return null;}final String scheme = uri.getScheme();String data = null;if (scheme == null) {data = uri.getPath();} else if (ContentResolver.SCHEME_FILE.equals(scheme)) {data = uri.getPath();} else if (ContentResolver.SCHEME_CONTENT.equals(scheme)) {String[] projection = {MediaStore.Images.ImageColumns.DATA};Cursor cursor = context.getContentResolver().query(uri, projection, null, null, null);if (null != cursor) {if (cursor.moveToFirst()) {int index = cursor.getColumnIndex(MediaStore.Images.ImageColumns.DATA);if (index > -1) {data = cursor.getString(index);}}cursor.close();}}return data;}private static String getFilePathFromUri(Context context, Uri uri) {String realFilePath = getRealFilePath(context, uri); //防止获取不到真实的地址,因此这里需要进行判断if (!TextUtils.isEmpty(realFilePath)) {return realFilePath;}File filesDir = context.getApplicationContext().getFilesDir();String fileName = getFileName(uri);if (!TextUtils.isEmpty(fileName)) {File copyFile1 = new File(filesDir + File.separator + fileName);copyFile(context, uri, copyFile1);return copyFile1.getAbsolutePath();}return null;}private static void copyFile(Context context, Uri srcUri, File dstFile) {try {InputStream inputStream = context.getContentResolver().openInputStream(srcUri);if (inputStream == null) {return;}OutputStream outputStream = new FileOutputStream(dstFile);copyStream(inputStream, outputStream);inputStream.close();outputStream.close();} catch (Exception e) {e.printStackTrace();}}private static int copyStream(InputStream input, OutputStream output) {final int BUFFER_SIZE = 1024 * 2;byte[] buffer = new byte[BUFFER_SIZE];BufferedInputStream in = new BufferedInputStream(input, BUFFER_SIZE);BufferedOutputStream out = new BufferedOutputStream(output, BUFFER_SIZE);int count = 0, n = 0;try {while ((n = in.read(buffer, 0, BUFFER_SIZE)) != -1) {out.write(buffer, 0, n);count += n;}out.flush();} catch (Exception e) {} finally {try {out.close();in.close();} catch (Exception e) {}}return count;}private static String getFileName(Uri uri) {if (uri == null) {return null;}String fileName = null;String path = uri.getPath();int cut = path.lastIndexOf('/');if (cut != -1) {fileName = path.substring(cut + 1);}return fileName;}/*** @param uri The Uri to check.* @return Whether the Uri authority is MediaProvider.*/private static boolean isMediaDocument(Uri uri) {return "com.android.providers.media.documents".equals(uri.getAuthority());}/*** @param uri The Uri to check.* @return Whether the Uri authority is ExternalStorageProvider.*/private static boolean isExternalStorageDocument(Uri uri) {return "com.android.externalstorage.documents".equals(uri.getAuthority());}/*** @param uri The Uri to check.* @return Whether the Uri authority is DownloadsProvider.*/private static boolean isDownloadsDocument(Uri uri) {return "com.android.providers.downloads.documents".equals(uri.getAuthority());}/*** @param uri The Uri to check.* @return Whether the Uri authority is Google Photos.*/private static boolean isGooglePhotosUri(Uri uri) {return "com.google.android.apps.photos.content".equals(uri.getAuthority());}/*** Android 10 以上适配** @param context* @param uri* @return*/@RequiresApi(api = Build.VERSION_CODES.Q)private static String uriToFileApiQ(Context context, Uri uri) {File file = null;//android10以上转换if (uri.getScheme().equals(ContentResolver.SCHEME_FILE)) {file = new File(uri.getPath());} else if (uri.getScheme().equals(ContentResolver.SCHEME_CONTENT)) {//把文件复制到沙盒目录ContentResolver contentResolver = context.getContentResolver();Cursor cursor = contentResolver.query(uri, null, null, null, null);if (cursor.moveToFirst()) {@SuppressLint("Range") String displayName =cursor.getString(cursor.getColumnIndex(OpenableColumns.DISPLAY_NAME));try {InputStream is = contentResolver.openInputStream(uri);File file1 =new File(context.getExternalCacheDir().getAbsolutePath() + "/" + System.currentTimeMillis());if (!file1.exists()) {file1.mkdir();}File cache = new File(file1.getPath(), displayName);FileOutputStream fos = new FileOutputStream(cache);FileUtils.copy(is, fos);file = cache;fos.close();is.close();} catch (IOException e) {e.printStackTrace();}}}return file.getAbsolutePath();}/*** 获取目录文件大小** @param dir* @return*/public static long getDirSize(File dir) {if (dir == null) {return 0;}if (!dir.isDirectory()) {return 0;}long dirSize = 0;File[] files = dir.listFiles();for (File file : files) {if (file.isFile()) {dirSize += file.length();} else if (file.isDirectory()) {dirSize += file.length();dirSize += getDirSize(file); // 递归调用继续统计}}return dirSize;}/*** 转换文件大小** @param fileS* @return B/KB/MB/GB*/public static String formatFileSize(long fileS) {java.text.DecimalFormat df = new java.text.DecimalFormat("#.00");String fileSizeString = "";if (fileS < 1024) {fileSizeString = df.format((double) fileS) + "B";} else if (fileS < 1048576) {fileSizeString = df.format((double) fileS / 1024) + "KB";} else if (fileS < 1073741824) {fileSizeString = df.format((double) fileS / 1048576) + "MB";} else {fileSizeString = df.format((double) fileS / 1073741824) + "G";}return fileSizeString;}public static File saveFile(String filePath,String fileName, Bitmap bitmap){ByteArrayOutputStream baos =new ByteArrayOutputStream();bitmap.compress(Bitmap.CompressFormat.JPEG,100,baos);byte[] bytes = baos.toByteArray();try {File file = new File(filePath, fileName);FileOutputStream fos = new FileOutputStream(file);fos.write(bytes);fos.close();return file;} catch (Exception e) {e.printStackTrace();return null;}}
}

完整代码

package portrait.bala.portrait;import android.Manifest;
import android.app.Activity;
import android.content.ContentValues;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;import java.io.File;import androidx.activity.ComponentActivity;
import androidx.activity.result.ActivityResultLauncher;
import androidx.activity.result.contract.ActivityResultContracts;
import androidx.annotation.NonNull;
import androidx.core.app.ActivityCompat;
import androidx.core.content.FileProvider;import static android.os.Environment.DIRECTORY_PICTURES;public class MainActivity extends ComponentActivity {//改变头像的标记位private ImageView headImage = null;private final int PERMISSION_CAMERA = 0;//读和相机权限private final int PERMISSION_READ = 1;//读取权限private final String picPermission = PermissionUtil.getReadImgPermission();private Uri fileUri;private boolean isToCrop = true;private ActivityResultLauncher<Intent> cropLauncher;private ActivityResultLauncher<Intent> takePhotoLauncher;private ActivityResultLauncher<Intent> albumLauncher;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);headImage = (ImageView) findViewById(R.id.imageView);Button buttonLocal = (Button) findViewById(R.id.buttonLocal);buttonLocal.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {checkPicPermission();}});Button buttonCamera = (Button) findViewById(R.id.buttonCamera);buttonCamera.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {checkCameraPermission();//检查是否有权限}});cropLauncher =registerForActivityResult(new ActivityResultContracts.StartActivityForResult(), result -> {if (result.getResultCode() != Activity.RESULT_OK) return;setImageToHeadView(result.getData().getData());});albumLauncher =registerForActivityResult(new ActivityResultContracts.StartActivityForResult(), result -> {if (result.getResultCode() != Activity.RESULT_OK) return;try {if (isToCrop) {cropRawPhoto(result.getData().getData());} else {setImageToHeadView(result.getData().getData());}} catch (Exception e) {e.printStackTrace();}});takePhotoLauncher =registerForActivityResult(new ActivityResultContracts.StartActivityForResult(), result -> {if (result.getResultCode() != Activity.RESULT_OK) return;try {if (isToCrop) {cropRawPhoto(fileUri);} else {setImageToHeadView(fileUri);}} catch (Exception e) {e.printStackTrace();}});}// 从本地相册选取图片作为头像private void choseHeadImageFromGallery() {Intent intentFromGallery = new Intent(Intent.ACTION_PICK, null);intentFromGallery.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, "image/*");
//        startActivityForResult(intentFromGallery, CODE_GALLERY_REQUEST);albumLauncher.launch(intentFromGallery);}// 启动手机相机拍摄照片作为头像private void choseHeadImageFromCameraCapture() {File file = buildTemporaryFile();Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {  //如果是7.0以上,使用FileProvider,否则会报错intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);fileUri = FileProvider.getUriForFile(this,getPackageName() + ".fileProvider", file);intent.putExtra(MediaStore.EXTRA_OUTPUT, fileUri); //设置拍照后图片保存的位置}intent.putExtra("outputFormat", Bitmap.CompressFormat.JPEG.toString()); //设置图片保存的格式takePhotoLauncher.launch(intent);}private void checkCameraPermission() {int result = ActivityCompat.checkSelfPermission(this, Manifest.permission.CAMERA);if (result == PackageManager.PERMISSION_DENIED) {String[] permissions = {Manifest.permission.CAMERA};ActivityCompat.requestPermissions(this, permissions, PERMISSION_CAMERA);} else {choseHeadImageFromCameraCapture();}}private void checkPicPermission() {int permission = ActivityCompat.checkSelfPermission(this, picPermission);if (permission == PackageManager.PERMISSION_DENIED) {String[] permissions = {picPermission};ActivityCompat.requestPermissions(this, permissions, PERMISSION_READ);} else {choseHeadImageFromGallery();}}//权限申请回调@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {super.onRequestPermissionsResult(requestCode, permissions, grantResults);switch (requestCode) {case PERMISSION_CAMERA:if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {choseHeadImageFromCameraCapture();}break;case PERMISSION_READ:if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {choseHeadImageFromGallery();}break;}}/*** 裁剪原始的图片*/public void cropRawPhoto(Uri uri) {Intent intent = new Intent("com.android.camera.action.CROP");intent.putExtra("crop", "true");intent.putExtra("aspectX", 1);  //X方向上的比例intent.putExtra("aspectY", 1);  //Y方向上的比例intent.putExtra("outputX", 500); //裁剪区的宽intent.putExtra("outputY", 500);//裁剪区的高intent.putExtra("scale ", true); //是否保留比例intent.putExtra("return-data", false);intent.putExtra("outputFormat", Bitmap.CompressFormat.JPEG.toString());intent.setDataAndType(uri, "image/*");// 7.0 使用 FileProvider 并赋予临时权限if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);}File temporaryFile = buildTemporaryFile();if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) {createCropImageFile();intent.putExtra(MediaStore.EXTRA_OUTPUT, fileUri);} else {intent.putExtra(MediaStore.EXTRA_OUTPUT, fileUri = Uri.fromFile(temporaryFile));      //设置输出}cropLauncher.launch(intent);}public File buildTemporaryFile() {File file;if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {file = new File(Environment.getExternalStoragePublicDirectory(DIRECTORY_PICTURES),System.currentTimeMillis() + ".jpg");} else {file = new File(getExternalCacheDir(), System.currentTimeMillis() + ".jpg");}return file;}public void createCropImageFile() {try {long currentTimeMillis = System.currentTimeMillis();String fileName = "IMG_" + currentTimeMillis + "_CROP.jpg";File imgFile = new File(Environment.getExternalStoragePublicDirectory(DIRECTORY_PICTURES) + File.separator + fileName);// 通过 MediaStore API 插入file 为了拿到系统裁剪要保存到的uri(因为App没有权限不能访问公共存储空间,需要通过 MediaStore API来操作)ContentValues values = new ContentValues();values.put(MediaStore.Images.Media.DATA, imgFile.getAbsolutePath());values.put(MediaStore.Images.Media.DISPLAY_NAME, fileName);values.put(MediaStore.Images.Media.MIME_TYPE, "image/jpeg");fileUri = getContentResolver().insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, values);} catch (Exception e) {e.printStackTrace();}}/*** 提取保存裁剪之后的图片数据,并设置头像部分的View*/private void setImageToHeadView(Uri uri) {try {Bitmap bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(uri));headImage.setImageBitmap(bitmap);} catch (Exception e) {e.printStackTrace();}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/40393.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

三、Prometheus监控Tidb

1.下载node_exporter https://download.pingcap.org/node_exporter-v1.3.1-linux-amd64.tar.gz将其配置为系统服务&#xff1a; vim /usr/lib/systemd/system/node_exporter.service[Unit] Descriptionnode_exporter Documentationhttps://prometheus.io [Service] ExecStart…

单片机软件架构连载(1)-枚举(enum)

今天跟大家讲一下我在产品开发时&#xff0c;用枚举(enum)的一些骚操作&#xff0c;都是实战经验&#xff0c;不难&#xff0c;但开发经验尚浅的话&#xff0c;不一定能把它灵活应用。 为什么要讲枚举呢&#xff1f; 因为我发现它是一个容易被遗忘&#xff0c;同时又非常重要的…

RK3568驱动指南|第十六篇 SPI-第195章 实践:移植官方mcp2515驱动

瑞芯微RK3568芯片是一款定位中高端的通用型SOC&#xff0c;采用22nm制程工艺&#xff0c;搭载一颗四核Cortex-A55处理器和Mali G52 2EE 图形处理器。RK3568 支持4K 解码和 1080P 编码&#xff0c;支持SATA/PCIE/USB3.0 外围接口。RK3568内置独立NPU&#xff0c;可用于轻量级人工…

顶顶通呼叫中心中间件(mod_cti基于FreeSWITCH)-http话术接口测试流程

文章目录 前言联系我们部署http话术PHP例子Java例子 登录ccadmin-web配置拨号方案创建与注册分机创建分机注册分机 测试 前言 用户一直想体验机器人话术的效果&#xff0c;但却找不到门路。本文提供了配置机器人话术接口的配置流程&#xff0c;供用户体验。用户可以根据本文的…

springboot交流论坛网站-计算机毕业设计源码00304

Springboot交流论坛网站 摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了交流论坛网站的开发全过程。通过分析交流论坛网站管理的不足&#xff0c;创建了一个计算机管理交流论坛网站的方案。文章介绍了交流论坛…

Excel 宏录制与VBA编程 ——VBA编程技巧篇三 (未初始化Range判断、遍历工作表方法、工作表多行重复内容剔除)

未初始化Range的判断 有时候需要对已定义未初始化的range对象做判断 dim curRange as range If curRange Is Nothing Thendebug.print("未初始化的..") End If遍历工作表方法 Chr&#xff08;10&#xff09;&#xff1a;ASCII码中的换行键&#xff0c;相当于vbLF。 …

如何在Android Studio中查看APP客户端日志

测试Android应用时&#xff0c;日志查看是一个至关重要的调试工具&#xff0c;它帮助测试人员快速定位问题。幸运的是&#xff0c;Android Studio为我们提供了一个强大的工具——Logcat&#xff0c;使得查看运行时日志变得直接且简单。本文将引导你如何在Android Studio中使用L…

【鸿蒙学习笔记】@Prop装饰器:父子单向同步

官方文档&#xff1a;Prop装饰器&#xff1a;父子单向同步 [Q&A] Prop装饰器作用 Prop装饰的变量可以和父组件建立单向的同步关系。Prop装饰的变量是可变的&#xff0c;但是变化不会同步回其父组件。 [Q&A] Prop装饰器特点 &#xff11;・Prop装饰器不能在Entry装饰的…

银行批处理包括公共,合同,贷后,评级,押品,业务审批,贸易融资,授信管理,保理,贴现详细的业务逻辑和这些模块之间的相互联系

银行批处理系统是银行业务运作的核心&#xff0c;涵盖了从客户信息管理到风险控制的多个方面。以下是一些常见的银行批处理模块&#xff0c;以及它们的业务逻辑和相互联系&#xff1a; 1. **公共模块**&#xff1a; - 包含银行业务所需的共用数据和工具&#xff0c;如客户信…

MySQL数据库增删改查示例

一、 1、登陆数据库 2、创建数据库zoo 3、修改数据库zoo字符集为gbk 4、选择当前数据库为zoo 5、查看创建数据库zoo信息 6、删除数据库zoo 二、创建俩张表 先创建一个数据库并使用&#xff1a; 创建员工表 创建员工绩效表 三、修改表 1.在员工表的基本上增加一个image系列&a…

从新手到高手:Scala函数式编程完全指南,Scala 访问修饰符(6)

1、Scala 访问修饰符 Scala 访问修饰符基本和Java的一样&#xff0c;分别有&#xff1a;private&#xff0c;protected&#xff0c;public。 如果没有指定访问修饰符&#xff0c;默认情况下&#xff0c;Scala 对象的访问级别都是 public。 Scala 中的 private 限定符&#xff…

设计模型 - 学习笔记

学习参考&#xff1a; https://blog.csdn.net/m0_65346405/article/details/136994128 《系统分析师教程》 《设计模式之禅》 一. 设计模式的5大原则 1. 单一职责原则 一个类应该只有一个变化因子。 就是说&#xff0c;一个类要变化&#xff0c;比如增加功能&#xff0c;那么引…

C语言 | Leetcode C语言题解之第205题同构字符串

题目&#xff1a; 题解&#xff1a; struct HashTable {char key;char val;UT_hash_handle hh; };bool isIsomorphic(char* s, char* t) {struct HashTable* s2t NULL;struct HashTable* t2s NULL;int len strlen(s);for (int i 0; i < len; i) {char x s[i], y t[i]…

盘点一波国际上最具挑战性的11个IT认证,你有几个证书?

在信息技术领域&#xff0c;获得认证不仅是对专业知识和技能的认可&#xff0c;更是提升职业竞争力的重要手段。 随着技术的发展和行业的需求&#xff0c;IT认证的种类越来越多&#xff0c;难度也越来越大。 你可能听说过一些知名的认证&#xff0c;比如思科的CCIE、华为的HCIE…

自闭症儿童:探索症状背后的多彩内心世界

在星启帆自闭症康复中心&#xff0c;我们每天与一群独特而珍贵的孩子相遇——他们&#xff0c;是自闭症谱系障碍的患儿。自闭症&#xff0c;这一复杂的神经发育障碍&#xff0c;以其多样化的症状表现&#xff0c;为每个孩子的生活轨迹绘上了不同的色彩。 自闭症孩子的症状各异…

微信小程序-组件样式隔离

一.isolated isolated是自定义组件.js的options对象字段styleIsolation的默认值&#xff0c;表示自定义组件和组件使用者之间的样式相互独立&#xff0c;互不影响。 写法&#xff1a; options:{//isolated默认值&#xff0c;开启样式隔离&#xff0c;使用者和自定义组件的样式…

go语言并发编程1-Gouroutine

参考文档&#xff1a;www.topgoer.com 使用方法 直接包装成函数&#xff0c;go关键字触发即可 注意事项 1 main方法结束后&#xff0c;main方法内启动的子协程会立即结束&#xff0c;无论是否执行完毕&#xff1b; 启动多个groutine 使用sync包的WaitGroup来控制&#xf…

springboot的非物质文化遗产管理系统-计算机毕业设计源码16087

目录 摘要 1 绪论 1.1 选题背景与意义 1.2国内外研究现状 1.3论文结构与章节安排 2系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1系统开发流程 2.2.2 用户登录流程 2.2.3 系统操作流程 2.2.4 添加信息流程 2.2.5 修改信息流程 2.2.6 删除信息流程 2.3 系统功能…

微信小程序 typescript 开发日历界面

1.界面代码 <view class"o-calendar"><view class"o-calendar-container" ><view class"o-calendar-titlebar"><view class"o-left_arrow" bind:tap"prevMonth">《</view>{{year}}年{{month…

Maven:下载配置教学(2024版 最简)

文章目录 一、Maven下载1.1 下载官网1.2 下载压缩包1.3 解压1.4 创建repo文件夹 二、Maven配置2.1 环境变量2.1.1 新建系统变量2.1.2 添加Path 2.2 阿里云镜像2.3 JDK2.4 本地仓库2.5 conf文件的全部内容2.6 测试安装配置是否成功 三、IDEA中配置Maven3.1 新配置3.2 推荐配置 四…