@dcl/protocol 1.0.0-11780504028.commit-c886080 → 1.0.0-11858567019.commit-f8ad8ea

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (62) hide show
  1. package/out-js/decentraland/common/texture.gen.d.ts +18 -0
  2. package/out-js/decentraland/common/texture.gen.js +104 -4
  3. package/out-js/decentraland/common/texture.gen.js.map +1 -1
  4. package/out-js/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +41 -0
  5. package/out-js/decentraland/sdk/components/avatar_modifier_area.gen.js +241 -3
  6. package/out-js/decentraland/sdk/components/avatar_modifier_area.gen.js.map +1 -1
  7. package/out-js/decentraland/sdk/components/camera_mode_area.gen.d.ts +35 -1
  8. package/out-js/decentraland/sdk/components/camera_mode_area.gen.js +172 -3
  9. package/out-js/decentraland/sdk/components/camera_mode_area.gen.js.map +1 -1
  10. package/out-js/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +19 -0
  11. package/out-js/decentraland/sdk/components/gltf_container_loading_state.gen.js +90 -3
  12. package/out-js/decentraland/sdk/components/gltf_container_loading_state.gen.js.map +1 -1
  13. package/out-js/decentraland/sdk/components/gltf_node.gen.d.ts +66 -0
  14. package/out-js/decentraland/sdk/components/gltf_node.gen.js +69 -0
  15. package/out-js/decentraland/sdk/components/gltf_node.gen.js.map +1 -0
  16. package/out-js/decentraland/sdk/components/gltf_node_state.gen.d.ts +43 -0
  17. package/out-js/decentraland/sdk/components/gltf_node_state.gen.js +122 -0
  18. package/out-js/decentraland/sdk/components/gltf_node_state.gen.js.map +1 -0
  19. package/out-js/decentraland/sdk/components/material.gen.d.ts +20 -0
  20. package/out-js/decentraland/sdk/components/material.gen.js +86 -2
  21. package/out-js/decentraland/sdk/components/material.gen.js.map +1 -1
  22. package/out-js/decentraland/sdk/components/mesh_collider.gen.d.ts +18 -0
  23. package/out-js/decentraland/sdk/components/mesh_collider.gen.js +90 -4
  24. package/out-js/decentraland/sdk/components/mesh_collider.gen.js.map +1 -1
  25. package/out-js/decentraland/sdk/components/mesh_renderer.gen.d.ts +19 -3
  26. package/out-js/decentraland/sdk/components/mesh_renderer.gen.js +90 -4
  27. package/out-js/decentraland/sdk/components/mesh_renderer.gen.js.map +1 -1
  28. package/out-js/decentraland/sdk/components/ui_text.gen.d.ts +4 -0
  29. package/out-js/decentraland/sdk/components/ui_text.gen.js +30 -1
  30. package/out-js/decentraland/sdk/components/ui_text.gen.js.map +1 -1
  31. package/out-js/decentraland/sdk/components/ui_transform.gen.d.ts +35 -0
  32. package/out-js/decentraland/sdk/components/ui_transform.gen.js +188 -2
  33. package/out-js/decentraland/sdk/components/ui_transform.gen.js.map +1 -1
  34. package/out-ts/decentraland/common/texture.gen.ts +119 -4
  35. package/out-ts/decentraland/sdk/components/avatar_modifier_area.gen.ts +292 -1
  36. package/out-ts/decentraland/sdk/components/camera_mode_area.gen.ts +218 -2
  37. package/out-ts/decentraland/sdk/components/gltf_container_loading_state.gen.ts +108 -2
  38. package/out-ts/decentraland/sdk/components/gltf_node.gen.ts +116 -0
  39. package/out-ts/decentraland/sdk/components/gltf_node_state.gen.ts +139 -0
  40. package/out-ts/decentraland/sdk/components/material.gen.ts +102 -1
  41. package/out-ts/decentraland/sdk/components/mesh_collider.gen.ts +99 -0
  42. package/out-ts/decentraland/sdk/components/mesh_renderer.gen.ts +100 -3
  43. package/out-ts/decentraland/sdk/components/ui_text.gen.ts +40 -1
  44. package/out-ts/decentraland/sdk/components/ui_transform.gen.ts +212 -1
  45. package/package.json +2 -2
  46. package/proto/decentraland/common/texture.proto +8 -1
  47. package/proto/decentraland/sdk/components/avatar_modifier_area.proto +21 -0
  48. package/proto/decentraland/sdk/components/camera_mode_area.proto +22 -3
  49. package/proto/decentraland/sdk/components/global_light.proto +22 -0
  50. package/proto/decentraland/sdk/components/gltf_container_loading_state.proto +13 -0
  51. package/proto/decentraland/sdk/components/gltf_node.proto +42 -0
  52. package/proto/decentraland/sdk/components/gltf_node_state.proto +20 -0
  53. package/proto/decentraland/sdk/components/light.proto +42 -0
  54. package/proto/decentraland/sdk/components/material.proto +11 -0
  55. package/proto/decentraland/sdk/components/mesh_collider.proto +8 -1
  56. package/proto/decentraland/sdk/components/mesh_renderer.proto +8 -3
  57. package/proto/decentraland/sdk/components/spotlight.proto +21 -0
  58. package/proto/decentraland/sdk/components/ui_canvas.proto +16 -0
  59. package/proto/decentraland/sdk/components/ui_scroll_result.proto +12 -0
  60. package/proto/decentraland/sdk/components/ui_text.proto +3 -0
  61. package/proto/decentraland/sdk/components/ui_transform.proto +21 -0
  62. package/public/sdk-components.proto +2 -0
@@ -123,11 +123,23 @@ export interface VideoTexture {
123
123
  filterMode?: TextureFilterMode | undefined;
124
124
  }
125
125
 
126
+ export interface UiCanvasTexture {
127
+ uiCanvasEntity: number;
128
+ /** default = TextureWrapMode.Clamp */
129
+ wrapMode?:
130
+ | TextureWrapMode
131
+ | undefined;
132
+ /** default = FilterMode.Bilinear */
133
+ filterMode?: TextureFilterMode | undefined;
134
+ }
135
+
126
136
  export interface TextureUnion {
127
- tex?: { $case: "texture"; texture: Texture } | { $case: "avatarTexture"; avatarTexture: AvatarTexture } | {
128
- $case: "videoTexture";
129
- videoTexture: VideoTexture;
130
- } | undefined;
137
+ tex?:
138
+ | { $case: "texture"; texture: Texture }
139
+ | { $case: "avatarTexture"; avatarTexture: AvatarTexture }
140
+ | { $case: "videoTexture"; videoTexture: VideoTexture }
141
+ | { $case: "uiTexture"; uiTexture: UiCanvasTexture }
142
+ | undefined;
131
143
  }
132
144
 
133
145
  function createBaseTexture(): Texture {
@@ -418,6 +430,92 @@ export namespace VideoTexture {
418
430
  }
419
431
  }
420
432
 
433
+ function createBaseUiCanvasTexture(): UiCanvasTexture {
434
+ return { uiCanvasEntity: 0, wrapMode: undefined, filterMode: undefined };
435
+ }
436
+
437
+ export namespace UiCanvasTexture {
438
+ export function encode(message: UiCanvasTexture, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
439
+ if (message.uiCanvasEntity !== 0) {
440
+ writer.uint32(8).uint32(message.uiCanvasEntity);
441
+ }
442
+ if (message.wrapMode !== undefined) {
443
+ writer.uint32(16).int32(message.wrapMode);
444
+ }
445
+ if (message.filterMode !== undefined) {
446
+ writer.uint32(24).int32(message.filterMode);
447
+ }
448
+ return writer;
449
+ }
450
+
451
+ export function decode(input: _m0.Reader | Uint8Array, length?: number): UiCanvasTexture {
452
+ const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
453
+ let end = length === undefined ? reader.len : reader.pos + length;
454
+ const message = createBaseUiCanvasTexture();
455
+ while (reader.pos < end) {
456
+ const tag = reader.uint32();
457
+ switch (tag >>> 3) {
458
+ case 1:
459
+ if (tag !== 8) {
460
+ break;
461
+ }
462
+
463
+ message.uiCanvasEntity = reader.uint32();
464
+ continue;
465
+ case 2:
466
+ if (tag !== 16) {
467
+ break;
468
+ }
469
+
470
+ message.wrapMode = reader.int32() as any;
471
+ continue;
472
+ case 3:
473
+ if (tag !== 24) {
474
+ break;
475
+ }
476
+
477
+ message.filterMode = reader.int32() as any;
478
+ continue;
479
+ }
480
+ if ((tag & 7) === 4 || tag === 0) {
481
+ break;
482
+ }
483
+ reader.skipType(tag & 7);
484
+ }
485
+ return message;
486
+ }
487
+
488
+ export function fromJSON(object: any): UiCanvasTexture {
489
+ return {
490
+ uiCanvasEntity: isSet(object.uiCanvasEntity) ? Number(object.uiCanvasEntity) : 0,
491
+ wrapMode: isSet(object.wrapMode) ? textureWrapModeFromJSON(object.wrapMode) : undefined,
492
+ filterMode: isSet(object.filterMode) ? textureFilterModeFromJSON(object.filterMode) : undefined,
493
+ };
494
+ }
495
+
496
+ export function toJSON(message: UiCanvasTexture): unknown {
497
+ const obj: any = {};
498
+ message.uiCanvasEntity !== undefined && (obj.uiCanvasEntity = Math.round(message.uiCanvasEntity));
499
+ message.wrapMode !== undefined &&
500
+ (obj.wrapMode = message.wrapMode !== undefined ? textureWrapModeToJSON(message.wrapMode) : undefined);
501
+ message.filterMode !== undefined &&
502
+ (obj.filterMode = message.filterMode !== undefined ? textureFilterModeToJSON(message.filterMode) : undefined);
503
+ return obj;
504
+ }
505
+
506
+ export function create<I extends Exact<DeepPartial<UiCanvasTexture>, I>>(base?: I): UiCanvasTexture {
507
+ return UiCanvasTexture.fromPartial(base ?? {});
508
+ }
509
+
510
+ export function fromPartial<I extends Exact<DeepPartial<UiCanvasTexture>, I>>(object: I): UiCanvasTexture {
511
+ const message = createBaseUiCanvasTexture();
512
+ message.uiCanvasEntity = object.uiCanvasEntity ?? 0;
513
+ message.wrapMode = object.wrapMode ?? undefined;
514
+ message.filterMode = object.filterMode ?? undefined;
515
+ return message;
516
+ }
517
+ }
518
+
421
519
  function createBaseTextureUnion(): TextureUnion {
422
520
  return { tex: undefined };
423
521
  }
@@ -434,6 +532,9 @@ export namespace TextureUnion {
434
532
  case "videoTexture":
435
533
  VideoTexture.encode(message.tex.videoTexture, writer.uint32(26).fork()).ldelim();
436
534
  break;
535
+ case "uiTexture":
536
+ UiCanvasTexture.encode(message.tex.uiTexture, writer.uint32(34).fork()).ldelim();
537
+ break;
437
538
  }
438
539
  return writer;
439
540
  }
@@ -466,6 +567,13 @@ export namespace TextureUnion {
466
567
 
467
568
  message.tex = { $case: "videoTexture", videoTexture: VideoTexture.decode(reader, reader.uint32()) };
468
569
  continue;
570
+ case 4:
571
+ if (tag !== 34) {
572
+ break;
573
+ }
574
+
575
+ message.tex = { $case: "uiTexture", uiTexture: UiCanvasTexture.decode(reader, reader.uint32()) };
576
+ continue;
469
577
  }
470
578
  if ((tag & 7) === 4 || tag === 0) {
471
579
  break;
@@ -483,6 +591,8 @@ export namespace TextureUnion {
483
591
  ? { $case: "avatarTexture", avatarTexture: AvatarTexture.fromJSON(object.avatarTexture) }
484
592
  : isSet(object.videoTexture)
485
593
  ? { $case: "videoTexture", videoTexture: VideoTexture.fromJSON(object.videoTexture) }
594
+ : isSet(object.uiTexture)
595
+ ? { $case: "uiTexture", uiTexture: UiCanvasTexture.fromJSON(object.uiTexture) }
486
596
  : undefined,
487
597
  };
488
598
  }
@@ -495,6 +605,8 @@ export namespace TextureUnion {
495
605
  (obj.avatarTexture = message.tex?.avatarTexture ? AvatarTexture.toJSON(message.tex?.avatarTexture) : undefined);
496
606
  message.tex?.$case === "videoTexture" &&
497
607
  (obj.videoTexture = message.tex?.videoTexture ? VideoTexture.toJSON(message.tex?.videoTexture) : undefined);
608
+ message.tex?.$case === "uiTexture" &&
609
+ (obj.uiTexture = message.tex?.uiTexture ? UiCanvasTexture.toJSON(message.tex?.uiTexture) : undefined);
498
610
  return obj;
499
611
  }
500
612
 
@@ -521,6 +633,9 @@ export namespace TextureUnion {
521
633
  ) {
522
634
  message.tex = { $case: "videoTexture", videoTexture: VideoTexture.fromPartial(object.tex.videoTexture) };
523
635
  }
636
+ if (object.tex?.$case === "uiTexture" && object.tex?.uiTexture !== undefined && object.tex?.uiTexture !== null) {
637
+ message.tex = { $case: "uiTexture", uiTexture: UiCanvasTexture.fromPartial(object.tex.uiTexture) };
638
+ }
524
639
  return message;
525
640
  }
526
641
  }
@@ -40,6 +40,48 @@ export function avatarModifierTypeToJSON(object: AvatarModifierType): string {
40
40
  }
41
41
  }
42
42
 
43
+ export enum AvatarControlType {
44
+ /** CCT_NONE - avatar cannot move */
45
+ CCT_NONE = 0,
46
+ /** CCT_RELATIVE - avatar moves relative to the camera origin */
47
+ CCT_RELATIVE = 1,
48
+ /** CCT_TANK - avatar moves like a tank: left/right rotate the player, forward/backward advance/retreat the player */
49
+ CCT_TANK = 2,
50
+ UNRECOGNIZED = -1,
51
+ }
52
+
53
+ export function avatarControlTypeFromJSON(object: any): AvatarControlType {
54
+ switch (object) {
55
+ case 0:
56
+ case "CCT_NONE":
57
+ return AvatarControlType.CCT_NONE;
58
+ case 1:
59
+ case "CCT_RELATIVE":
60
+ return AvatarControlType.CCT_RELATIVE;
61
+ case 2:
62
+ case "CCT_TANK":
63
+ return AvatarControlType.CCT_TANK;
64
+ case -1:
65
+ case "UNRECOGNIZED":
66
+ default:
67
+ return AvatarControlType.UNRECOGNIZED;
68
+ }
69
+ }
70
+
71
+ export function avatarControlTypeToJSON(object: AvatarControlType): string {
72
+ switch (object) {
73
+ case AvatarControlType.CCT_NONE:
74
+ return "CCT_NONE";
75
+ case AvatarControlType.CCT_RELATIVE:
76
+ return "CCT_RELATIVE";
77
+ case AvatarControlType.CCT_TANK:
78
+ return "CCT_TANK";
79
+ case AvatarControlType.UNRECOGNIZED:
80
+ default:
81
+ return "UNRECOGNIZED";
82
+ }
83
+ }
84
+
43
85
  /**
44
86
  * The AvatarModifierArea component can be attached to an Entity to define a region of space where
45
87
  * avatar behavior changes.
@@ -63,10 +105,51 @@ export interface PBAvatarModifierArea {
63
105
  excludeIds: string[];
64
106
  /** list of modifiers to apply */
65
107
  modifiers: AvatarModifierType[];
108
+ movementSettings?:
109
+ | AvatarMovementSettings
110
+ | undefined;
111
+ /** if true, the player will be considered inside the area when they are within 0.3m of the area. default true */
112
+ useColliderRange?: boolean | undefined;
113
+ }
114
+
115
+ export interface AvatarMovementSettings {
116
+ controlMode?:
117
+ | AvatarControlType
118
+ | undefined;
119
+ /** if not explicitly set, the following properties default to user's preference settings */
120
+ runSpeed?:
121
+ | number
122
+ | undefined;
123
+ /** how fast the player gets up to speed or comes to rest. higher = more responsive */
124
+ friction?:
125
+ | number
126
+ | undefined;
127
+ /** how fast the player accelerates vertically when not on a solid surface, in m/s. should normally be negative */
128
+ gravity?:
129
+ | number
130
+ | undefined;
131
+ /** how high the player can jump, in meters. should normally be positive. gravity must have the same sign for jumping to be possible */
132
+ jumpHeight?:
133
+ | number
134
+ | undefined;
135
+ /** max fall speed in m/s. should normally be negative */
136
+ maxFallSpeed?:
137
+ | number
138
+ | undefined;
139
+ /** speed the player turns in tank mode, in radians/s */
140
+ turnSpeed?:
141
+ | number
142
+ | undefined;
143
+ /** speed the player walks at, in m/s */
144
+ walkSpeed?:
145
+ | number
146
+ | undefined;
147
+ /** whether to allow player to move at a slower speed (e.g. with a walk-key or when using a gamepad/joystick). defaults to true */
148
+ allowWeightedMovement?: boolean | undefined;
66
149
  }
67
150
 
68
151
  function createBasePBAvatarModifierArea(): PBAvatarModifierArea {
69
- return { area: undefined, excludeIds: [], modifiers: [] };
152
+ return { area: undefined, excludeIds: [], modifiers: [], movementSettings: undefined, useColliderRange: undefined };
70
153
  }
71
154
 
72
155
  export namespace PBAvatarModifierArea {
@@ -82,6 +165,12 @@ export namespace PBAvatarModifierArea {
82
165
  writer.int32(v);
83
166
  }
84
167
  writer.ldelim();
168
+ if (message.movementSettings !== undefined) {
169
+ AvatarMovementSettings.encode(message.movementSettings, writer.uint32(34).fork()).ldelim();
170
+ }
171
+ if (message.useColliderRange !== undefined) {
172
+ writer.uint32(40).bool(message.useColliderRange);
173
+ }
85
174
  return writer;
86
175
  }
87
176
 
@@ -123,6 +212,20 @@ export namespace PBAvatarModifierArea {
123
212
  }
124
213
 
125
214
  break;
215
+ case 4:
216
+ if (tag !== 34) {
217
+ break;
218
+ }
219
+
220
+ message.movementSettings = AvatarMovementSettings.decode(reader, reader.uint32());
221
+ continue;
222
+ case 5:
223
+ if (tag !== 40) {
224
+ break;
225
+ }
226
+
227
+ message.useColliderRange = reader.bool();
228
+ continue;
126
229
  }
127
230
  if ((tag & 7) === 4 || tag === 0) {
128
231
  break;
@@ -139,6 +242,10 @@ export namespace PBAvatarModifierArea {
139
242
  modifiers: Array.isArray(object?.modifiers)
140
243
  ? object.modifiers.map((e: any) => avatarModifierTypeFromJSON(e))
141
244
  : [],
245
+ movementSettings: isSet(object.movementSettings)
246
+ ? AvatarMovementSettings.fromJSON(object.movementSettings)
247
+ : undefined,
248
+ useColliderRange: isSet(object.useColliderRange) ? Boolean(object.useColliderRange) : undefined,
142
249
  };
143
250
  }
144
251
 
@@ -155,6 +262,11 @@ export namespace PBAvatarModifierArea {
155
262
  } else {
156
263
  obj.modifiers = [];
157
264
  }
265
+ message.movementSettings !== undefined &&
266
+ (obj.movementSettings = message.movementSettings
267
+ ? AvatarMovementSettings.toJSON(message.movementSettings)
268
+ : undefined);
269
+ message.useColliderRange !== undefined && (obj.useColliderRange = message.useColliderRange);
158
270
  return obj;
159
271
  }
160
272
 
@@ -167,6 +279,185 @@ export namespace PBAvatarModifierArea {
167
279
  message.area = (object.area !== undefined && object.area !== null) ? Vector3.fromPartial(object.area) : undefined;
168
280
  message.excludeIds = object.excludeIds?.map((e) => e) || [];
169
281
  message.modifiers = object.modifiers?.map((e) => e) || [];
282
+ message.movementSettings = (object.movementSettings !== undefined && object.movementSettings !== null)
283
+ ? AvatarMovementSettings.fromPartial(object.movementSettings)
284
+ : undefined;
285
+ message.useColliderRange = object.useColliderRange ?? undefined;
286
+ return message;
287
+ }
288
+ }
289
+
290
+ function createBaseAvatarMovementSettings(): AvatarMovementSettings {
291
+ return {
292
+ controlMode: undefined,
293
+ runSpeed: undefined,
294
+ friction: undefined,
295
+ gravity: undefined,
296
+ jumpHeight: undefined,
297
+ maxFallSpeed: undefined,
298
+ turnSpeed: undefined,
299
+ walkSpeed: undefined,
300
+ allowWeightedMovement: undefined,
301
+ };
302
+ }
303
+
304
+ export namespace AvatarMovementSettings {
305
+ export function encode(message: AvatarMovementSettings, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
306
+ if (message.controlMode !== undefined) {
307
+ writer.uint32(8).int32(message.controlMode);
308
+ }
309
+ if (message.runSpeed !== undefined) {
310
+ writer.uint32(21).float(message.runSpeed);
311
+ }
312
+ if (message.friction !== undefined) {
313
+ writer.uint32(29).float(message.friction);
314
+ }
315
+ if (message.gravity !== undefined) {
316
+ writer.uint32(37).float(message.gravity);
317
+ }
318
+ if (message.jumpHeight !== undefined) {
319
+ writer.uint32(45).float(message.jumpHeight);
320
+ }
321
+ if (message.maxFallSpeed !== undefined) {
322
+ writer.uint32(53).float(message.maxFallSpeed);
323
+ }
324
+ if (message.turnSpeed !== undefined) {
325
+ writer.uint32(61).float(message.turnSpeed);
326
+ }
327
+ if (message.walkSpeed !== undefined) {
328
+ writer.uint32(69).float(message.walkSpeed);
329
+ }
330
+ if (message.allowWeightedMovement !== undefined) {
331
+ writer.uint32(72).bool(message.allowWeightedMovement);
332
+ }
333
+ return writer;
334
+ }
335
+
336
+ export function decode(input: _m0.Reader | Uint8Array, length?: number): AvatarMovementSettings {
337
+ const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
338
+ let end = length === undefined ? reader.len : reader.pos + length;
339
+ const message = createBaseAvatarMovementSettings();
340
+ while (reader.pos < end) {
341
+ const tag = reader.uint32();
342
+ switch (tag >>> 3) {
343
+ case 1:
344
+ if (tag !== 8) {
345
+ break;
346
+ }
347
+
348
+ message.controlMode = reader.int32() as any;
349
+ continue;
350
+ case 2:
351
+ if (tag !== 21) {
352
+ break;
353
+ }
354
+
355
+ message.runSpeed = reader.float();
356
+ continue;
357
+ case 3:
358
+ if (tag !== 29) {
359
+ break;
360
+ }
361
+
362
+ message.friction = reader.float();
363
+ continue;
364
+ case 4:
365
+ if (tag !== 37) {
366
+ break;
367
+ }
368
+
369
+ message.gravity = reader.float();
370
+ continue;
371
+ case 5:
372
+ if (tag !== 45) {
373
+ break;
374
+ }
375
+
376
+ message.jumpHeight = reader.float();
377
+ continue;
378
+ case 6:
379
+ if (tag !== 53) {
380
+ break;
381
+ }
382
+
383
+ message.maxFallSpeed = reader.float();
384
+ continue;
385
+ case 7:
386
+ if (tag !== 61) {
387
+ break;
388
+ }
389
+
390
+ message.turnSpeed = reader.float();
391
+ continue;
392
+ case 8:
393
+ if (tag !== 69) {
394
+ break;
395
+ }
396
+
397
+ message.walkSpeed = reader.float();
398
+ continue;
399
+ case 9:
400
+ if (tag !== 72) {
401
+ break;
402
+ }
403
+
404
+ message.allowWeightedMovement = reader.bool();
405
+ continue;
406
+ }
407
+ if ((tag & 7) === 4 || tag === 0) {
408
+ break;
409
+ }
410
+ reader.skipType(tag & 7);
411
+ }
412
+ return message;
413
+ }
414
+
415
+ export function fromJSON(object: any): AvatarMovementSettings {
416
+ return {
417
+ controlMode: isSet(object.controlMode) ? avatarControlTypeFromJSON(object.controlMode) : undefined,
418
+ runSpeed: isSet(object.runSpeed) ? Number(object.runSpeed) : undefined,
419
+ friction: isSet(object.friction) ? Number(object.friction) : undefined,
420
+ gravity: isSet(object.gravity) ? Number(object.gravity) : undefined,
421
+ jumpHeight: isSet(object.jumpHeight) ? Number(object.jumpHeight) : undefined,
422
+ maxFallSpeed: isSet(object.maxFallSpeed) ? Number(object.maxFallSpeed) : undefined,
423
+ turnSpeed: isSet(object.turnSpeed) ? Number(object.turnSpeed) : undefined,
424
+ walkSpeed: isSet(object.walkSpeed) ? Number(object.walkSpeed) : undefined,
425
+ allowWeightedMovement: isSet(object.allowWeightedMovement) ? Boolean(object.allowWeightedMovement) : undefined,
426
+ };
427
+ }
428
+
429
+ export function toJSON(message: AvatarMovementSettings): unknown {
430
+ const obj: any = {};
431
+ message.controlMode !== undefined &&
432
+ (obj.controlMode = message.controlMode !== undefined ? avatarControlTypeToJSON(message.controlMode) : undefined);
433
+ message.runSpeed !== undefined && (obj.runSpeed = message.runSpeed);
434
+ message.friction !== undefined && (obj.friction = message.friction);
435
+ message.gravity !== undefined && (obj.gravity = message.gravity);
436
+ message.jumpHeight !== undefined && (obj.jumpHeight = message.jumpHeight);
437
+ message.maxFallSpeed !== undefined && (obj.maxFallSpeed = message.maxFallSpeed);
438
+ message.turnSpeed !== undefined && (obj.turnSpeed = message.turnSpeed);
439
+ message.walkSpeed !== undefined && (obj.walkSpeed = message.walkSpeed);
440
+ message.allowWeightedMovement !== undefined && (obj.allowWeightedMovement = message.allowWeightedMovement);
441
+ return obj;
442
+ }
443
+
444
+ export function create<I extends Exact<DeepPartial<AvatarMovementSettings>, I>>(base?: I): AvatarMovementSettings {
445
+ return AvatarMovementSettings.fromPartial(base ?? {});
446
+ }
447
+
448
+ export function fromPartial<I extends Exact<DeepPartial<AvatarMovementSettings>, I>>(
449
+ object: I,
450
+ ): AvatarMovementSettings {
451
+ const message = createBaseAvatarMovementSettings();
452
+ message.controlMode = object.controlMode ?? undefined;
453
+ message.runSpeed = object.runSpeed ?? undefined;
454
+ message.friction = object.friction ?? undefined;
455
+ message.gravity = object.gravity ?? undefined;
456
+ message.jumpHeight = object.jumpHeight ?? undefined;
457
+ message.maxFallSpeed = object.maxFallSpeed ?? undefined;
458
+ message.turnSpeed = object.turnSpeed ?? undefined;
459
+ message.walkSpeed = object.walkSpeed ?? undefined;
460
+ message.allowWeightedMovement = object.allowWeightedMovement ?? undefined;
170
461
  return message;
171
462
  }
172
463
  }