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

企业邮箱大全号码大全长沙百度网站推广优化

企业邮箱大全号码大全,长沙百度网站推广优化,建各企业网站多少钱,iis 建设网站文档生成时间:2023-07-02 16:02:42 (老久之前的不成熟版本) 基本信息 项目信息文件名easy_clock.gdGodot版本4.0.3-stable (official)is_tooltrueextendControlclass_nameEasyClock所在项目名称组件库文件路径res://easy_clock.gd绝对路径E:/Godot4.x - 软件/音频…

文档生成时间:2023-07-02 16:02:42
(老久之前的不成熟版本)

基本信息

项目信息
文件名easy_clock.gd
Godot版本4.0.3-stable (official)
is_tooltrue
extendControl
class_nameEasyClock
所在项目名称组件库
文件路径res://easy_clock.gd
绝对路径E:/Godot4.x - 软件/音频可视化/easy_clock.gd
作者巽星石

概述

一个纯粹基于_draw简易参数化时钟组件。可以自由缩放,目前支持各种颜色、字体、字号修改以及开启或关闭绘制数字、刻度。

基于_process刷新有点浪费,后期可能基于Timer进行修改。

变量

变量类型描述
draw_centerbool是否绘制中心
draw_numsbool是否绘制数字
draw_scalesbool是否绘制刻度线
bk_colorColor表盘 - 背景颜色
h_colorColor时针 - 颜色
m_colorColor分针 - 颜色
s_colorColor秒针 - 颜色
center_colorColor中心点 - 颜色
h_widthint时针 - 宽度
m_widthint分针 - 宽度
s_widthint秒针 - 宽度
nums_colorColor数字 - 颜色
font_sizeint数字 - 字体大小
fontSystemFont数字 - 字体

源代码

以下是完整源代码:

# ========================================================
# 名称:EasyClock
# 类型:Control扩展节点
# 简介:利用_draw实现的参数化的指针型钟表组件
# 作者:巽星石
# Godot版本:4.0.3-stable (official)
# 创建时间:2023-07-02 14:36:14
# 最后修改时间:20237216:22:40
# ========================================================
@tool
extends Control
class_name EasyClock
# =================================== 参数 ===================================
# 功能开关
@export_group("switch")
## 是否绘制中心
@export var draw_center:bool = false:set(val):draw_center = valqueue_redraw()
## 是否绘制数字
@export var draw_nums:bool = false:set(val):draw_nums = valqueue_redraw()
## 是否绘制刻度
@export var draw_scales:bool = false:set(val):draw_scales = valqueue_redraw()
# 颜色
@export_group("Color")
## 表盘 - 颜色
@export var bk_color:Color = Color("#ccc"):set(val):bk_color = valqueue_redraw()
## 时针 - 颜色
@export var h_color:Color = Color("#444"):set(val):h_color = valqueue_redraw()
## 分针 - 颜色
@export var m_color:Color = Color("#444"):set(val):m_color = valqueue_redraw()
## 秒针 - 颜色
@export var s_color:Color = Color("#444"):set(val):s_color = valqueue_redraw()
## 中心点 - 颜色
@export var center_color:Color = Color("#ccc"):set(val):center_color = valqueue_redraw()
# 宽度
@export_group("Width")
## 时针 - 宽度
@export var h_width:int = 10:set(val):h_width = valqueue_redraw()
## 分针 - 宽度
@export var m_width:int = 5:set(val):m_width = valqueue_redraw()
## 秒针 - 宽度
@export var s_width:int = 3:set(val):s_width = valqueue_redraw()
@export_group("nums")
## 表盘数字 - 颜色
@export var nums_color:Color = Color("#ccc"):set(val):nums_color = valqueue_redraw()
## 默认字体大小
@export var font_size = 14:set(val):font_size = valqueue_redraw()
## 默认字体	
@export var font:SystemFont:set(val):font = valqueue_redraw()# =================================== 动态计算参数 ===================================
var center = Vector2(100,100) # 表盘中心
var r = 80 # 表盘半径
var h_r = 60 # 时针长度
var m_r = 50 # 分针长度
var s_r = 40 # 秒针长度func _ready():resized.connect(func():calc())calc()queue_redraw()# 重新计算
func calc():center = get_global_rect().get_center()r = get_global_rect().size.y/2h_r = r * 0.82m_r = r * 0.85s_r = r * 0.9func _process(delta):queue_redraw()func _draw():# 获取当前时间信息var dict = Time.get_datetime_dict_from_system()# 绘制表盘draw_circle(center,r,bk_color)draw_circle(center,r * 0.8,bk_color.darkened(0.2))draw_circle(center,r * 0.8 - 10,bk_color.darkened(0.15))# 绘制日期var date := "%d.%d.%d" % [dict["year"],dict["month"],dict["day"]]draw_string(font, Vector2.DOWN * r * 0.4 + center - Vector2(font_size * 2,-font_size/2),date,HORIZONTAL_ALIGNMENT_CENTER,-1,font_size * 1.5,nums_color)# 绘制时间# 绘制数字if draw_nums:for i in range(1,13):var f_size = font_size if i % 3 != 0 else font_size * 2draw_string(font, (Vector2.UP * (r - f_size/1.25)).rotated((2* PI /12) * i) + center - Vector2(f_size/3,-f_size/2),str(i),HORIZONTAL_ALIGNMENT_CENTER,-1,f_size,nums_color)# 绘制draw_line(center,(Vector2.UP * h_r).rotated((2* PI /12) * dict["hour"]) + center,h_color,h_width)draw_line(center,(Vector2.UP * m_r).rotated((2* PI /60) * dict["minute"]) + center,m_color,m_width)draw_line(center,(Vector2.UP * s_r).rotated((2* PI /60) * dict["second"]) + center,s_color,s_width)# 绘制中心if draw_center:draw_circle(center,r * 0.1,center_color)draw_circle(center,r * 0.1 - 8,center_color.darkened(0.2))draw_circle(center,5,center_color.darkened(0.3))# 绘制刻度线if draw_scales:for i in range(60):draw_line((Vector2.UP * r * 0.9).rotated((2* PI /60) * i) + center ,(Vector2.UP * r * 0.95).rotated((2* PI /60) * i) + center,s_color,1)
http://www.dtcms.com/wzjs/38948.html

相关文章:

  • 如何查询企业有没有做网站谷歌seo站内优化
  • 做彩平的网站拓客软件排行榜
  • 建设传奇私服发布网站东莞做网站最好的是哪家
  • 北京app开发公司排名云南网络推广seo代理公司
  • 从零开始做网站电商推广平台有哪些
  • 电子产品网站建设网络推广求职招聘交流群
  • 互联网如何做推广seo外链推广工具下载
  • 扁平化网站设计方案口碑营销的经典案例
  • 甘肃省两学一做专题网站郑州网站优化渠道
  • 考试类网站如何做站长工具高清吗
  • 小程序开发厂家站长工具 seo综合查询
  • 做网站前途如何云南今日头条新闻
  • 武汉制作网站公司哪家好上海百度推广优化
  • 基于php网站建设优化设计七年级下册语文答案
  • ui设计公司排行榜免费seo营销优化软件下载
  • 源码资源下载站传媒公司
  • 厦门网站建设培训班网页设计与制作学什么
  • 湖南网站建设 系统在线营销推广
  • 北京网站建设策划建设seo 培训教程
  • 卧龙区网站建设哪家好seo网页优化工具
  • 做国外营销型网站设计sem分析是什么
  • 青岛做网站建设定制廊坊seo排名收费
  • 网站建设富库2022近期重大新闻事件10条
  • 无锡高端网站建设开发竞价托管外包代运营
  • 做翻译兼职的网站亚马逊免费的关键词工具
  • 重庆建设网站的公司简介百度开户代理商
  • 同ip怎么做不同的网站肇庆网站快速排名优化
  • 宁波外贸网站建设公司网站建设方案
  • 青岛建网站选青岛博采网络seo优化网站百度技术
  • 精湛的网站设计西安关键词排名首页