HarmonyOS中的Image图片样式设置

文章详细介绍了如何在Flutter应用中使用Image组件,包括设置图片的渲染模式(原色或黑白)、调整解码尺寸以降低分辨率、以及应用像素颜色滤镜。展示了通过API如`renderMode`、`sourceSize`和`colorFilter`实现图片效果的技术方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@Entry
@Component
struct ImageSimple {

  build() {
    Column({ space: 10 }) {
      //通过renderMode属性设置图片的渲染模式为原色或黑白
      Row({ space: 50 }) {
        Image($r('app.media.girl'))
          // 设置图片的渲染模式为原色
          .renderMode(ImageRenderMode.Original)
          .width(100)
          .height(100)
          .border({ width: 1 })
            // overlay是通用属性,用于在组件上显示说明文字
          .overlay('Original', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })

        Image($r('app.media.girl'))
          // 设置图片的渲染模式为黑白
          .renderMode(ImageRenderMode.Template)
          .width(100)
          .height(100)
          .border({ width: 1 })
          .overlay('Template', { align: Alignment.Bottom, offset: { x: 0, y: 20 } })
      }
      .margin(20)
      .justifyContent(FlexAlign.Center)

      //通过sourceSize属性设置图片解码尺寸,降低图片的分辨率。
      Row({ space: 50 }) {
        Image($r('app.media.girl'))
          .sourceSize({
            width: 150,
            height:180
          })
          .objectFit(ImageFit.ScaleDown)
          .aspectRatio(1)
          .width('25%')
          .border({ width: 1 })
          .overlay('width:150 height:180', { align: Alignment.Bottom, offset: { x: 0, y: 40 } })

        Image($r('app.media.girl'))
          .sourceSize({
            width: 90,
            height:100
          })
          .objectFit(ImageFit.ScaleDown)
          .width('25%')
          .aspectRatio(1)
          .border({ width: 1 })
          .overlay('width:90 height:100', { align: Alignment.Bottom, offset: { x: 0, y: 40 } })

      }

      //通过colorFilter修改图片的像素颜色,为图片添加滤镜。
      Row({ space: 50 }) {
        Image($r('app.media.girl'))
          .width('25%')
          .margin(10)

        Image($r('app.media.girl'))
          .width('25%')
          .margin(10)
          .colorFilter(
            [1, 1, 0, 0, 0,
              0, 1, 0, 0, 0,
              0, 0, 1, 0, 0,
              0, 0, 0, 1, 0])

      }
      .margin(30)
      .justifyContent(FlexAlign.Center)



    }
    .width('100%')
    .height('100%')
  }
}
1)通过renderMode属性设置图片的渲染模式为原色或黑白
2)通过sourceSize属性设置图片解码尺寸,降低图片的分辨率
3)通过colorFilter修改图片的像素颜色,为图片添加滤镜

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值