HarmonyOS:形状裁剪(clipShape)

一、简介

可利用clipShape 接口将组件裁剪为所需的形状。调用该接口后,可以保留该形状覆盖的组件部分,同时移除组件的其余部分。裁剪形状本身是不可见的。
说明 不同的形状支持的属性范围不同,路径是一种形状,除此之外还有椭圆、矩形等形状。

路径的形状不支持设置宽度和高度,具体形状支持的属性参考具体形状的文档。

形状中的fill属性对clipShape接口不生效。

二、裁剪圆形

通过设置CircleShape,将图片裁剪为圆形。 效果图

示例代码

c 复制代码
import { CircleShape } from '@kit.ArkUI'

@Entry
@Component
struct TestClipShape {
  @State message: string = 'Hello World';

  build() {
    Column({ space: 20 }) {
      //原图
      Image($r('app.media.mount'))
        .width('100%')

      // 用一个280px直径的圆对图片进行裁剪
      Image($r('app.media.mount'))
        .clipShape(new CircleShape({ width: '280px', height: '280px' }))
        .width('500px').height('280px')

      // 用一个350px直径的圆对图片进行裁剪
      Image($r('app.media.mount'))
        .clipShape(new CircleShape({ width: '350px', height: '350px' }))
        .width('500px').height('370px')
    }
    .height('100%')
    .width('100%')
    .padding({ top: 50 })
  }
}

三、裁剪椭圆形

通过设置EllipseShape,将图片裁剪为椭圆形。 效果图

示例代码

c 复制代码
import { CircleShape, EllipseShape } from '@kit.ArkUI'

@Entry
@Component
struct TestClipShape {
  @State message: string = 'Hello World';

  build() {
    Scroll() {
      Column({ space: 20 }) {
        //原图
        Image($r('app.media.mount'))
          .width('100%')

        Text('通过设置EllipseShape,将图片裁剪为椭圆形').fontSize(16).fontColor(Color.Black)
        Row({ space: 20 }) {
          // 用一个280px直径的圆对图片进行裁剪
          Image($r('app.media.mount'))
            .clipShape(new CircleShape({ width: '280px', height: '280px' }))
            .width('500px').height('280px')

          // 用一个350px直径的圆对图片进行裁剪
          Image($r('app.media.mount'))
            .clipShape(new CircleShape({ width: '350px', height: '350px' }))
            .width('500px').height('370px')
        }

        Text('通过设置EllipseShape,将图片裁剪为椭圆形').fontSize(16).fontColor(Color.Black)
        Row({ space: 20 }) {
          Image($r('app.media.background'))
            .clipShape(new EllipseShape({ width: '280px', height: '200px' }))
            .width('500px').height('400px')

          Image($r('app.media.background'))
            .clipShape(new EllipseShape({ width: '380px', height: '280px' }))
            .width('500px').height('400px')
        }
      }
      .width('100%')
    }
    .height('100%')
    .width('100%')

  }
}

四、裁剪矩形

通过设置RectShape,将图片裁剪为矩形。 效果图

示例代码

c 复制代码
import { CircleShape, EllipseShape, RectShape } from '@kit.ArkUI'

@Entry
@Component
struct TestClipShape {
  @State message: string = 'Hello World';

  build() {
    Scroll() {
      Column({ space: 20 }) {
        //原图
        Image($r('app.media.mount'))
          .width('100%')

        Text('通过设置EllipseShape,将图片裁剪为椭圆形').fontSize(16).fontColor(Color.Black)
        Row({ space: 20 }) {
          // 用一个280px直径的圆对图片进行裁剪
          Image($r('app.media.mount'))
            .clipShape(new CircleShape({ width: '280px', height: '280px' }))
            .width('500px').height('280px')

          // 用一个350px直径的圆对图片进行裁剪
          Image($r('app.media.mount'))
            .clipShape(new CircleShape({ width: '350px', height: '350px' }))
            .width('500px').height('370px')
        }

        Text('通过设置EllipseShape,将图片裁剪为椭圆形').fontSize(16).fontColor(Color.Black)
        Row({ space: 20 }) {
          Image($r('app.media.background'))
            .clipShape(new EllipseShape({ width: '280px', height: '200px' }))
            .width('500px').height('400px')

          Image($r('app.media.background'))
            .clipShape(new EllipseShape({ width: '380px', height: '280px' }))
            .width('500px').height('400px')
        }

        Text('通过设置RectShape,将图片裁剪为矩形').fontSize(16).fontColor(Color.Black)
        Row({ space: 20 }) {
          Image($r('app.media.background'))
            .clipShape(new RectShape({ width: '200px', height: '200px' }))
            .width('500px').height('400px')

          Image($r('app.media.background'))
            .clipShape(new RectShape({ width: '380px', height: '280px' }))
            .width('500px').height('400px')
        }

      }
      .width('100%')
    }
    .height('100%')
    .width('100%')

  }
}

五、裁剪不规则形状

通过设置PathShape,将图片裁剪为不规则形状。 效果图

示例代码

c 复制代码
import { CircleShape, EllipseShape, PathShape, RectShape } from '@kit.ArkUI'

@Entry
@Component
struct TestClipShape {
  @State message: string = 'Hello World';

  build() {
    Scroll() {
      Column({ space: 20 }) {
        //原图
        Image($r('app.media.mount'))
          .width('100%')

        Text('通过设置EllipseShape,将图片裁剪为椭圆形').fontSize(16).fontColor(Color.Black)
        Row({ space: 20 }) {
          // 用一个280px直径的圆对图片进行裁剪
          Image($r('app.media.mount'))
            .clipShape(new CircleShape({ width: '280px', height: '280px' }))
            .width('500px').height('280px')

          // 用一个350px直径的圆对图片进行裁剪
          Image($r('app.media.mount'))
            .clipShape(new CircleShape({ width: '350px', height: '350px' }))
            .width('500px').height('370px')
        }

        Text('通过设置EllipseShape,将图片裁剪为椭圆形').fontSize(16).fontColor(Color.Black)
        Row({ space: 20 }) {
          Image($r('app.media.background'))
            .clipShape(new EllipseShape({ width: '280px', height: '200px' }))
            .width('500px').height('400px')

          Image($r('app.media.background'))
            .clipShape(new EllipseShape({ width: '380px', height: '280px' }))
            .width('500px').height('400px')
        }

        Text('通过设置RectShape,将图片裁剪为矩形').fontSize(16).fontColor(Color.Black)
        Row({ space: 20 }) {
          Image($r('app.media.background'))
            .clipShape(new RectShape({ width: '200px', height: '200px' }))
            .width('500px').height('400px')

          Image($r('app.media.background'))
            .clipShape(new RectShape({ width: '380px', height: '280px' }))
            .width('500px').height('400px')
        }

        Text('通过设置PathShape,将图片裁剪为不规则形状').fontSize(16).fontColor(Color.Black)
        Row() {
          Image($r('app.media.background'))
            .clipShape(new PathShape({ commands: 'M0 0 H400 V200 H0 Z' }))
            .width('500px').height('300px')
        }
        .clip(true)
        .borderRadius(20)

      }
      .width('100%')
    }
    .height('100%')
    .width('100%')

  }
}
相关推荐
前端世界18 分钟前
鸿蒙加密存储实战:KeyStore、AES 与真实业务场景解析
华为·harmonyos
花开彼岸天~24 分钟前
Flutter跨平台开发:Books 在鸿蒙系统上的使用指南
flutter·华为·harmonyos
前端世界1 小时前
HarmonyOS 分布式身份认证详解:设备是如何“互相信任”的?
分布式·华为·harmonyos
爸爸6192 小时前
Flutter跨平台开发:Multiple Flutters 在鸿蒙系统上的使用指南
flutter·华为·harmonyos
花开彼岸天~3 小时前
Flutter跨平台开发:Android View 在鸿蒙系统上的使用指南
android·flutter·harmonyos
盐焗西兰花12 小时前
鸿蒙学习实战之路-ArkTS循环渲染_ForEach使用指南
学习·华为·harmonyos
俩毛豆15 小时前
【鸿蒙生态共建】意图框架的使用-通过小艺调起京东发起搜索《精通HarmonyOS NEXT :鸿蒙App开发入门与项目化实战》读者福利
华为·harmonyos·小艺
Devil枫18 小时前
HarmonyOS 应用草稿箱功能设计方案(安全可靠+轻量化存储)
华为·harmonyos
芒鸽1 天前
windows上使用Lycium 交叉编译移植鸿蒙三方库指南
windows·华为·harmonyos
FrameNotWork1 天前
HarmonyOS 广告 SDK 封装实战:从原生 Ads Kit 到可复用广告组件
华为·harmonyos