1. 上面初始化函数必须加Super::否则Tick函数不执行:或者其他莫名错误!!!
data:image/s3,"s3://crabby-images/dddfb/dddfba340a951af774fe11b4b3f3a8555b3eafa4" alt=""
2. UI中获取鼠标键盘输入键,必须加以下代码 然后重写NativeOnPreviewKeyDown函数,否则重写不生效!!!
data:image/s3,"s3://crabby-images/8f401/8f401368f8332f02ee0ba535ff7d100f3326738c" alt=""
3. Actor类添加tick函数必须在构造方法里面添加以下代码才生效
data:image/s3,"s3://crabby-images/f5183/f518360ff09faf868a3c9d100638a91b7dbc1253" alt=""
4. 剪切掉超出父类尺寸部分,可以用于放大功能提升显示精度而不影响整个控件的尺寸,默认不剪切Inherit
data:image/s3,"s3://crabby-images/72538/72538b3cc114d24b59b357586be67cdbeb19a2db" alt=""
5. 当某个类似按钮类型的在游戏中出现无法点击情况,先查看是不是有其他控件遮挡住了或者将按钮的Zorder设大
data:image/s3,"s3://crabby-images/e3b43/e3b431198446773f0f219fe7e530073c82d57ac9" alt=""
6. UI部件保证其他地方可以获取调用
data:image/s3,"s3://crabby-images/0f33c/0f33cfd226f23c8845514323d4eecc50c2d096c9" alt=""
7. UI保证屏幕尺寸不影响部件的相对位置
data:image/s3,"s3://crabby-images/200e1/200e1f1b70bf934471a3bfb2357eb385cb959ce7" alt=""
8. UI不改变边缘部分进行放大缩小等
data:image/s3,"s3://crabby-images/7c6c1/7c6c12802ff0ef1cdb5a1d877d7b113b3a4543cd" alt=""
9. UI要使某个图片靠边 且改变游戏窗口尺寸不影响UI部件的位置,可以调节锚点。
data:image/s3,"s3://crabby-images/6508c/6508c9a3ff22392e6d7a25f98c2581ee61380ae9" alt=""
data:image/s3,"s3://crabby-images/366f9/366f9c5255ce9dbb289f7bc6ed84e92890fc143f" alt=""
10. 关于Button
a. 假设该button在UE4 UI中已编辑
.h文件定义:
UButton* PuGongButton;
UFUNCTION()
void OnPuGongButtonPress();
UFUNCTION()
void OnPuGongButtonRelease();
NativeConstruct函数中:
//查找Btn_pugong
PuGongButton = FindWidget<UButton>("Btn_pugong");
//button按下-弹起事件
FindButtonAndBindPressed("Btn_pugong", "OnPuGongButtonPress");
FindButtonAndBindReleased("Btn_pugong", "OnPuGongButtonRelease");
b. 动态创建button
if (CvsRootPanel)
{
if (WidgetTree)
{
//创建建筑标识按钮
UButton * SceneryBtn = WidgetTree->ConstructWidget<UButton>(UButton::StaticClass());
if (SceneryBtn)
{
UPanelSlot* Slot = CvsRootPanel->AddChild(SceneryBtn);
if (UCanvasPanelSlot* cpSlot = Cast<UCanvasPanelSlot>(Slot))
{
//建筑默认尺寸
//cpSlot->SetSize(FVector2D(20, 20));
cpSlot->SetPosition(FVector2D(PanwInMiniMapLocX + MiniMapPosOffsetX, PanwInMiniMapLocY + MiniMapPosOffsetY));
}
//创建按钮显示的图片
UImage* ImgScenery = WidgetTree->ConstructWidget<UImage>(UImage::StaticClass());
if (ImgScenery)
{
UPanelSlot* Slot = SceneryBtn->AddChild(ImgScenery);
ImgScenery->SetBrushFromTexture(BuildingIcon, false);
}
}
}
}
11. 资源相关的变量需要加uproperty()
UPROPERTY()
UTexture2D* TaskIcon = nullptr;
12. UI字体描边
data:image/s3,"s3://crabby-images/19830/19830e6bb70bc4908cfd898f83e9d945bb662604" alt=""
data:image/s3,"s3://crabby-images/e088b/e088b997ffa111be19aa69edef9310a4e43eb82f" alt=""
字体选择如果没有 可以先查看打开,然后就有了
data:image/s3,"s3://crabby-images/cd070/cd07069dce9ad3352c2a1451aaffe90a329ebf66" alt=""
data:image/s3,"s3://crabby-images/4a4f9/4a4f93a29cedacf2f0e6ad522f924525a0196d30" alt=""
13. 可自由设置样式的字体
- 在ui中添加rich text block
data:image/s3,"s3://crabby-images/1ad8d/1ad8d0fd2f1845e341428a22bab1812d3f12573a" alt=""
- 创建data table
data:image/s3,"s3://crabby-images/2d614/2d614cee2c46a8bc594bc7bd53bf93af48062ee0" alt=""
- 选择richtextstylerow
data:image/s3,"s3://crabby-images/1d1d8/1d1d8132346d6ca9a99451b1d2e4d6e5f3725b9d" alt=""
- 点击add 添加
data:image/s3,"s3://crabby-images/05e21/05e21b409800f1c9ad16702a816dca0a2c6d02fe" alt=""
- 双击重新命名
data:image/s3,"s3://crabby-images/b27b3/b27b3dc3afe887a9ae376db41d83aafec7f3b37e" alt=""
- 这儿设置了7种不同的颜色,设置字体相关属性
data:image/s3,"s3://crabby-images/a7c86/a7c862ebf4bf9600cd69ccc156d1efc122755189" alt=""
- 回到UI界面 设置Text Style Set
data:image/s3,"s3://crabby-images/a9aba/a9aba831ef3ec1488003d862670d6f82eabae8d4" alt=""
- 字体内容格式<></>
data:image/s3,"s3://crabby-images/b09d6/b09d6846a1667611668a6a1eeb3df9e353daafa3" alt=""
- 效果:
data:image/s3,"s3://crabby-images/7edfa/7edfaa0250120a3f858287e0234773a25c3d4649" alt=""
14. UI添加动画方式
data:image/s3,"s3://crabby-images/eb73c/eb73c4c3e4fca46a454ea7aabd23369b293bc577" alt=""
网友评论