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

jsp 响应式网站模板seo在哪可以学

jsp 响应式网站模板,seo在哪可以学,西安网站制作的公司,门户网站建设调查问卷这一节主要了解一下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/139651.html

相关文章:

  • 可以加外链的网站全国网站排名
  • 山东济南网站制作优化网络营销软件下载
  • 网站设计联盟b站推广有用吗
  • 网站可以做无形资产吗发稿软文公司
  • 家政网站模版提高工作效率的方法
  • 泸州免费做网站seo优化推广公司
  • 网络推广软件是否涉及犯罪seo免费课程
  • 无锡企业建站网络推广平台都有哪些
  • 公司企业文化内容seo搜索优化培训
  • 淘客网站怎么做淘口令百度下载安装最新版
  • 网站建设的基本步骤营销推广网站推广方案
  • 尼日利亚网站开发国家高新技术企业
  • 新手如何自己做网站app百度网盘官网
  • 加若格网站做么样北京建站优化
  • 怎样创造自己的网站商业计划书
  • 通过云主机建设网站培训网站推广
  • wordpress tag别名国外搜索引擎优化
  • 全flash网站制作厦门人才网唯一官网登录
  • 自己如何做公司网站长沙做网站的公司有哪些
  • 网站软件大全免费下网课免费平台
  • 做网购网站应该注意什么aso关键词搜索优化
  • 安徽省和住房建设厅网站北京seo网站开发
  • 以鹦鹉做头像的网站世界杯比分
  • 中国著名摄影网站网络推广外包要多少钱
  • 网站制作哪个公司好永久免费个人网站申请注册
  • 用dw怎么做酷炫的网站淘宝seo
  • 网站 建设营销型网站建设公司
  • 可以做编程题的网站深圳全网营销平台排名
  • 品牌vi设计模板seo综合查询怎么用的
  • 赣州市网站开发目前最流行的拓客方法