cDistributedSmoothNodeBase.I 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. /**
  2. * PANDA 3D SOFTWARE
  3. * Copyright (c) Carnegie Mellon University. All rights reserved.
  4. *
  5. * All use of this software is subject to the terms of the revised BSD
  6. * license. You should have received a copy of this license along
  7. * with this source code in a file named "LICENSE."
  8. *
  9. * @file cDistributedSmoothNodeBase.I
  10. * @author drose
  11. * @date 2004-09-03
  12. */
  13. /**
  14. * Tells the C++ instance definition about the AI or Client repository, used
  15. * for sending datagrams.
  16. */
  17. INLINE void CDistributedSmoothNodeBase::
  18. set_repository(CConnectionRepository *repository,
  19. bool is_ai, CHANNEL_TYPE ai_id) {
  20. _repository = repository;
  21. _is_ai = is_ai;
  22. _ai_id = ai_id;
  23. }
  24. #ifdef HAVE_PYTHON
  25. /**
  26. * Tells the C++ instance definition about the global ClockDelta object.
  27. */
  28. INLINE void CDistributedSmoothNodeBase::
  29. set_clock_delta(PyObject *clock_delta) {
  30. _clock_delta = clock_delta;
  31. }
  32. #endif // HAVE_PYTHON
  33. /**
  34. * Returns true if at least some of the bits of compare are set in flags, but
  35. * no bits outside of compare are set. That is to say, that the only things
  36. * that are changed are the bits indicated in compare.
  37. */
  38. INLINE bool CDistributedSmoothNodeBase::
  39. only_changed(int flags, int compare) {
  40. return (flags & compare) != 0 && (flags & ~compare) == 0;
  41. }
  42. /**
  43. *
  44. */
  45. INLINE void CDistributedSmoothNodeBase::
  46. d_setSmStop() {
  47. // cout << "d_setSmStop" << endl;
  48. DCPacker packer;
  49. begin_send_update(packer, "setSmStop");
  50. finish_send_update(packer);
  51. }
  52. /**
  53. *
  54. */
  55. INLINE void CDistributedSmoothNodeBase::
  56. d_setSmH(PN_stdfloat h) {
  57. // cout << "d_setSmH: " << h << endl;
  58. DCPacker packer;
  59. begin_send_update(packer, "setSmH");
  60. packer.pack_double(h);
  61. finish_send_update(packer);
  62. }
  63. /**
  64. *
  65. */
  66. INLINE void CDistributedSmoothNodeBase::
  67. d_setSmZ(PN_stdfloat z) {
  68. // cout << "d_setSmZ: " << z << endl;
  69. DCPacker packer;
  70. begin_send_update(packer, "setSmZ");
  71. packer.pack_double(z);
  72. finish_send_update(packer);
  73. }
  74. /**
  75. *
  76. */
  77. INLINE void CDistributedSmoothNodeBase::
  78. d_setSmXY(PN_stdfloat x, PN_stdfloat y) {
  79. // cout << "d_setSmXY: " << x << ", " << y << endl;
  80. DCPacker packer;
  81. begin_send_update(packer, "setSmXY");
  82. packer.pack_double(x);
  83. packer.pack_double(y);
  84. finish_send_update(packer);
  85. }
  86. /**
  87. *
  88. */
  89. INLINE void CDistributedSmoothNodeBase::
  90. d_setSmXZ(PN_stdfloat x, PN_stdfloat z) {
  91. // cout << "d_setSmXZ: " << x << ", " << z << endl;
  92. DCPacker packer;
  93. begin_send_update(packer, "setSmXZ");
  94. packer.pack_double(x);
  95. packer.pack_double(z);
  96. finish_send_update(packer);
  97. }
  98. /**
  99. *
  100. */
  101. INLINE void CDistributedSmoothNodeBase::
  102. d_setSmPos(PN_stdfloat x, PN_stdfloat y, PN_stdfloat z) {
  103. // cout << "d_setSmXYZ: " << x << ", " << y << ", " << z << endl;
  104. DCPacker packer;
  105. begin_send_update(packer, "setSmPos");
  106. packer.pack_double(x);
  107. packer.pack_double(y);
  108. packer.pack_double(z);
  109. finish_send_update(packer);
  110. }
  111. /**
  112. *
  113. */
  114. INLINE void CDistributedSmoothNodeBase::
  115. d_setSmHpr(PN_stdfloat h, PN_stdfloat p, PN_stdfloat r) {
  116. // cout << "d_setSmHPR: " << h << ", " << p << ", " << r << endl;
  117. DCPacker packer;
  118. begin_send_update(packer, "setSmHpr");
  119. packer.pack_double(h);
  120. packer.pack_double(p);
  121. packer.pack_double(r);
  122. finish_send_update(packer);
  123. }
  124. /**
  125. *
  126. */
  127. INLINE void CDistributedSmoothNodeBase::
  128. d_setSmXYH(PN_stdfloat x, PN_stdfloat y, PN_stdfloat h) {
  129. // cout << "d_setSmXYH: " << x << ", " << y << ", " << h << endl;
  130. DCPacker packer;
  131. begin_send_update(packer, "setSmXYH");
  132. packer.pack_double(x);
  133. packer.pack_double(y);
  134. packer.pack_double(h);
  135. finish_send_update(packer);
  136. }
  137. /**
  138. *
  139. */
  140. INLINE void CDistributedSmoothNodeBase::
  141. d_setSmXYZH(PN_stdfloat x, PN_stdfloat y, PN_stdfloat z, PN_stdfloat h) {
  142. // cout << "d_setSmXYZH: " << x << ", " << y << ", " << z << ", " << h <<
  143. // endl;
  144. DCPacker packer;
  145. begin_send_update(packer, "setSmXYZH");
  146. packer.pack_double(x);
  147. packer.pack_double(y);
  148. packer.pack_double(z);
  149. packer.pack_double(h);
  150. finish_send_update(packer);
  151. }
  152. /**
  153. *
  154. */
  155. INLINE void CDistributedSmoothNodeBase::
  156. d_setSmPosHpr(PN_stdfloat x, PN_stdfloat y, PN_stdfloat z, PN_stdfloat h, PN_stdfloat p, PN_stdfloat r) {
  157. // cout << "d_setSmPosHpr: " << x << ", " << y << ", " << z << ", " << h <<
  158. // ", " << p << ", " << r << endl;
  159. DCPacker packer;
  160. begin_send_update(packer, "setSmPosHpr");
  161. packer.pack_double(x);
  162. packer.pack_double(y);
  163. packer.pack_double(z);
  164. packer.pack_double(h);
  165. packer.pack_double(p);
  166. packer.pack_double(r);
  167. finish_send_update(packer);
  168. }
  169. /**
  170. *
  171. */
  172. INLINE void CDistributedSmoothNodeBase::
  173. d_setSmPosHprL(PN_stdfloat x, PN_stdfloat y, PN_stdfloat z, PN_stdfloat h, PN_stdfloat p, PN_stdfloat r, uint64_t l) {
  174. // cout << "d_setSmPosHprL: " << x << ", " << y << ", " << z << ", " << h <<
  175. // ", " << p << ", " << r << l << endl;
  176. DCPacker packer;
  177. begin_send_update(packer, "setSmPosHprL");
  178. packer.pack_uint64(_currL[0]);
  179. packer.pack_double(x);
  180. packer.pack_double(y);
  181. packer.pack_double(z);
  182. packer.pack_double(h);
  183. packer.pack_double(p);
  184. packer.pack_double(r);
  185. finish_send_update(packer);
  186. }