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

什么网站可以做美食交换友情链接的方法

什么网站可以做美食,交换友情链接的方法,个人操作做网站排名,宜昌疫情最新消息西陵区这一节主要了解一下Compose中Brush,在Jetpack Compose里,Brush是一个重要的 API,它用于定义填充图形的颜色渐变或图案,能够为界面元素添加丰富的视觉效果。简单总结如下: 1 常见场景 填充形状(圆形、矩形等) 创建渐变…

        这一节主要了解一下Compose中Brush,在Jetpack Compose里,Brush是一个重要的 API,它用于定义填充图形的颜色渐变或图案,能够为界面元素添加丰富的视觉效果。简单总结如下:

1 常见场景
填充形状(圆形、矩形等)
创建渐变效果
实现纹理或图案
组合多个 Brush

2. 常用 Brush 类型

2.1 纯色填充(SolidColor)
// 直接使用Color作为Brush
drawCircle(color = Color.Red)
// 或显式创建SolidColor Brush
val brush = SolidColor(Color.Blue)
drawRect(brush = brush)2.2 线性渐变(LinearGradientBrush)
val brush = LinearGradientBrush(colors = listOf(Color.Red, Color.Blue),start = Offset(0f, 0f), end = Offset(size.width, size.height)  
)
drawRect(brush = brush)2.3 径向渐变(RadialGradientBrush)
val brush = RadialGradientBrush(colors = listOf(Color.Yellow, Color.Transparent),center = Offset(size.width / 2, size.height / 2), radius = size.minDimension / 2  // 半径
)
drawCircle(brush = brush, radius = size.minDimension / 2)2.4 扫描渐变(SweepGradientBrush)
val brush = SweepGradientBrush(colors = listOf(Color.Red, Color.Green, Color.Blue),center = Offset(size.width / 2, size.height / 2) 
)
drawCircle(brush = brush, radius = size.minDimension / 2)2.5 图像 Brush(ImageBrush)
val imageBitmap = painterResource(id = R.drawable.example).asImageBitmap()
val brush = ImageBrush(image = imageBitmap,contentScale = ContentScale.Crop
)
drawRect(brush = brush)

栗子:

import androidx.compose.animation.core.Animatable
import androidx.compose.animation.core.FastOutSlowInEasing
import androidx.compose.animation.core.infiniteRepeatable
import androidx.compose.animation.core.tween
import androidx.compose.foundation.background
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.size
import androidx.compose.runtime.Composable
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.runtime.remember
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Brush
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import kotlinx.coroutines.launch@Composable
fun GradientExample() {val gradientOffset = remember { Animatable(0f) }LaunchedEffect(Unit) {launch {gradientOffset.animateTo(targetValue = 100f,animationSpec = infiniteRepeatable(animation = tween(durationMillis = 2000,easing = FastOutSlowInEasing)))}}val dynamicGradient = Brush.linearGradient(colors = listOf(Color.Red, Color.Yellow),start = androidx.compose.ui.geometry.Offset(0f, 0f),end = androidx.compose.ui.geometry.Offset(gradientOffset.value, gradientOffset.value))Box(modifier = Modifier.size(100.dp).background(brush = dynamicGradient))
}
import androidx.compose.animation.core.*
import androidx.compose.foundation.Canvas
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.runtime.*
import androidx.compose.ui.Modifier
import androidx.compose.ui.geometry.Offset
import androidx.compose.ui.graphics.Brush
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.tooling.preview.Preview
import kotlin.math.cos
import kotlin.math.sin@Composable
fun RainbowGradient() {val angle by animateFloatAsState(targetValue = 360f,animationSpec = infiniteRepeatable(tween(5000, easing = LinearEasing)))val colors = listOf(Color(0xFFFF0000), // 红Color(0xFFFF7F00), // 橙Color(0xFFFFFF00), // 黄Color(0xFF00FF00), // 绿Color(0xFF0000FF), // 蓝Color(0xFF4B0082), // 靛Color(0xFF9400D3)  // 紫)Canvas(modifier = Modifier.fillMaxSize()) {val radians = angle * (Math.PI / 180).toFloat()val width = size.widthval height = size.heightval start = Offset(x = width / 2 + width / 2 * cos(radians),y = height / 2 + height / 2 * sin(radians))val end = Offset(x = width / 2 - width / 2 * cos(radians),y = height / 2 - height / 2 * sin(radians))drawRect(brush = Brush.linearGradient(colors = colors,start = start,end = end,tileMode = androidx.compose.ui.graphics.TileMode.Mirror))}
}

注意:
1 避免重复创建 Brush 实例:每次重组都创建新的Brush会导致不必要的内存分配和GC压力。使用remember缓存 Brush:

val gradientBrush = remember {LinearGradientBrush(colors = listOf(Color.Red, Color.Blue),start = Offset.Zero,end = Offset(size.width, size.height))
}

2 优先使用内置Brush工厂方法直接调用Brush.linearGradient()等方法,避免手动创建子类:

val brush = Brush.linearGradient(colors = listOf(...))// 不推荐
val brush = LinearGradientBrush(...)

3 对静态内容使用drawWithCache,缓存复杂Brush计算结果,避免重复绘制:

Modifier.drawWithCache {val cachedBrush = createComplexBrush()onDraw { drawRect(brush = cachedBrush) }
}

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

相关文章:

  • 北京网站建设 专业10年兰州seo公司
  • 怎么做网站的域名解析免费发布产品信息的网站
  • 重庆网站建设流程广告策划公司
  • 企业建站系统平台惠州抖音seo策划
  • 百度小程序wordpress网站内容seo
  • 做网站和做app哪个成本高郑州seo关键词优化公司
  • 西部建设网站免费舆情网站
  • 什么网站可以做问卷百度软件下载
  • 昆明云南微网站建设外贸谷歌seo
  • 易签到网站开发设计百度问答seo
  • 服务器迁移对做网站的影响哪里有网络推广
  • 垂直网站需要多少钱佛山优化网站关键词
  • 产品开发流程8个步骤案例seo关键词排名优
  • 会员中心网站模板友情网站
  • 商丘网站建设和制作目前最火的自媒体平台
  • 长沙建设品牌网站2345网址导航设置
  • 网站开发笔记本网站推广优化怎么做最好
  • 网站开发合同范本seo排名优化软件免费
  • 优化一个网站可以做多少关键词线下推广的渠道和方法
  • 江苏省工程建设招标网站商务软文写作
  • 个人网站建设如何赚钱百度收录技巧
  • 网站首页新增悬浮小窗怎么做一般网站推广要多少钱
  • 做装饰画的行业网站百度推广怎么联系
  • 视频网站怎么做压力测试上海谷歌优化
  • 成都精品网站建设如何自己制作一个网站
  • 手机wordpress怎么保存图片青岛网站优化公司哪家好
  • 牡丹江网站制作网站seo优化服务商
  • godaddy服务器做网站关键词排名优化教程
  • 小的电商网站外链代发平台
  • 西安有几家做网站淘宝运营培训机构