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

长沙个人网站建设淘宝店铺买卖交易平台

长沙个人网站建设,淘宝店铺买卖交易平台,wordpress开户多站点,做百度网站排名软件概述 在设计圆角容器时突发奇想: 将圆角矩形的每个顶点坐标除以对应圆角矩形所在Rect2的size,就得到了顶点对应的UV坐标。然后使用draw_colored_polygon,便可以做到用图片填充圆角矩形的效果。而且这种计算的效果就是图片随着其填充的图像缩…

概述

在设计圆角容器时突发奇想:

  • 将圆角矩形的每个顶点坐标除以对应圆角矩形所在Rect2size,就得到了顶点对应的UV坐标。
  • 然后使用draw_colored_polygon,便可以做到用图片填充圆角矩形的效果。
  • 而且这种计算的效果就是图片随着其填充的图像缩放。
  • 这就类似于是在CanvasItem的绘图函数基础上实现了矢量蒙版效果

基础原理

  • 以上面的五角星为例,它的某个顶点P的UV坐标,应该如下计算:
    顶点P的UV坐标 = 点P的坐标 五角星所在轴对齐包围盒Rect2的size 顶点\text{P}的\text{UV}坐标 = \frac{点\text{P}的坐标}{五角星所在轴对齐包围盒\text{Rect2}的\text{size} } 顶点PUV坐标=五角星所在轴对齐包围盒Rect2sizeP的坐标

  • 前提是:五角星Rect2position(0,0)

  • 这是一种类似自适应的填充形式,图片会随图形的缩放进行缩放,大小和位置始终与图形的包围盒Rect2一致

  • 但是在其他情况下,我们或许需要实现一些复杂的填充效果,比如控制图片进行偏移、旋转、缩放等。这时,上面的UV计算方法就不顶用了。

此时,我们需要考虑图片本身和图形两者是独立的,然后考虑通过它们之间偏移关系去映射坐标位置。

测试

编写了一个基础的UI场景进行测试:

# ==========================================================
# UVtest
# 类型:测试
# 概述:实现基于绘图函数的矢量蒙版效果
# 巽星石
# 创建时间:20251322:50:10
# 最后修改时间:20251323:04:28
# ==========================================================@tool
extends Control@export var texture:Texture2D:set(val):texture = valqueue_redraw()@export var texture_position:=Vector2(): ## 纹理的偏移set(val):texture_position = valqueue_redraw()@export var texture_scale:=Vector2.ONE: ## 纹理缩放值set(val):texture_scale = valqueue_redraw()@export_range(-360,360,1) var texture_rotation_degree:=0: ## 纹理旋转set(val):texture_rotation_degree = valqueue_redraw()@export var fill_color:=Color.WHITE:set(val):fill_color = valqueue_redraw()func _draw() -> void:var rect = get_rect() * get_transform()var pots = star(0,5,rect.size.y/2.0,rect.size.y/3.0,rect.get_center())# 绘制背景if texture:var rot = deg_to_rad(texture_rotation_degree)var image_rect = Rect2(texture_position,texture.get_size() * texture_scale)var r:Vector2 = rect.size/image_rect.size  # 比例var uvs:PackedVector2Arrayfor pot in pots: # 计算UV坐标# 进行旋转变换后的坐标var p = (pot - rect.get_center()).rotated(-rot) + rect.get_center()uvs.append(((p - texture_position)/rect.size) * r)# 绘制圆角矩形draw_colored_polygon(pots,fill_color,uvs,texture)else:draw_polygon(pots,[fill_color])pass# 星形
func star(start_angle:int,edges:int,r:float,r2:float = 0,offset:Vector2 = Vector2.ZERO):if r2 == 0:r2 = r/2.0var points:PackedVector2Array# 外部半径var vec  = Vector2.RIGHT.rotated(deg_to_rad(start_angle)) * r# 内部半径var vec2  = Vector2.RIGHT.rotated(deg_to_rad(start_angle + 180/edges)) * r2for i in range(edges):points.append(vec.rotated(2 * PI/edges * i) + offset)points.append(vec2.rotated(2 * PI/edges * i) + offset)return points

效果:

进行偏移、旋转和缩放后的效果:

提示

本例中暂时没有使用几何图形自身的Rect2,而是采用了测试场景控件元素的Rect2,所以带来的实际效果可能不太相同。

也就是说这还是一个未完成的实验版本。后续敬请期待。

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

相关文章:

  • php一台电脑做网站windows优化大师的作用
  • 家装设计网站怎么做上海互联网公司排名
  • 网站开发的常见编程语言有哪些浏览器看b站
  • 自做网站多少钱百度网页游戏
  • 西安seo服务外包seo如何优化
  • 国外哪个网站可以做外贸比较好有人百度看片吗
  • 网页设计软件排名seo公司是什么意思
  • 做网站设计的提成点是多少软文广告属于什么营销
  • 电商网站后台建设广东今天新闻最新消息
  • 网站建设中可能出现的问题海外社交媒体营销
  • 做品牌特卖的网站代写文章价格表
  • 怎么自己建立一个网站后台seo推广专员工作好做吗
  • 专门做租房的网站重庆森林经典台词截图
  • 内蒙古自治区党风廉政建设网站怎么做推广
  • 怎样自己做卖商品的网站交换链接的作用
  • 自己做的微课上传到哪个网站网络营销师主要做什么
  • 丰城市城乡规划建设局网站怎样推广公司的网站
  • 如何做网站的301重定向链接推广
  • 建设共享经济网站的可行性泉州网站seo公司
  • 自建网站需要哪些技术b2b电商平台有哪些
  • 做房产网站不备案可以吗黄冈免费网站推广平台汇总
  • 离线网站制作活动策划公司
  • 做前端网站考虑兼容分辨率宁波网络推广方式
  • 万网可以花钱做网站吗上海排名优化seo
  • 林州网站建设价格南京今天重大新闻事件
  • 国内做设计的网站有哪些上海网站建设关键词排名
  • 主流的外贸平台深圳网络推广优化
  • 辽宁省住房和城乡建设部网站厦门零基础学seo
  • 有ecs怎么做网站百度云官网
  • 开发房地产需要多少钱石家庄seo网络优化的公司