14072202(带IK的Recoil)

【目标】

带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

来自为知笔记(Wiz)

时间: 2024-08-13 20:58:37

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

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

首先在网上查了一下: Solr Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口.用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索引;也可以通过Http Get操作提出查找请求,并得到XML格式的返回结果. Solr引擎 Solr是一个高性能,采用Java5开发,基于Lucene的全文搜索服务器.同时对其进行了扩展,提供了比Lucene更为丰富的查询语言,同时实现了可配置.可扩展并对查询性能进行了优化,并且提供了一个完善的功能

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

我这里集成好了一个自带IK的版本,下载即用, https://github.com/xlb378917466/elasticsearch5.2.include_IK 添加了IK插件意味着你可以使用ik_smart(最粗粒度的拆分)和ik_max_word(最细粒度的拆分)两种analyzer. 你也可以从下面这个地址获取最新的IK源码,自己集成, https://github.com/medcl/elasticsearch-analysis-ik, 里面还提供了使用说明,可以很快上手. 一般使用

Unity给力插件之Final IK

Final IK细节: 1.Aim IK:设定一个目标,关节末端始终朝向该目标,一般用来做头部的朝向. 步骤: a.在模型头节点处添加Aim空物体并reset b.给模型添加Aim IK组件,并填上Aim Transform及根脊椎到头的4节关节(可以设置权重) c.创建目标target(空物体)于脸的正前方, d.在模型上添加空物体Pin,位置与target一致 e.给target添加Aim Boxing脚本,参数为模型对象及pin f.运行后移动target,模型的脸带动上半身的身体并始终朝

在JDBC中使用带参数的SQL语句

ADO.Net中,支持带参数的SQL语句,例如:Select * from Tables where [email protected],其中@column1为SQL参数,使用起来非常方便,而JDBC中没有找到此功能,感觉有点不便, 于是想自己实现一个.今天正好看见csdn中有一篇http://blog.csdn.net/wallimn/article/details/3734242 文章,有些感触,于是把自己的实现也写出来. 我的思路: 1: 在SQL语句中找到以@开始,以" ",

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

1.首先需要安装好Elasticsearch 和elasticsearch-analysis-ik分词器 2.配置ik同义词 Elasticsearch 自带一个名为 synonym 的同义词 filter.为了能让 IK 和 synonym 同时工作,我们需要定义新的 analyzer,用 IK 做 tokenizer,synonym 做 filter.听上去很复杂,实际上要做的只是加一段配置. 打开 /config/elasticsearch.yml 文件,加入以下配置: [html] vi

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

在这里一下讲解着三个的安装和配置, 是因为solr需要使用tomcat和IK分词器, 这里会通过图文教程的形式来详解它们的安装和使用.注: 本文属于原创文章, 如若转载,请注明出处, 谢谢.关于设置IK分词器的文章 IK分词器: http://www.cnblogs.com/wang-meng/p/5814798.html 1, 解压tar文件首先我们在根目录下建立一个solr目录(使用命令: mkdir /solr):  然后查看目录是否生成成功:  解压solr/tomcat/IK 到sol

Solr(四)Solr实现简单的类似百度搜索高亮功能-1.配置Ik分词器

配置Ik分词器 一 效果图 二 实现此功能需要添加分词器,在这里使用比较主流的IK分词器. 1 没有配置IK分词器,用solr自带的text分词它会把一句话分成单个的字. 2 配置IK分词器,的话它会把句子分成词组 三 下载配置分词器 1 下载分词器IK 分词器下载地址: http://download.csdn.net/detail/u013292160/9926148 2 解压下载的文件 3 将ik-analyzer-solr5-5.x.jar这个jar包放入solr项目下的WEB-INF\

ES1.4 中文分词插件ik

ES 官方只支持smartcn这个中文分词插件,是按照单个字进行索引.前端产品搜索时,凡是带这个关键字的都会被索引到.打个比方:搜索"苹果"关键词,凡是包含"苹"和"果"的title都会被索引到.所以为了这个需求,找一个第三方的中文分词插件.看了一下,国内有几款中分分词插件:ik.ansj和mmseg.最后我选择使用了ik. ES1.4 下安装ik,碰到了不少坑.最后终于搞定,所以分享一下ik的安装步骤. 1. 下载es源代码,然后进行编译,将相

CentOS 6.5+Nutch 1.7+Solr 4.7+IK 2012

环境 Linux版本:CentOS 6.5 JDK版本:JDK 1.7 Nutch版本:Nutch 1.7 Solr版本:Solr 4.7 IK版本:IK-Analyzer 2012 目录 1.安装JDK 2.安装Solr 3.为Solr配置IK分词 4.安装Nutch 内容 1.安装JDK 1.1 在/usr/下创建java/目录,下载JDK包并解压 [[email protected] ~]# mkdir /usr/java  [[email protected] ~]# cd /usr/j