[UE4]属性声明(Property Declaration)各個宏的定義及作用

2023-11-06 23:31

本文主要是介绍[UE4]属性声明(Property Declaration)各個宏的定義及作用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

轉載自:https://www.jianshu.com/p/a86d567be8c3

參考:https://blog.csdn.net/claien/article/details/49358697

 

属性声明(Property Declaration)

属性变量使用标准C ++变量语法声明,通过使用UPROPERTY宏来进行属性声明标记。

UPROPERTY([specifier, specifier, ...], [meta(key=value, key=value, ...)])
Type VariableName;

属性修饰符(Property Specifiers)

在声明属性时,声明上可添加修饰符以控制引擎和编辑器针对不属性的展现。

常用

Category

定义属性的分类。

UPROPERTY(Category=CategoryName)
Type VariableName;UPROPERTY(Category="CategoryName|SubCategoryName")
Type VariableName;
UPROPERTY(EditAnywhere, Category = "MyCategory")
int CategoryNum;UPROPERTY(EditAnywhere, Category = "MyCategory|SubCategory")
int SubCategoryNum;

1

 

2

Blueprint~辨析

BlueprintAssignable

仅能用于Multicast代理。
应显示该属性,以供在蓝图中分配。

UPROPERTY(BlueprintAssignable)
Type VariableName;

BlueprintCallable

仅能用于Multicast代理。
应显示该属性,以在蓝图代码中调用。

UPROPERTY(BlueprintCallable)
Type VariableName;

BlueprintReadOnly

这个属性可以通过蓝图读取,但不能修改。
这个操作符与BlueprintReadWrite不兼容。

UPROPERTY(BlueprintReadOnly)
Type VariableName;

BlueprintReadWrite

此属性可以读取或从蓝图写的。
这个操作符与BlueprintReadOnly不兼容。

UPROPERTY(BlueprintReadWrite)
Type VariableName;
[SpecifiersTest.h]
DECLARE_DYNAMIC_MULTICAST_DELEGATE_OneParam(FStringDelegate, FString, testStr);
...
UPROPERTY(BlueprintAssignable, Category = "Blueprint")
FStringDelegate WriteToLogDelegate;
UFUNCTION(BlueprintCallable, Category = "Blueprint")
void TestAssignable();// 还是有点不太懂这种方式实际场景怎么用
UPROPERTY(BlueprintCallable, Category = "Blueprint")
FStringDelegate WriteToLogCall;UPROPERTY(BlueprintReadOnly, Category = "Blueprint")
int OnlyTime;UPROPERTY(BlueprintReadWrite, Category = "Blueprint")
int WriteTime;[SpecifiersTest.cpp]
void ASpecifiersTest::TestAssignable()
{UE_LOG(SpecifiersTest, Log, TEXT("This is AssignableTest"));if (GEngine)GEngine->AddOnScreenDebugMessage(-1, 2.0f, FColor::Red, TEXT("This is AssignableTest!"));
}

1

 

2

event

 

test event

 

play - press w

Edit~辨析

EditAnywhere

表示该属性可从编辑器内的属性窗口编辑,在原型和实例中。

UPROPERTY(EditAnywhere)
Type VariableName;

EditDefaultsOnly

表示该属性可通过属性窗口来编辑,但仅能对原型编辑。

UPROPERTY(EditDefaultsOnly)
Type VariableName;

EditFixedSize

仅限于动态数组,这使得用户不能通过UnrealEd属性窗口来变更数组的长度。

UPROPERTY(EditFixedSize)
Type VariableName;

EditInline

通过此修饰符使得用户可编辑UnrealEd的属性查看器中的变量所引用的对象属性。(仅对对象引用可用,包括对象引用数组)。

UPROPERTY(EditInline)
Type VariableName;
  • EditInline is deprecated.Remove it, or use Instanced instead.

EditInstanceOnly

表示该属性可通过属性窗口来编辑,但仅能对实例而非原型进行编辑。

UPROPERTY(EditInline)
Type VariableName;
UPROPERTY(EditAnywhere, Category = "EditCategory")
int EditAnyNum;UPROPERTY(EditDefaultsOnly, Category = "EditCategory")
int EditDefaultNum;UPROPERTY(EditAnywhere, Category = "EditCategory")
TArray<int32> EditAnyArray;
UPROPERTY(EditAnywhere, EditFixedSize, Category = "EditCategory")
TArray<int32> EditFixedArray;\\ UPROPERTY(EditInline, Category = "EditCategory")
\\ int EditInlineNum;UPROPERTY(EditInstanceOnly, Category = "EditCategory")
int EditInstanceNum;

原型中

 

实例中

Visible~

VisibleAnywhere

表示该属性在属性窗口中可见,但无法被编辑。

UPROPERTY(VisibleAnywhere)
Type VariableName;

VisibleDefaultsOnly

表示该属性仅在原型的属性窗口中可见,且无法被编辑。

UPROPERTY(VisibleDefaultsOnly)
Type VariableName;

VisibleInstanceOnly

表示该属性仅在实例的属性窗口中可见,且无法被编辑。

UPROPERTY(VisibleInstanceOnly)
Type VariableName;
UPROPERTY(VisibleAnywhere, Category = "VisCategory")
int VisAnyNum;UPROPERTY(VisibleDefaultsOnly, Category = "VisCategory")
int VisDefaultNum;UPROPERTY(VisibleInstanceOnly, Category = "VisCategory")
int VisInstanceNum;

原型中

 

实例中

其他

AdvancedDisplay

属性被显示在细节面板的高级下拉框中。

UPROPERTY(EditAnywhere, Category = "Adv")
int AdvNum1;
UPROPERTY(EditAnywhere, AdvancedDisplay, Category = "Adv")
int AdvNum2;

1

2

Const

这个变量是常量,应该导出为常量。
常量特性不会在编辑器修改。

  • 使用的时候报错,不清楚为啥 - Unknown variable specifier 'Const'

Transient

该属性为临时属性;不应被保存,在载入时会被填零。

UPROPERTY(Transient)
Type VariableName;

不懂

  • 一时看不太懂、使用又比较深不常用、需要深入了解的,后续有机会再补充

AssetRegistrySearchable

表明此属性及其值将会为任意将其作为成员变量而包含的资源类示例被自动添加到资源注册中。
不可用于结构体属性或参数。

Config

表示该变量将会成为可配置状态。
当前值可被保存到ini文件中,并且将在创建时被载入;无法在默认属性中被赋值;只读。

DuplicateTransient

表示该变量的值应的任何类型的重复(复制/粘贴,二进制复制等)的过程中被重置为类的默认值。

Export

仅对对象属性(或对象数组)有效。表示当对象被复制(复制/粘贴)或导出到T3D时,被分配给该属性的对象应完全作为子对象区块来导出,而不是仅仅输出对象引用本身。

GlobalConfig

类似于config修饰符,区别是您不能在子类中重载它;无法在默认属性中被赋值; 只读 。

Instanced

仅能用于对象属性。
当此类的实例被创建时,它会被赋予一个默认分配给此变量的对象的独特拷贝;用于对在类默认属性中定义的子对象进行实例化。
类似EditInline和Export修饰符。

Interp

表示该值可由Matinee的浮点或向量属性轨迹来随时间驱动。

Localized

此变量的值将定义本地值;最常用于字符串;只读 。

Native

属性为native:C++代码负责对其序列化并显示给GC。

NoClear

防止该对象引用在编辑器中被设置为None.隐藏编辑器的清除(以及浏览)按钮。

NoExport

仅对native类有效。此变量不应被包含在自动生成的类声明中。

NonTransactional

表示变更为此变量值将不会被包含在编辑器的撤消/重做历史中。

Ref

该值在函数调用后被复制出来。仅在函数参数声明中有效。

Replicated

此变量应通过节点网络进行复制。

ReplicatedUsing

此变量应通过节点网络进行复制,在其接受到 Callback 函数后执行。
使用方法: ReplicatedUsing=FunctionName(函数名称)

RepRetry

仅用于结构体属性。如无法被完全发送,请重试复制此属性(例如,对象引用尚无法通过节点网络来进行序列化)。对于简单引用来说,这是一个默认值,但对结构体来说,由于带宽消耗,很多情况下我们不需要。所以除非此标识被定义,否则其会被禁用。

SaveGame

游戏存档说明一个简单的方法,包括明确的领域为检查点/保存系统在性能水平。您可以设定要保存,然后使用代理存档读/写各个领域的标志。

SerializeText

原生属性应序列化为文本(文本导入,导出文本)。

SimpleDisplay

属性默认情况下,在详细信息面板出现肉眼可见的。

扩展

原型 & 实例

总的来说,我是这么理解的,也不知是否准确:

  • 一个类对应的蓝图类即为原型。
  • 一个类添加至关卡等的对象即为实例。



作者:peony007
链接:https://www.jianshu.com/p/a86d567be8c3
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

这篇关于[UE4]属性声明(Property Declaration)各個宏的定義及作用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/359734

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Spring 中 BeanFactoryPostProcessor 的作用和示例源码分析

《Spring中BeanFactoryPostProcessor的作用和示例源码分析》Spring的BeanFactoryPostProcessor是容器初始化的扩展接口,允许在Bean实例化前... 目录一、概览1. 核心定位2. 核心功能详解3. 关键特性二、Spring 内置的 BeanFactory

Spring组件初始化扩展点BeanPostProcessor的作用详解

《Spring组件初始化扩展点BeanPostProcessor的作用详解》本文通过实战案例和常见应用场景详细介绍了BeanPostProcessor的使用,并强调了其在Spring扩展中的重要性,感... 目录一、概述二、BeanPostProcessor的作用三、核心方法解析1、postProcessB

MyBatis的配置对象Configuration作用及说明

《MyBatis的配置对象Configuration作用及说明》MyBatis的Configuration对象是MyBatis的核心配置对象,它包含了MyBatis运行时所需的几乎所有配置信息,这个对... 目录MyBATis配置对象Configuration作用Configuration 对象的主要作用C

HTML5 data-*自定义数据属性的示例代码

《HTML5data-*自定义数据属性的示例代码》HTML5的自定义数据属性(data-*)提供了一种标准化的方法在HTML元素上存储额外信息,可以通过JavaScript访问、修改和在CSS中使用... 目录引言基本概念使用自定义数据属性1. 在 html 中定义2. 通过 JavaScript 访问3.

CSS模拟 html 的 title 属性(鼠标悬浮显示提示文字效果)

《CSS模拟html的title属性(鼠标悬浮显示提示文字效果)》:本文主要介绍了如何使用CSS模拟HTML的title属性,通过鼠标悬浮显示提示文字效果,通过设置`.tipBox`和`.tipBox.tipContent`的样式,实现了提示内容的隐藏和显示,详细内容请阅读本文,希望能对你有所帮助... 效

MySQL表锁、页面锁和行锁的作用及其优缺点对比分析

《MySQL表锁、页面锁和行锁的作用及其优缺点对比分析》MySQL中的表锁、页面锁和行锁各有特点,适用于不同的场景,表锁锁定整个表,适用于批量操作和MyISAM存储引擎,页面锁锁定数据页,适用于旧版本... 目录1. 表锁(Table Lock)2. 页面锁(Page Lock)3. 行锁(Row Lock