百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

鸿蒙开发:使用Rect绘制矩形(鸿蒙系统画图软件)

myzbx 2025-05-08 20:11 10 浏览

前言

本文基于Api13

几何图形的绘制,很多人都能想到使用Canvas,除了Canvas之外,其实还有着很多的实现方式,比如要实现一个简单的矩形,如果是填充方式,我们就可以使用backgroundColor,设置一定宽高即可,如果是轮廓边框模式,我们就可以使用border,我们可以简单列举一下:


实现一个长100,宽100,背景为红色的实心矩形,这种情况下,我们就可以随意使用一个组件来实现:


Column() {

      }.width(100)
      .height(100)
      .backgroundColor(Color.Red)

效果如下:

当然了,你也可以加上一个borderRadius属性,让其变为一个圆形:


Column() {

      }.width(100)
      .height(100)
      .backgroundColor(Color.Red)
      .borderRadius(100)


效果如下:


如果你要实现的不是一个实心的,而是一个空心的,那么我们可以使用border来实现:


Column() {

      }.width(100)
      .height(100)
      .border({ width: 1, color: Color.Red })

可以看到,实心已经变成了空心效果:

以上的案例呢,只能说我们是用背景和边框样式实现的,其实除了以上的实现方式之外,鸿蒙中还给我们提供了很多的几何组件,比如圆形,矩形,三角形等等,目前有7种绘制类型,分别为Circle(圆形)、Ellipse(椭圆形)、Line(直线)、Polyline(折线)、Polygon(多边形)、Path(路径)、Rect(矩形),必须使用Shape组件做为父组件。


矩形Rect

Rect主要用于绘制矩形绘制组件。

我们看下源码,参数如下:


    new (value?: {
        width?: number | string;
        height?: number | string;
        radius?: number | string | Array<any>;
    } | {
        width?: number | string;
        height?: number | string;
        radiusWidth?: number | string;
        radiusHeight?: number | string;
    }): RectAttribute;


width:宽度,取值范围≥0;height: 高度,取值范围≥0;radius:圆角半径,支持分别设置四个角的圆角度数,取值范围≥0;radiusWidth:圆角宽度,取值范围≥0;radiusHeight:圆角高度,取值范围≥0。


除了属性之外,也支持以下的方法:


方法

参数

概述

radiusWidth

number/string

设置圆角的宽度,仅设置宽时宽高一致

radiusHeight

number/string

设置圆角的高度,仅设置高时宽高一致

radius

number /string / Array<string/ number>

设置圆角半径大小,取值范围≥0

fill

ResourceColor

设置填充区域的颜色,异常值按照默认值处理

fillOpacity

number /string/ Resource

设置填充区域透明度。取值范围是[0.0, 1.0],若给定值小于0.0,则取值为0.0;若给定值大于1.0,则取值为1.0,其余异常值按1.0处理

stroke

ResourceColor

设置边框颜色,不设置时,默认没有边框

strokeDashArray

Array<any>

设置边框间隙。取值范围≥0

strokeDashOffset

number/string

设置边框绘制起点的偏移量

strokeLineCap

LineCapStyle

设置边框端点绘制样式

strokeLineJoin

LineJoinStyle

设置边框拐角绘制样式

strokeMiterLimit

number/string

设置斜接长度与边框宽度比值的极限值

strokeOpacity

number/string/Resource

设置边框透明度

strokeWidth

Length

设置边框宽度

antiAlias

boolean

设置是否开启抗锯齿效果


实心矩形

默认情况下,它就是一个实心的矩形,背景颜色为黑色。


Rect().width(100)
      .height(100)


效果如下:

通过fill属性设置填充颜色,通过stroke属性设置边框颜色。


设置背景颜色为粉色:


Rect().width(100)
       .height(100)
      .fill(Color.Pink)

效果如下:

边框矩形


绘制边框需要注意一点,那就是不能仅设置stroke属性,还要设置fillOpacity属性,否则边框是没有效果的,比如,设置边框为1,颜色为粉色的案例如下:


Rect().width(100)
      .height(100)
      .fillOpacity(0)
      .stroke(Color.Pink)
      .strokeWidth(1)


效果如下:

圆角矩形

实现一个圆角效果,可以通过radius属性,比如实现一个,圆角度数为10的矩形:

 Rect()
        .width(100)
        .height(100)
        .fill(Color.Pink)
        .radius(10)

效果如下:

当然了,你也可以实现单独的一个角的度数设置,比如设置左上角为10度。


 Rect()
          .width(100)
          .height(100)
          .fill(Color.Pink)
          .radius([[10,10]])

效果如下:


渐变矩形

渐变色,我们可以直接使用通用属性linearGradient来实现,案例如下:

Rect()
          .width(100)
          .height(100)
          .fillOpacity(0)
          .linearGradient({
            direction: GradientDirection.Right,
            colors: [[Color.Red, 0.0], [Color.Orange, 0.3], [Color.Pink, 1.0]]
          })

效果如下:


相关总结

几何矩形,在实际的开发中,有多种的实现方式,并非一定需要Rect组件,但是,如果有需要用到矩形的场景,建议还是使用Rect组件,因为Rect组件自身携带了很多样式属性,可以满足我们日常的不同的需求。

相关推荐

疯鸟开发者又杀回来了 虐心游戏《旋转直升机2》周四上架

寿司发表于2015-12-1616:34想必有不少玩家都曾被“自虐神作”FlappyBird《疯狂的小鸟》给“虐待”过,而继这款休闲游戏之后,其制作人越南大叔DongNguyen又再度...

暴雪游戏新服务,游戏时间自由转!

宝子们,暴雪游戏服务中心推出了一项超级人性化的新服务!很多像我们这样的玩家,有好多子账号,或者同一身份证下有多个战网账号。有时候就想看看小号,还得充值,真的太亏啦!但是现在不用愁啦,新服务可以在...

Maybe Test |《旋转冲击波》游戏体验

点击“MaybeTest”关注我们,每天都有最火爆的游戏体验报告!《旋转冲击波》游戏体验微信号:MaybeTest旋转冲击波(OneMoreDash)是一款简单的休闲游戏,游戏中的设计可谓简单,虽...

从翻花绳到数字游戏:童年乐趣的变迁与联机时代的到来

在当今这个科技飞速发展的时代,许多曾经简单而纯粹的游戏逐渐被高科技产品所取代。然而,最近一段时间,一段关于女孩们在课间玩翻花绳的视频引发了网友们的热议,大家纷纷感慨:“越来越高级了,小时候我都是用手玩...

旋转横条新游曝光 旋转十字连线唯美画面

GingearStudio是由仅有几个人组成的独立制作团队,而这款休闲游戏OpenBar《旋转横条》便是它们的处女作。该作以简朴的画风为主,搭配模拟水珠气泡流动的游戏背景而打造,令整个游戏都...

Glozzle 旋转解谜攻略大全 旋转注意方可过

Glozzle旋转解谜里面我们需要通过一些办法才能够更为巧妙的结合出我们所需要的图形,究竟接下来我们该如何解决这一切的谜题呢?一起来看下本篇Glozzle旋转解谜攻略大全是如何做到的吧。Glozz...

烧脑解谜游戏《棱镜》上架 几何旋转连线拼凑核心

寿司发表于2016-02-1417:33以简单的图形结合不复杂玩法的几何游戏想必不少玩家都会有所接触,但这款_PRISM《棱镜》却用烧脑的玩法搭配变化多端的几何图形来呈现出不一样的烧脑解谜游戏...

索尼新专利“旋转椅”曝光! 全方位体验VR游戏

集微网消息,近日有玩家就发现了一款由索尼申请的PSVR新专利,能让玩家享受全方位沉浸式VR体验的新设备——“旋转椅”,有了它,玩家就能在VR游戏中旋转跳跃不停歇。从专利示意图给出的备注来看,序号“10...

能旋转的塔防游戏? 睡意侵袭试玩体验

最近优秀的塔防游戏可真是不少,大家现在肯定都在关注着《王国保卫战:起源》何时来到安卓平台,小编也跟大家一样很期待这款神作,在漫长的等待时间里,小编要为大家推荐一款比较另类的塔防游戏,它就是《睡意侵袭》...

Unity2D游戏制作教程 | 8.设置基本输入系统并实现人物移动

我们操作玩家的按键在新版本的unity中是可以更改的,默认是wasd,但是在新版本中可以实现更换按键,我们可以来试一下,通过代码实现玩家在按键的控制下移动。在Unity中如何通过代码控制人物的基本移动...

这是勇敢者的游戏!你不来试一下?

滑雪勇敢者的游戏想要征服长长的雪道先得经历一次次摔倒又一次次站起……你以为我们是来介绍赛事的其实我们是来送欢乐的动动手指和天南地北的网友来场刺激的“雪上疾行”https://pd.xinhua-new...

正惊GIF:智慧改变生活!一个小操作,板车变成自动旋转餐桌?

大家好,这里是正惊游戏,我是你们的正惊小弟。前方高能预警,每周二准时更新的GIF毫无尿点,请君一看……GIF图片较大,手机端请在Wifi情况下查看。工作人员一个月来毫无进展个子矮还是衣服太长不行,我一...

如何手动增加东皇太一魔法球回血频率?顺时针旋转走位是最优选择

东皇太一顺时针旋转走位无非是为了提升一技能魔法球接触敌方单位的频率,以此触发更强大的恢复效果。东皇一技能回血量取决于魔法球的触碰次数东皇的一技能最多可创造同时存在的三颗魔法球,辅以被动的回血特性,命中...

是躺是站由你决定 休闲游戏《翻转河马》考验你瞬间反应

寿司发表于2015-12-2417:55因为可爱和滑稽的形象,所以部分动物形象都一直被众多游戏制作商当作吸引女性玩家的重要元素,而在这款由游戏制作商Ketchapp发布的休闲游戏FlipHi...

Taito公布迷你街机 配有可旋转屏幕和轨迹球手柄

近年来诸多游戏厂商均在复刻复古游戏机,而Taito今天也成为了其中之一。Taito作为游戏行业老牌游戏厂商,旗下有《太空侵略者》、《泡泡龙》等经典街机游戏。今天他们公布了全新的迷你街机:EgretI...