【目标】

带IK的Recoil

【思路】

1 继承于USkelControlLimb和UGameSkelCtrl_Recoil

2 效果对比

 以这个骨骼为例

Recoil

Limb


可见,Recoil只影响一根骨骼
如果两个结合就是,Recoil产生的冲击位移作为Limb的控制点,由控制点带动三根骨骼的移动

【步骤】

1 在\ue3\Development\Src\Engine\Classes中新建SkelControlLimbRecoil.uc

先复制\ue3\Development\Src\GameFramework\Classes\GameSkelCtrl_Recoil.uc的内容

make 后 编译代码会出现结构体 枚举 重命名

需要将\GameSkelCtrl_Recoil.uc的结构体 枚举注释掉

2 在UnSkelControl.cpp 添加类实现

  1. IMPLEMENT_CLASS(USkelControlLimbRecoil)
  2. ...
  3. /*-----------------------------------------------------------------------------
  4. USkelControlLimbRecoil
  5. -----------------------------------------------------------------------------*/
  6. FVector2D USkelControlLimbRecoil::GetAim(USkeletalMeshComponent* InSkelComponent)
  7. {
  8. return Aim;
  9. }
  10. /** Is skeleton currently mirrored */
  11. UBOOL USkelControlLimbRecoil::IsMirrored(USkeletalMeshComponent* InSkelComponent)
  12. {
  13. return FALSE;
  14. }
  15. // USkelControlBase interface
  16. void USkelControlLimbRecoil::TickSkelControl(FLOAT DeltaSeconds, USkeletalMeshComponent* SkelComp)
  17. {
  18. bApplyControl = FALSE;
  19. if( ControlStrength > ZERO_ANIMWEIGHT_THRESH )
  20. {
  21. // if willing to play recoil, reset its state
  22. if( bPlayRecoil != bOldPlayRecoil )
  23. {
  24. bPlayRecoil = bOldPlayRecoil;
  25. Recoil.TimeToGo = Recoil.TimeDuration;
  26. // ERS_Random == Start at random position along sine wave,
  27. // ERS_Zero == Start at 0
  28. const FLOAT TWO_PI = 2.f * (FLOAT)PI;
  29. Recoil.RotSinOffset.X = Recoil.RotParams.X == ERS_Random ? appFrand() * TWO_PI : 0.f;
  30. Recoil.RotSinOffset.Y = Recoil.RotParams.Y == ERS_Random ? appFrand() * TWO_PI : 0.f;
  31. Recoil.RotSinOffset.Z = Recoil.RotParams.Z == ERS_Random ? appFrand() * TWO_PI : 0.f;
  32. Recoil.LocSinOffset.X = Recoil.LocParams.X == ERS_Random ? appFrand() * TWO_PI : 0.f;
  33. Recoil.LocSinOffset.Y = Recoil.LocParams.Y == ERS_Random ? appFrand() * TWO_PI : 0.f;
  34. Recoil.LocSinOffset.Z = Recoil.LocParams.Z == ERS_Random ? appFrand() * TWO_PI : 0.f;
  35. Recoil.RotOffset = FRotator(0,0,0);
  36. Recoil.LocOffset = FVector(0.f);
  37. }
  38. if( Recoil.TimeToGo > DeltaSeconds )
  39. {
  40. Recoil.TimeToGo -= DeltaSeconds;
  41. if( Recoil.TimeToGo > 0.f )
  42. {
  43. bApplyControl = TRUE;
  44. // Smooth fade out
  45. const FLOAT TimePct = Clamp<FLOAT>(Recoil.TimeToGo / Recoil.TimeDuration, 0.f, 1.f);
  46. const FLOAT Alpha = TimePct*TimePct*(3.f - 2.f*TimePct);
  47. const FLOAT AlphaTimesDelta = Alpha * DeltaSeconds;
  48. // Recoil Bone Rotation, compute sin wave value for each component
  49. if( !Recoil.RotAmplitude.IsZero() )
  50. {
  51. if( Recoil.RotAmplitude.X != 0.f )
  52. {
  53. Recoil.RotSinOffset.X += AlphaTimesDelta * Recoil.RotFrequency.X;
  54. Recoil.RotOffset.Pitch = appTrunc(Alpha * Recoil.RotAmplitude.X * appSin(Recoil.RotSinOffset.X));
  55. }
  56. if( Recoil.RotAmplitude.Y != 0.f )
  57. {
  58. Recoil.RotSinOffset.Y += AlphaTimesDelta * Recoil.RotFrequency.Y;
  59. Recoil.RotOffset.Yaw = appTrunc(Alpha * Recoil.RotAmplitude.Y * appSin(Recoil.RotSinOffset.Y));
  60. }
  61. if( Recoil.RotAmplitude.Z != 0.f )
  62. {
  63. Recoil.RotSinOffset.Z += AlphaTimesDelta * Recoil.RotFrequency.Z;
  64. Recoil.RotOffset.Roll = appTrunc(Alpha * Recoil.RotAmplitude.Z * appSin(Recoil.RotSinOffset.Z));
  65. }
  66. }
  67. // Recoil Bone Location, compute sin wave value for each component
  68. if( !Recoil.LocAmplitude.IsZero() )
  69. {
  70. if( Recoil.LocAmplitude.X != 0.f )
  71. {
  72. Recoil.LocSinOffset.X += AlphaTimesDelta * Recoil.LocFrequency.X;
  73. Recoil.LocOffset.X = Alpha * Recoil.LocAmplitude.X * appSin(Recoil.LocSinOffset.X);
  74. }
  75. if( Recoil.LocAmplitude.Y != 0.f )
  76. {
  77. Recoil.LocSinOffset.Y += AlphaTimesDelta * Recoil.LocFrequency.Y;
  78. Recoil.LocOffset.Y = Alpha * Recoil.LocAmplitude.Y * appSin(Recoil.LocSinOffset.Y);
  79. }
  80. if( Recoil.LocAmplitude.Z != 0.f )
  81. {
  82. Recoil.LocSinOffset.Z += AlphaTimesDelta * Recoil.LocFrequency.Z;
  83. Recoil.LocOffset.Z = Alpha * Recoil.LocAmplitude.Z * appSin(Recoil.LocSinOffset.Z);
  84. }
  85. }
  86. }
  87. }
  88. }
  89. Super::TickSkelControl(DeltaSeconds, SkelComp);
  90. }
  91. void USkelControlLimbRecoil::CalculateNewBoneTransforms(INT BoneIndex, USkeletalMeshComponent* SkelComp, TArray<FBoneAtom>& OutBoneTransforms)
  92. {
  93. Super::CalculateNewBoneTransforms(BoneIndex, SkelComp, OutBoneTransforms);
  94. }

现在需要将USkelControlLimb.EffectorLocation 设置为Recoil影响的骨骼的更新的位置

3

4



14072202(带IK的Recoil)的更多相关文章

  1. 带 IK 分词器的 Luke 和 搜索应用服务器solr

    首先在网上查了一下: Solr Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口.用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索 ...

  2. Unity给力插件之Final IK

    Final IK细节: 1.Aim IK:设定一个目标,关节末端始终朝向该目标,一般用来做头部的朝向. 步骤: a.在模型头节点处添加Aim空物体并reset b.给模型添加Aim IK组件,并填上A ...

  3. 在ElasticSearch中使用 IK 中文分词插件

    我这里集成好了一个自带IK的版本,下载即用, https://github.com/xlb378917466/elasticsearch5.2.include_IK 添加了IK插件意味着你可以使用ik ...

  4. humanoid ik unity 配件 animation的问题

    遇到这样一个问题 想给角色设置ik 以实现代码控制的 更为自然的 角色动作 比如角色头跟随点击转动 身体也有相应扭转 https://docs.unity3d.com/Manual/InverseKi ...

  5. 全文检索引擎sphinx 与 Elasticsearch 索引速度对比

    sphinx的特色之一是建立索引速度快,最近转投Elasticsearch后,一直想做个对比,网上资料常见说法是10倍的差距. 测试环境 硬件:单核,2G内存的E5-2630 虚拟机 操作系统:Cen ...

  6. Elasticsearch java api操作(一)(Java Low Level Rest Client)

    一.说明: 一.Elasticsearch提供了两个JAVA REST Client版本: 1.java low level rest client: 低级别的rest客户端,通过http与集群交互, ...

  7. [Linux]Linux下安装和配置solr/tomcat/IK分词器 详细实例一.

    在这里一下讲解着三个的安装和配置, 是因为solr需要使用tomcat和IK分词器, 这里会通过图文教程的形式来详解它们的安装和使用.注: 本文属于原创文章, 如若转载,请注明出处, 谢谢.关于设置I ...

  8. 安装elasticsearch及中文IK和近义词配置

    安装elasticsearch及中文IK和近义词配置 安装java环境 java环境是elasticsearch安装必须的 yum install java-1.8.0-openjdk 安装elast ...

  9. 使用 Elasticsearch ik分词实现同义词搜索(转)

    1.首先需要安装好Elasticsearch 和elasticsearch-analysis-ik分词器 2.配置ik同义词 Elasticsearch 自带一个名为 synonym 的同义词 fil ...

随机推荐

  1. Spring框架简介 Spring Framework Introduction

    Introduction The Spring Framework provides a comprehensive programming and configuration model for m ...

  2. 【Selenium】4.创建你的第一个Selenium IDE脚本

    http://newtours.demoaut.com/ 这个网站将会用来作为我们测试的网址. 通过录制来创建一个脚本 让我们来用最普遍的方法——录制来创建一个脚本.然后,我们将会用回放的功能来执行录 ...

  3. Cocos2d-x PluginX (二)增加新的Plugin

    创建Plugin目录 第一步,在plugin/plugins下,目录需要严格按照如下规范实现: plugin/plugins/alipay/proj.android /proj.ios 因为publi ...

  4. svn提交时强制添加注释

    1,找到Repositories 文件夹 2,在Repositories 中找到对应的工程, 3,在工程下找到hooks文件夹 4.在hooks文件夹下添加 :pre-commit.bat文件;文件内 ...

  5. Openstack的web管理端相关

    openstack的web管理端技术方面要关注的问题. 同步?异步 先说浏览器的同步和异步,我们知道的浏览器可以使用ajax实现异步请求,就是浏览器在请求数据的时候,我们管理员还能对浏览器就行其他操作 ...

  6. Angularjs 中文版API v1.3.9 阅读

    http://www.angularjsapi.cn/#/bootstrap 2016.7.4 ng.function: 1.angular.bind(self,fn,args ); 2.angula ...

  7. 数据可视化:Echart中k图实现动态阈值报警及实时更新数据

    1 目标 使用Echart的k图展现上下阈值,并且当真实值超过上阈值或低于下阈值时候,标红报警. 2 实现效果 如下:

  8. 04-时序逻辑电路设计之计数器——小梅哥FPGA设计思想与验证方法视频教程配套文档

    芯航线--普利斯队长精心奉献 实验目的:以计数器为例学会简单的时序逻辑电路设计 实验平台:芯航线FPGA核心板 实验原理: 时序逻辑电路是指电路任何时刻的稳态输出不仅取决于当前的输入,还与前一时刻输入 ...

  9. linux下安装及配置和启动memcached

    一.下载文件: 下载memcached和libevent,放到/hom/zwl/目录下 # wget http://www.danga.com/memcached/dist/memcached-1.2 ...

  10. prototype与原型链

    1.今天翻看 阮一峰老师的博客看到了,一篇讲javascript为什么要设计出prototype,跳转      大意就是new 的方式有缺陷,没有共同的属性,一下明白了很多. 在来一张原型链的图: