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

jsp 响应式网站模板下载长沙百度

jsp 响应式网站模板下载,长沙百度,专业简历制作网站推荐,wordpress模板小程序这一节主要了解一下Compose中的图片选择器,图片选择器是一种允许用户从设备相册或文件系统中选择图片的组件,它简化了媒体文件访问流程,简单总结如下: API: ActivityResultContracts.GetMultipleContents() 用于从系统选择多个媒体文件的契约&#xff0…

        这一节主要了解一下Compose中的图片选择器,图片选择器是一种允许用户从设备相册或文件系统中选择图片的组件,它简化了媒体文件访问流程,简单总结如下:

API:
ActivityResultContracts.GetMultipleContents()
用于从系统选择多个媒体文件的契约(Contract)。它允许用户通过系统文件选择器同时选择多张图片、视频或其他类型的文件,并返回这些文件的Uri列表。
ActivityResultContracts.PickMultipleVisualMedia()
Android13(API 33)引入的专用契约,用于从系统媒体库中多选图片或视频。它提供了更优化的媒体选择体验,自动处理权限请求,并支持按类型过滤。

 

栗子:

 

package com.example.test0121.imagepickerimport android.net.Uri
import android.os.Build
import androidx.activity.compose.rememberLauncherForActivityResult
import androidx.activity.result.PickVisualMediaRequest
import androidx.activity.result.contract.ActivityResultContracts
import androidx.compose.foundation.background
import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.*
import androidx.compose.foundation.shape.CircleShape
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material3.*
import androidx.compose.runtime.*
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.clip
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.layout.ContentScale
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import coil.compose.AsyncImage
import coil.request.ImageRequest
import com.google.accompanist.permissions.ExperimentalPermissionsApi@OptIn(ExperimentalPermissionsApi::class, ExperimentalLayoutApi::class)
@Composable
fun ImagePickerDemo() {val context = LocalContext.currentval maxImages = 6var selectedImages by remember { mutableStateOf<List<Uri>>(emptyList()) }val isAndroid15OrHigher = Build.VERSION.SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKEval mediaPickerLauncher = rememberLauncherForActivityResult(contract = ActivityResultContracts.PickMultipleVisualMedia()) { uris ->selectedImages = uris}val legacyImagePickerLauncher = rememberLauncherForActivityResult(contract = ActivityResultContracts.GetMultipleContents()) { uris ->selectedImages = uris.take(maxImages)}Column(modifier = Modifier.fillMaxSize().padding(16.dp),horizontalAlignment = Alignment.CenterHorizontally) {Text(text = "多图选择器测试",fontSize = 20.sp,fontWeight = FontWeight.Bold,modifier = Modifier.padding(bottom = 16.dp))FlowRow(modifier = Modifier.fillMaxWidth(),horizontalArrangement = Arrangement.spacedBy(8.dp),verticalArrangement = Arrangement.spacedBy(8.dp)) {if (selectedImages.size < maxImages) {Box(modifier = Modifier.size(100.dp).clip(RoundedCornerShape(8.dp)).background(MaterialTheme.colorScheme.surfaceVariant).clickable {if (isAndroid15OrHigher) {mediaPickerLauncher.launch(PickVisualMediaRequest(mediaType = ActivityResultContracts.PickVisualMedia.ImageOnly,))} else {                             legacyImagePickerLauncher.launch("image/*")}},contentAlignment = Alignment.Center) {Column(horizontalAlignment = Alignment.CenterHorizontally) {Icon(painter = painterResource(android.R.drawable.ic_menu_camera),contentDescription = "添加图片",tint = MaterialTheme.colorScheme.onSurfaceVariant,modifier = Modifier.size(30.dp))Text(text = "添加图片",fontSize = 12.sp,color = MaterialTheme.colorScheme.onSurfaceVariant,modifier = Modifier.padding(top = 4.dp))}}}selectedImages.forEachIndexed { index, uri ->Box(modifier = Modifier.size(100.dp)) {AsyncImage(model = ImageRequest.Builder(context).data(uri).crossfade(true).build(),contentDescription = "选择的图片 $index",contentScale = ContentScale.Crop,modifier = Modifier.fillMaxSize().clip(RoundedCornerShape(8.dp)))IconButton(onClick = { selectedImages = selectedImages.filterIndexed { i, _ -> i != index } },modifier = Modifier.size(28.dp).align(Alignment.TopEnd).background(Color.Black.copy(alpha = 0.5F), CircleShape).padding(2.dp)) {Icon(painter = painterResource(android.R.drawable.ic_delete),contentDescription = "删除",tint = Color.White,modifier = Modifier.size(16.dp))}}}}Text(text = "已选择 ${selectedImages.size}/$maxImages 张图片",fontSize = 14.sp,color = MaterialTheme.colorScheme.secondary,modifier = Modifier.padding(top = 12.dp))}
}
清单文件:<uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"tools:ignore="QueryAllPackagesPermission" /> <!-- <uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE" --><!-- tools:ignore="ScopedStorage" /> --><uses-permission android:name="android.permission.READ_MEDIA_IMAGES" /> <uses-permission android:name="android.permission.READ_MEDIA_VISUAL_USER_SELECTED" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

http://www.dtcms.com/wzjs/28840.html

相关文章:

  • 深圳做分销网站的公司浙江网站建设制作
  • 长春市大学生网站建设上海哪家seo公司好
  • 温州通告最新合肥seo排名扣费
  • 网站做政务长春seo招聘
  • 网站防御怎么做微信指数查询
  • 深圳注册公司流程及资料怎样在网上办理网站搜索引擎优化方法
  • 中国市政建设局网站谷歌aso优化
  • 世界500强企业名单2022seo国外推广软件
  • 网站建设功能宁德市自然资源局
  • 微网站促销版什么是软文营销?
  • 泸州中泸集团建设有限公司网站什么是搜索引擎竞价推广
  • 开一家网站建设公司有前景吗网站网页的优化方法
  • 顺德公司做网站北京推广优化公司
  • 外贸网站建设.cover长沙在线网站的目标客户
  • 开发菏泽网站建设网站收录查询站长工具
  • 车公庙做网站建站推广
  • 微信公众号做特效的网站长春网站制作企业
  • 青岛注册公司网站百度广告位
  • 河北省城乡建设厅网站首页竞价代运营公司
  • 西安有那些做网站的公司腾讯3大外包公司
  • 做网站基础教程外链群发
  • 温州做网站哪儿百度托管公司
  • 济南区网站开发成人编程培训机构排名前十
  • 网站建设收费标准流程网站开发建站
  • 湖南品牌网站建设百度外推代发排名
  • 合肥专业做网站建设内容哪里有网站推广优化
  • 龙岩网站报价百度推广登录首页
  • html网站成品下载怎么查看域名是一级还是二级域名
  • 街道口做网站公司怎么做好网络销售
  • 中远建设集团有限公司网站找培训机构的app