godot4自定义按钮,适配boxcontainer中放置

本文介绍了如何在godot4中创建自定义按钮,并使其能够正确适应BoxContainer布局。通过提供的代码示例,展示了在godot4游戏引擎中实现这一功能的详细步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

godot4自定义按钮,适配boxcontainer中放置

实现代码如下:

extends Button
class_name CustomButton

@export var texture:Texture
@export var texture_image_count:int
@export var reload:bool = true :
	set(value):
		reload = value
		_setTexture()
	get:
		return reload
	
	
func _ready():
	_setTexture()


func _process(_delta):
	if(reload):
		_setTexture()

func _setTexture():
	if texture == null:
		return
	add_theme_stylebox_override("normal", _getOneImageInTexture(0))
	if texture_image_count >= 3:
		add_theme_stylebox_override("pressed", _getOneImageInTexture(1))
		add_theme_stylebox_override("hover", _getOneImageInTexture(2))
	else:
		add_theme_stylebox_override("pressed", StyleBoxEmpty.new())
		add_theme_stylebox_override("hover", StyleBoxEmpty.new())	
	
	if texture_image_count == 4:
		add_theme_stylebox_override("disabled", _getOneImageInTexture(3))
	else:
		add_theme_stylebox_override("disabled", StyleBoxEmpty.new())

	add_theme_stylebox_override("focus", StyleBoxEmpty.new())
	
	var width = texture.get_width() / texture_image_count	
	var height = texture.get_height()	
	size = Vector2(width, height)
	custom_minimum_size = Vector2(width, height)
		
func _getOneImageInTexture(number):
	var width = texture.get_width() / texture_image_count
	var height = texture.get_height()
	var style_box_texture = StyleBoxTexture.new()
	style_box_texture.texture = texture;
	var x = number * width
	style_box_texture.region_rect = Rect2(x, 0, width, height)
	return style_box_texture

界面添加自定义按钮:
在这里插入图片描述
运行效果:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值