Ahogy a hurok viselkedik

Zdravsvtuyte, a helyzet a következő: próbálja forgatni egy objektumot a saját tengelye körül, a nyilakkal jelölt. ám az értékek cseréjét csak forgás 1 lépésben balra vagy jobbra. Nem értem, mi a probléma már az óra. az alábbi kódot:

  1. érvényteleníti Update ()
  2. // áruház ezen a területen az egyszerű optimalizálását a mozgás / forgási sebesség
  3. float sebesség = 1;
  4. // balra
  5. ha (Input.GetKey (KeyCode.LeftArrow)) TurnPlatform (sebességű);
  6. // kapcsolja be a jobb
  7. if (Input.GetKey (KeyCode.RightArrow)) TurnPlatform (sebesség);
  8. // előrelépni
  9. if (Input.GetKey (KeyCode.UpArrow)) MovePlatform (sebesség);
  10. // hátrál
  11. ha (Input.GetKey (KeyCode.DownArrow)) MovePlatform (sebességű);
  12. >
  13. // mozgás platform
  14. void MovePlatform (float sebesség)
  15. float posX = gameObject.transform.position.x + sebesség;
  16. float Posy = gameObject.transform.position.y;
  17. float posZ = gameObject.transform.position.z;
  18. gameObject.transform.position = új Vector3 (posX, Posy, posZ);
  19. >
  20. // forgatni a platform
  21. void TurnPlatform (float sebesség)
  22. // pillanatnyi helyzetének tárolása, kivéve Y, amely hozzá az aktuális pozícióját +/- fokos elfordulása
  23. float Rotx = gameObject.transform.rotation.x;
  24. float ROTY = gameObject.transform.rotation.y + sebesség;
  25. float Rötz = gameObject.transform.rotation.z;
  26. gameObject.transform.rotation = Quaternion.Euler (Rotx, ROTY, Rötz) ;;
  27. >

Paul Siberdt írta (a): [3] alkalmazása a paramétereket a funkciókat a meglévő változók a script ragyog szórakozz neveket. Megoldásként - hívás, például azok aláhúzás: _speed

Hadd fejezzem ki (és nem csak) szempontjából. Van olyan dolog, mint a Code egyezmények - egy megállapodás egy adott nyelv írásmódja kódot. Ezek majdnem minden nyelven. Maximális biztonság, ezek díszített Java és C #. nem csupán egy sor ajánlást, valamint sürgősen sor ajánlást az egyes kódok stílus szempontból a megállapodás vannak írva ezek a nyelvek.

Szóval, az elnevezés a változók Sharp (ez nem az én döntésem, hogy kövesse ezeket a szabályokat, de a IMHO is beleértve):
- Nyilvános és védett változók kezdődik nagybetűvel, és ne használjon speciális karaktereket önmagukban (public int SomeValue;)
- Tulajdonságok függetlenül hatálya kezdődik nagybetűvel és jelenleg nem használják a speciális szimbólumok (magán kettős SomeDouble)
- Egyéni változók egy osztályon belül az aláhúzás az elején, és kezdődik egy kisbetű, és ne használjon speciális karaktereket más helyeken (magán húr _someString;)
- Helyi változók kezdődik egy kisbetű, és ne használjon speciális karaktereket önmagukban (public void fuggveny ()).

Ez nem a részletek a megállapodás, de egy rövid felidézése.

Ha fel ReSharper, de nem kapcsolja ki a háttérvilágítást megállapodások - a kód elkápráztatja kék aláhúzás. Frusztráló, és ez jobb (ismét, IMHO).

De a munka oda-vissza négyes támaszkodva evlerovy sarkok veszélyesen kiszámíthatatlan leletek.
Az egyetlen dolog, amit tehetünk Bole-mene magabiztosan - hozzon létre evlerovy forgatás egy tengelyre, hogy őket négyes, és kizárólag rajtuk. Ami, mellesleg, én az utolsó [negyedik] bekezdésében a válaszát.


Valójában én nem ajánlom játszik az Euler szögek, anélkül, hogy megértenénk őket.
Meg kell többször (jobb - néhány nappal a sorban lefekvés előtt), olvassa el ezt és ezt. Természetesen, ha azt szeretnénk, hogy mester őket. Óvatosan, breynfak (nem abban az értelemben, PL cím)!

Johnson megjelent eredményeként osztás null. Krivokoder visszaeső. Harap.
Jó, hogy a kórházban a sebészek nem ugyanaz, mint az újoncok ezen a fórumon. Azért jöttem, hogy húzza a köröm a kezéből, és levágja a tojásokat.
ProgrammerNotFoundException on line 0!

Kapcsolódó cikkek