我在 swift 中创建了一个小行星类型的游戏,其中我有多种类型的敌人。我目前有一个敌人被一击摧毁。我正在尝试创建第二个敌人,该敌人被两次打击摧毁。
我在类级别分配了一个变量"varenemyTwoHealth = 0",然后在我为其创建敌人、物理体、路径等的函数中添加了"self.enemyTwoHealth = 2"。在我的"didBegin(_contact:SKPhysicsContact)"内部,当导弹与敌人相撞时,我减少"enemyTwoHealth -= 1"并检查"ifenemyTwoHealth <= 0 { body2.node?.removeFromParent()}"。
我遇到的问题是,当第二个敌人在杀死第一个敌人之前出现在屏幕上时,它会将他们的所有生命值再次重置为 2。 (例如,EnemyType2 生成,它有 2 生命值,我击中它一次,现在它有 1 生命值;第二个 EnemyType2 生成,现在都有 2 生命值。)
如何将健康变量分配给每个单独的敌人?
(代码很多,所以我试着只包含相关代码)
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | var enemyTwoHealth = 0 func didBegin(_ contact: SKPhysicsContact) { if body1.categoryBitMask == PhysicsCategories.Missle && body2.categoryBitMask == PhysicsCategories.EnemyTwo { if enemyTwoLives <= 0 { body2.node?.removeFromParent() addScore() } else { enemyTwoHealth -= 1 } body1.node?.removeFromParent() } } func spawnEnemyTwo() { self.enemyTwoLives = 2 } } |
您至少有四个选项,其中 2 个选项已被评论建议。
因为这是一个小行星游戏,我根本不会制造"健康"。在你的情况下,我会做的是拥有一个 SKSpriteNodes 的子继承权。
你的层次结构应该是这样的:
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 | | -- Bigger asteroid - zPosition = 4 | | | -- Big asteroid - zPosition = 3 | | | | | -- Small asteroid - zPosition = 2 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | -- Small asteroid - zPosition = 2 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | -- Big asteroid - zPosition = 3 | | | | | -- Small asteroid - zPosition = 2 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | -- Small asteroid - zPosition = 2 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | -- Big asteroid - zPosition = 3 | | | | | -- Small asteroid - zPosition = 2 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | -- Small asteroid - zPosition = 2 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | -- Smaller asteroid - zPosition = 1 | | | | | | | | | -- Smallest asteroid - zPosition = 0 | | | | | | | | | -- Smallest asteroid - zPosition = 0 |
所有这些小行星都将位于 (0,0) 位置,除了 zPosition 最高的节点。
然后,当你的游戏进行时,当你最大的小行星被击中时,你有一种方法可以将它的直系子代(不是孙子代)从小行星上取下并带到现场。然后,您应用您的代码,使它们根据Bullets的进入方式向不同方向投射。
每次小行星被击中时,您将孩子移动到场景并移除父母。
最终你会找到最小的没有孩子的小行星,从而摧毁所有的小行星。
这种方法在 RAM 上会有点贵,但你不必担心不断地创建新对象会丢失 CPU 周期。
你可以做的另一件事是子类 SKSpriteNode 给每个类。
2 3 4 5 6 7 | var health = 0 convenience init(health:Int){ self.init(imageNamed:"rock") self.health = health } } |
您可以做的另一件事是将运行状况添加到 userData:
2 3 4 5 6 7 8 9 10 | userData["health"] = 2 rock.userData = userData .... if let health = rock.userData["health"]{ health -= 1 rock.userData["health"] = 1 } |
最后,您可以使用 GamePlayKit 并添加一个健康组件:
2 3 4 5 6 7 8 9 10 11 12 | var health = 2 } .... var healthComponent = new HealthComponent() rock.entity.addComponent(healthComponent) .... if let healthComponent = rock.entity.component(ofType:HealthComponent){ healthComponent.health -= 1 } |
我在我的rails应用程序中安装了来自github.com的acts_as_versioned插件,但有一段代码我不完全理解,我希望有人能帮我解决这个问题class_eval我知道block内的方法(或任何它是什么)被定义为类内的实例方法,但我在插件的任何地方都找不到定义为常量的CLASS_METHODS,而且我也不确定是什么here,并且有问题的代码从lib/acts_as_versioned.rb的第199行开始。如果有人愿意告诉我这里的内幕,我将不胜感激。谢谢-C 最佳答案 这是一个异端。http://en.wikipedia
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我最近开始学习Ruby,这是我的第一门编程语言。我对语法感到满意,并且我已经完成了许多只教授相同基础知识的教程。我已经写了一些小程序(包括我自己的数组排序方法,在有人告诉我谷歌“冒泡排序”之前我认为它非常聪明),但我觉得我需要尝试更大更难的东西来理解更多关于Ruby.关于如何执行此操作的任何想法?
我在Ruby中遇到了一个关于Dir[]和File.join()的简单程序,blobs_dir='/path/to/dir'Dir[File.join(blobs_dir,"**","*")].eachdo|file|FileUtils.rm_rf(file)ifFile.symlink?(file)我有两个困惑:首先,File.join(@blobs_dir,"**","*")中的第二个和第三个参数是什么意思?其次,Dir[]在Ruby中有什么用?我只知道它等价于Dir.glob(),但是,我对Dir.glob()确实不是很清楚。 最佳答案
1.回顾.TransportServicepublicclassTransportServiceextendsAbstractLifecycleComponentTransportService:方法:1publicfinalTextendsTransportResponse>voidsendRequest(finalTransport.Connectionconnection,finalStringaction,finalTransportRequestrequest,finalTransportRequestOptionsoptions,TransportResponseHandlerT>
目录一.大致如下常见问题:(1)找不到程序所依赖的Qt库version`Qt_5'notfound(requiredby(2)CouldnotLoadtheQtplatformplugin"xcb"in""eventhoughitwasfound(3)打包到在不同的linux系统下,或者打包到高版本的相同系统下,运行程序时,直接提示段错误即segmentationfault,或者Illegalinstruction(coredumped)非法指令(4)ldd应用程序或者库,查看运行所依赖的库时,直接报段错误二.问题逐个分析,得出解决方法:(1)找不到程序所依赖的Qt库version`Qt_5'
我是Ruby的新手,但过去两周我一直在对Chef测试进行大量研究。该测试使用ChefSpec和Fauxhai,但它看起来不是很“像ruby”,我希望社区能给我一些编码风格的建议。有没有更好的方法来编写这样的嵌套循环?Recipe/foo/recipes/default.rbpackage"foo"doaction:installendRecipe/foo/spec/default_spec.rbrequire'chefspec'describe'foo::default'doplatforms={"debian"=>['6.0.5'],"ubuntu"=>['12.04','10.04
假设一个使用类变量的简单ruby程序,classHolder@@var=99defHolder.var=(val)@@var=valenddefvar@@varendend@@var="toplevelvariable"a=Holder.newputsa.var我猜结果应该是99,但输出不是99。我想知道为什么。由于类变量的范围是类,我假设@@var="toplevelvariable"行不会影响类中的变量。 最佳答案 @@var是Holder的类变量。而顶层的@@var不是Holder的同名类变量@@var,是你在创建类Obj
一文解决关于VLAN所有的疑惑VLAN基本概念为什么需要VLAN?怎么在交换机上划分VLAN,VLAN的工作原理有了子网,已经隔离了广播,还需要VLAN干啥?只进行子网划分,不进行VLAN划分VLAN划分与子网划分附加VLAN信息的方法VLAN划分交换机的端口类型(Access和Trunk)一、访问链接二、汇聚链接汇聚链接VLAN间通信为什么要进行VLAN间通信?路由器实现VLAN间通信路由器和交换机的连接方式通信细节三层交换机实现VLAN间通信加速VLAN间通信三层交换机与路由器三层交换机路由器路由器和交换机配合构建LAN的实例使用VLAN设计局域网的特点VLAN增加网络的灵活性不使用VLA
我正在尝试了解CoffeeScript变量的范围。根据文档:ThisbehavioriseffectivelyidenticaltoRuby'sscopeforlocalvariables.但是,我发现它的工作方式不同。在CoffeeScript中a=1changeValue=->a=3changeValue()console.log"a:#{a}"#Thisdisplays3在ruby中a=1deffa=3endputsa#Thisdisplays1有人能解释一下吗? 最佳答案 Ruby的局部变量(以[a-z_]开头)arerea
关于yolov5训练时参数workers和batch-size的理解yolov5训练命令workers和batch-size参数的理解两个参数的调优总结yolov5训练命令python.\train.py--datamy.yaml--workers8--batch-size32--epochs100yolov5的训练很简单,下载好仓库,装好依赖后,只需自定义一下data目录中的yaml文件就可以了。这里我使用自定义的my.yaml文件,里面就是定义数据集位置和训练种类数和名字。workers和batch-size参数的理解一般训练主要需要调整的参数是这两个:workers指数据装载时cpu所使