收集2018-2-10前的,新的在新帖里
周末,是扯淡的日子,正如詩里扯的淡:
你是一樹一樹的花開,
是燕在樑間呢喃,
你是愛、是暖、是希望,
你是人間的四月天!
最新劇情:UE4扯淡大雜燴第二季
First Egg
APawn.IsLocallyControlled 和APawn.IsPlayerControlled 完全就是扯淡。不能準確表示單機、客戶端、獨立服務器、監聽服務器下的Pawn狀態。
Game動態更新csv表格
官方版本UDataTable只能在Editor中實例化,Game中都被宏定義禁用了。如果要搞,將對應的邏輯相關的代碼文件遷移到客戶端就可以用了,只有三五個文件。記之。
屬性與RPC的網絡包處理過于復雜
實現部分不是一般的復雜,什么每個包里解析出object和guid,然后分發消息。每個UObject都可能是一個網絡包里的object。Guid大概從自然數簡單遞增,每個對象在客戶端和服務端都有個映射表。還有個channel,不是channel V,混在里面濫竽充數。那UDP還要處理重發來著。那Replicator不是SG中的小蟲子,是用來處理object的消息分發的代理。那ip connection和net driver,在十幾個對象里穿梭把別人都不放在眼里。
扯個SceneCapturer的淡
這個淡可以一扯是因為有2份重名的類和文件名字(4.11)
Engine\Plugins\Experimental\StereoPanorama\Source\StereoPanorama\Private\SceneCapturer.h
Engine\Source\Runtime\Engine\Classes\Engine\SceneCapture.h
好了,扯完了淡,要記得實驗庫中的SceneCaputre的Acotr和Component與Engine庫中有重名,不要混淆了
扯個Gameplay Tags的蛋
USING GAMEPLAY TAGS TO LABEL AND ORGANIZE YOUR CONTENT IN UE4
使用游戲性標記在 UE4 中標記和整理內容
Missing:扯蛋
你們要的蛋蛋來了:
首先在Gameplay Ablitities開啟后,有個Cue編輯窗。在這里可以可以增加tag。例如增加“GameplayCue.Damage.Type1”和“GameplayCue.Damage.Type2”
然后,找2個cue,例如Blueprint'/Game/Blueprints/GameplayCues/Cue_HitImpact.Cue_HitImpact',將它們的tags分別設為上面的1型和2型
于是乎,在UGameplayEffect的成員FGameplayEffectCue.GameplayCueTags對應的BP窗口上就可以選中這2個tag了,多選就多個效果。
其配置文件路徑:GameAbility\Config\DefaultGameplayTags.ini
ACharacter構造時掛接的子對象由于重構改名后造成ACharacterBP中被不正常清空的BUG
ACharacter的構造掛了這樣一個成員:
AttributeSet = CreateDefaultSubobject(ucustomattributeset)(TEXT("AttributeSet"));
然后將UCustomAttributeSet重新換個名字
于是只要開始Play就會發現AttributeSet被清空了,版本4.15.1。反復清空緩存和編譯BP都無法解決,懷疑某些符號在C++重命名后在BP中的布局已經紊亂了,初始化的時候錯誤的被越界覆蓋或清除了
解決:
將CharacterBP先reparent到一個更底層的類,然后再reparent回來還原。
扯一只瑪雅2016的蛋
Maya2016按照官方的說明安裝Animation and Rigging Tools Installation,啟動Maya木有彈出Browser窗口。
后來發現,這個淡本身就是扯淡,Maya LT并不支持Python。從而又有下一個蛋可以扯了:maya vs maya-LT。
Maya vs. Maya LT
Maya vs. Maya LT
LT是個縮水版。
NOT POT Texture
Never streaming
No Mipmap
扯個IN/OUT的淡
ApplyGameplayEffectSpecToSelf(OUT FGameplayEffectSpec& GameplayEffect, FPredictionKey PredictionKey = FPredictionKey());
UnrealEngine\Engine\Source\Runtime\Core\Public\Windows\WindowsSystemIncludes.h
#ifndef OUT
#define OUT
#endif
#ifndef IN
#define IN
#endif
菩提本無樹,庸人自擾之。
搞個USTRUCT(BlueprintType)新策略限制在BP中使用某些方法
BP中一旦亂用起來,其實也是很可怕的。于是為了彰顯千年的功績,硬擼個新區讓它橫空出世以千年大計的牌坊插在流芳萬世的信息鎖國的遺臭上,隨心所欲不怕矩。
USTRUCT(BlueprintType)
structFProjectileEffectContainer{
GENERATED_USTRUCT_BODY()
UPROPERTY(EditAnywhere)
TArray Effects;
TArray ApplyEffect(AActor* Target);
}
USTRUCT中的方法不能聲明為BP方法,這樣就不能再BP中濫用了。然后再擼個UBlueprintFunctionLibrary來訪問這些USTRUCT中的方法,在BP中隨心所欲的玩吧。
來扯一只Camera自動激活的蛋
場景中的CameraActor的屬性中有一個Auto Player Activation,可以指定一個Player,自動給其激活camera。曾經有一只碼農嫌的蛋痛于是在場景里放了2個這個CameraActor,都指定自動激活給Player0,于是開始游戲后Camera只是激活到了后來加入場景的CameraActor,這樣這項很重要的工作這只碼農有一半的時間做了無用功,只因為加了2個CameraActor。
總結下,考慮一張Level,里面一只默認的ThirdPerson Character,當然默認是帶一個CameraComponent的,另外Level里還放一只CameraActor。則Level激活Camera優先級順序如下
優先激活指定了Auto Player Activation的CameraActor。這個時候Character上的CameraComponent指定激活與否效果一樣
如果CameraActor沒有指定Auto Player Activation,則其在Level中就是只廢物,可以無視掉。在這個情況下,則:
優先激活Character上帶自動激活屬性(Auto Activation)的CameraComponent,例如Character上有多個CameraComponent,激活其中帶自動激活屬性的。如果多個Component都帶自動激活屬性,那么就XX了。
如果場景中既沒有帶指定Player的CameraActor,或根本就沒有CameraActor,然后所有的ActorComponent都不帶自動激活屬性,則引擎將Camera的坐標指定為Character的世界坐標
扯完了Camera的蛋,順便扯扯如何切這只蛋:
用Player Controller的Set View Target with Blend指定Camera
New View Target可以指定任意Actor,如果目標是CameraActor,則其上的PP屬性等都可以繼承過來,如果只是簡單Actor,則只去這個Actor的變換矩陣。
如果要切換回Character,New View Target指定為自己,例如Get Player Character
不扯蛋就遺忘
BP的For有2個參數:First ,Last。其基于人類友好的方式計數,也就是計算序列為:First, First+1 ... Last。不同于C。
扯扯回調的蛋
DECLARE_DELEGATE( DelegateName )
DECLARE_MULTICAST_DELEGATE( DelegateName )
DECLARE_EVENT( OwningType, EventName )
USTRUCT的構造的蛋
USTRUCT默認可以不寫構造函數,但是如果寫了帶參數的構造函數,則蛋來了:必須補上那個不帶參數的默認構造函數。例如下面代碼塊被注釋后就無法通過UBT編譯:
USTRUCT(BlueprintType)
struct FSortRecordItem
{
// GENERATED_USTRUCT_BODY()
// FSortRecordItem()
// {
// }
FSortRecordItem(int32 a)
{
}
};
一只friend function的蛋
UCLASS(MinimalAPI)
classULandscapeSplinesComponent:publicUPrimitiveComponent
{
// many friendsfriendclassFLandscapeToolSplines;
friendclassFLandscapeSplinesSceneProxy;
friendclassULandscapeSplineControlPoint;
friendclassULandscapeSplineSegment;
#ifWITH_EDITOR
// TODO - move this out of ULandscapeInfo
friend bool ULandscapeInfo::ApplySplinesInternal(boolbOnlySelected,ALandscapeProxy*Landscape);
#endif
Transform的蛋蛋
Actor和Component取Transform是不同的:
Actor用GetTransform, Component用GetComponentTransform
Vector與Position進行Transform也是不同的,很容易混淆。或許再扯一萬年的蛋,還是會誤用吧:
Vector用TransformVector,Position用TransformPosition
模塊引用的蛋蛋
假設主工程交模塊MyProject,則底層宏會定義一個MyProject_API的模塊導出宏。
這個時候你另外定義了一個模塊用于實現某個功能,例如CustomDetail。如果在它里面要引用MyProject的class,則只需:
1,CustomDetail工程引入MyPrject作為依賴:PrivateDependencyModuleNames.AddRange
2,MyPrject的class加裝MyProject_API修飾。
這種扯淡的事也能碰到!
在Editor里Play后,全屏幕黑。剛build完lighting,以為是光照參數造成的bug。折騰之,我去,不是。偶然發現竟然是相當于相機被放在了Camera的Actor Mesh中間,被一個立方mesh包圍了,相當于跑到這只mesh內部渲染了。
只好修復引擎了。
升級到4.15編譯Android的蛋
gc++崩潰,并找到提示:
LogPlayLevel: UnrealBuildTool: This application has requested the Runtime to terminate it in an unusual way.
LogPlayLevel: UnrealBuildTool: Please contact the application's support team for more information.
Expression: DeclKind != Decl::LinkageSpec && "Should not perform lookups into linkage specs!"
網上找的解決方式:
更新AndroidWroks。
c:\nvpack\Chooser.exe
https://answers.unrealengine.com/questions/578929/launch-and-package-fail-for-c-android-projects-in.html
扯淡的是,這并不能解決問題。然后嘗試直接設置ndk目錄:在配置,android sdk中設置ndk為最新的,發現編譯C++后不會崩潰,但是UBT又報錯。
所以ndk更新是可以解決C++編譯,但是根源在于UE4.15沒有正確設置到最新的NDK.
安裝最新的AndroidWorks:
D:\Program Files (x86)\Epic Games\UE_4.15\Engine\Extras\AndroidWorks\Win64\CodeWorksforAndroid-1R5-windows.exe
安裝后從之前的1R1升級到了1R5了,然后需要網絡更新了。
Invalid-or-unsupported-command---UE4.15與NDK android-24的蛋
====2017/4/26 14:05:28====PREPARING NATIVE CODE=================================================================
UEDeployAndroid.RequiresOBB: APK contains data.
UEDeployAndroid.GenerateManifest: Fixing minSdkVersion; NDK level above 19 requires minSdkVersion of 21 (arch=armv7)
UEDeployAndroid.UpdateProjectProperties:
====2017/4/26 14:05:28====UPDATING BUILD CONFIGURATION FILES====================================================
**************************************************************************
The "android" command is deprecated.
For manual SDK, AVD, and project management, please use Android Studio.
For command-line tools, use tools\bin\sdkmanager.bat
and tools\bin\avdmanager.bat
**************************************************************************
Invalid or unsupported command "--silent update lib-project --path JavaLibs/downloader_library --target android-24"
破蛋之策在這里:
https://forums.unrealengine.com/showthread.php?142035-Invalid-or-unsupported-command
簡單來說就是將在Project Setting里NDK的版本填為"Android-19"
其實問題只是解決了部分。最終解決方式:
在AndroidWorks中選中1R4,
卸載sdk和ndk然后重新安裝。
Building Lighting的蛋
人生波譎云詭,一般人碰不到的事總能碰到,現在Building Lighting總是失敗,報錯:
Lighting build failed. Swarm failed to kick off
Error, fatal in BeginJobSpecification
發現那個Build Lighting的關聯邏輯:UE4Editor-UnrealEd.dll!FStaticLightingSystem::BeginLightmassProcess
其實無甚鳥用。之前google有人提到:重新編譯UnrealLightmass。之前想當然的重新編譯solution以為UnrealLightmass也是重新編譯了,沒有效果也就不在意,畢竟google上各種答案混雜,偶然可以碰對。
今天選中UnrealLightmass工程后編譯,build lighting竟然好了!好吧,build solution是有些工程是可以默認不參與編譯的。微軟一向如此,總是隱式的干一堆你并不存完全總是意料之中的事,微軟口碑爛了,這黑鍋都沒興趣扔它了。
Beam Particle的蛋
需要在Particle的Source和Target中設置Methord為User Set,不然在運行時設置位置會無效。
設置起源與目標
SetBeamSourcePoint/SetBeamTargetPoint
Sequence與Delay
Sequence中的邏輯是“順序并行”執行的,并不是順序串行執行,不明白的自己去想!
正確使用物理效果的姿勢
首先,扯點淡,不然后面說的都是扯淡: Mesh對象要生成collision,否則物理是無效的。
對于地面:只需要開啟gravity。
對于地上的物體,需要開啟:模擬物理,重力。如果要與其他物理碰撞,要在編輯器里設置collision preset類型,在代碼或bp里對應UPrimitiveComponent.SetCollisionResponseToAllChannels 。
創建Spline遇到的蛋蛋
Add Spline Component默認情況下會添加2個Point,這個其實也不是很扯蛋,只是經常容易忘了。
GooglePlay的蛋
本是Google的蛋,不關Epic。總之,google之。24H后,加上googlegroup郵箱,刷新后幾分鐘beta show就出來了。只是中間在切了一下beta using googlegroup并加入googlegroup,不知道有沒有關系。
---不知道說的什么
來個Plugins中模塊的蛋
定義好模塊編譯神馬的都OK了,啟動時卻報錯,找不到這個模塊。問題出在uproject文件中沒有加入這個模塊。
蛋:不要混淆Editor和Game的模塊目錄
這一蛋是混淆了Editor和Game的模塊目錄,在MyGame.Build.cs中用PrivateDependencyModuleNames引入了GameplayAbilitiesEditor。于是折騰了好久。
DebugGame Editor的蛋
假設在DebugGame Editor配置下開發,一起都很好。偶然一次你又雙擊uproject文件啟動編輯器了,會發現修改了C++邏輯似乎不對。那是因為DebugGame Editor生成的編輯器并非Development Editor。
升級后ACharacter莫名其妙問題
//AbilitySystemComponent莫名其妙變空指針,調試發現初始化后某個地方導致變空
//具體細節不明,懷疑是版本升級后所致,之前也碰到過幾次版本升級造成莫名其妙的問題
//在BP里將先reparent到Character,再reparent回BaseCharacter就好了
<占位標題>
<占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述占位描述>
<占位項1>
<占位項2>
UE4無法加載dll
如果某個插件在.uproject中沒有配置,會提醒無法加載這個模塊的dll