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

鸿蒙Harmony-圆形绘制组件Circle使用详解

目录

一,定义

 二,使用案例

三,作为其他组件背景使用

一,定义

Circle是鸿蒙提供的圆形绘制组件,利用该组件可以绘制圆形背景,圆形图案等

官方提供的参数和属性:

参数:

参数名参数类型必填参数描述
widthstring | number宽度。
默认值:0
说明:
异常值按照默认值处理。
heightstring | number高度。
默认值:0
说明:
异常值按照默认值处理。

属性:

名称类型默认值描述
fillResourceColorColor.Black设置填充区域颜色。
从API version 9开始,该接口支持在ArkTS卡片中使用。
说明:
异常值按照默认值处理。
fillOpacitynumber | string | Resource1设置填充区域透明度。
取值范围是[0.0, 1.0],若给定值小于0.0,则取值为0.0;若给定值大于1.0,则取值为1.0,其余异常值按1.0处理。
从API version 9开始,该接口支持在ArkTS卡片中使用。
strokeResourceColor-设置边框颜色,不设置时,默认没有边框。
从API version 9开始,该接口支持在ArkTS卡片中使用。
说明:
异常值不会绘制边框。
strokeDashArrayArray<any>[]设置边框间隙。
从API version 9开始,该接口支持在ArkTS卡片中使用。
说明:
异常值按照默认值处理。
strokeDashOffsetnumber | string0边框绘制起点的偏移量。
从API version 9开始,该接口支持在ArkTS卡片中使用。
说明:
异常值按照默认值处理。
strokeLineCapLineCapStyleLineCapStyle.Butt设置边框端点绘制样式。
从API version 9开始,该接口支持在ArkTS卡片中使用。
strokeLineJoinLineJoinStyleLineJoinStyle.Miter设置边框拐角绘制样式。
从API version 9开始,该接口支持在ArkTS卡片中使用。
说明:
Circle组件无法形成拐角,该属性设置无效。
strokeMiterLimitnumber | string4设置斜接长度与边框宽度比值的极限值。
从API version 9开始,该接口支持在ArkTS卡片中使用。
说明:
Circle组件无法设置尖角图形,该属性设置无效。
strokeOpacitynumber | string | Resource1设置边框透明度。
默认值:1
从API version 9开始,该接口支持在ArkTS卡片中使用。
说明:
该属性的取值范围是[0.0, 1.0],若给定值小于0.0,则取值为0.0;若给定值大于1.0,则取值为1.0,其余异常值按1.0处理 。
strokeWidthLength1设置边框宽度。
从API version 9开始,该接口支持在ArkTS卡片中使用。
说明:
该属性若为string类型, 暂不支持百分比,百分比按照1px处理。
antiAliasbooleantrue是否开启抗锯齿效果。
从API version 9开始,该接口支持在ArkTS卡片中使用。

 二,使用案例

绘制基本圆形:

@Entry
@Component
struct Index {

  build() {
      Stack({alignContent: Alignment.Center}) {
        Circle({width: 60, height: 60})
          .fill("#ff00ff")
      }
      .width("100%")
      .height("100%")

  }
}

效果如下: 

添加圆形边框并且设置边框宽度:

@Entry
@Component
struct Index {
  build() {
      Stack({alignContent: Alignment.Center}) {
      
        Circle({width: 100, height: 100})
          .fill("#ff00ff")
          .stroke("#000000")
          .strokeWidth(3)
      }
      .width("100%")
      .height("100%")

  }
}

效果如下: 

 

 设置边框为虚线:

@Entry
@Component
struct Index {

  build() {
      Stack({alignContent: Alignment.Center}) {
       
        Circle({width: 100, height: 100})//设置圆形直径
          .fill("#ff00ff")//设置填充颜色
          .stroke("#000000")//设置边框颜色
          .strokeWidth(3)//设置边框宽度
          .strokeDashArray([1,2])//设置边框虚线
      }
      .width("100%")
      .height("100%")

  }
}

三,作为其他组件背景使用

在安卓中,可以自定义drawable-xml来作为其他组件的背景,在鸿蒙中,可以将Circle作为其他组件的背景使用。

首先自定义Builder:

@Builder bg() {
    Circle({width: "100%", height: "100%"})
      .fill("#ff00ff")
      .stroke("#000000")
      .strokeWidth(3)
      .strokeDashArray([1,2])
  }

然后在组件中使用:

@Entry
@Component
struct Index {

  @Builder bg() {
    Circle({width: "100%", height: "100%"})
      .fill("#ff00ff")
      .stroke("#000000")
      .strokeWidth(3)
      .strokeDashArray([1,2])
  }



  build() {
      Stack({alignContent: Alignment.Center}) {
        Image($r('app.media.pic_bed_nurse_in'))
          .width(60)
          .height(60)
          .background(this.bg())//使用背景
      }
      .width("100%")
      .height("100%")

  }
}

 效果如下:

 

 


http://www.kler.cn/a/379273.html

相关文章:

  • ArcGIS005:ArcMap常用操作101-150例动图演示
  • RabbitMQ的原理和集成使用
  • 2024年一带一路金砖技能大赛之大数据容器云开发
  • Java实现动态切换ubuntu壁纸功能
  • 【MySQL】 穿透学习数据库理论与知识剖析
  • 保研考研机试攻略:python笔记(2)
  • 基于python的机器学习(一)—— 基础知识(Scikit-learn安装)
  • JVM 类加载器
  • 单调栈--- 分奖金
  • 开源呼叫中心系统 FreeIPCC:WebRTC 详解
  • 贪心算法习题其二【力扣】【算法学习day.18】
  • dns服务部署 作业
  • Docker:网络 Network
  • 探索Python编程:从入门到实践的全面指南
  • 海康威视监控rtsp播放
  • ubantu lnmp
  • 【Android】Activity组件通信
  • 002-Kotlin界面开发之Kotlin旋风之旅
  • Jmeter5.X性能测试
  • 【机器学习】 16. 降维:PCA-主成分分析 Principle Component Analysis
  • Docker部署Portainer CE结合内网穿透实现容器的可视化管理与远程访问
  • Docker配置国内源加速
  • chrome 安装vuejs
  • CocoaPods安装步骤详解 - 2024
  • 封装ES高亮Yxh-Es
  • auxm 注册多个router参数时报错