S&box Wiki

Revision Difference

Components#563217

<cat>Code.Game</cat> <title>Components</title> # Components Components are bits of functionality you can add to [GameObjects](https://wiki.facepunch.com/sbox/GameObjects). You can create a component to do anything you wish. There are also numerous components that exist in the s&box engine by default. You can find a list of example components within the [sbox-scenestaging repo](https://github.com/Facepunch/sbox-scenestaging/tree/main/code/ExampleComponents) on Facepunch's GitHub. Components are bits of functionality you can add to [GameObjects](https://wiki.facepunch.com/sbox/GameObjects). You can create a component to do anything you wish. There are also numerous components that exist in the s&box engine by default. You can find a list of example components within the [sbox-scenestaging repo](https://github.com/Facepunch/sbox-scenestaging/tree/main/Code/ExampleComponents) on Facepunch's GitHub. ## Properties An attribute `[Property]` can be added to a [property member](https://learn.microsoft.com/en-us/dotnet/csharp/programming-guide/classes-and-structs/properties) on your component class, which allows you to slot in information about the property outside of code. This allows your component to be more re-usable. ```cs public sealed class Health : Component { // MaxHealth can be changed within the editor now, but defaults to 100f. [Property] public float MaxHealth { get; set; } = 100f; public float CurrentHealth { get; set; } protected override void OnStart() { // Set current health to max health when this component starts up CurrentHealth = MaxHealth; } } ``` See the [Attributes and Component Properties](https://wiki.facepunch.com/sbox/Property) page for more info and examples. ## Methods There are a number of methods you can override when making your own component. You can find a full list [here](https://docs.facepunch.com/s/sbox-dev/doc/component-methods-OCvoNh8ByW). Below is an example of overriding a method. There are a number of methods you can override when making your own component. You can find a full list [here](https://sbox.game/dev/doc/the-scene-system/components/component-methods/). Below is an example of overriding a method. ```cs public sealed class MyComponent : Component { // OnUpdate is called every frame protected override void OnUpdate() { LocalRotation = Rotation.Random; } } ``` ## Enabling and Disabling You can enable or disable a component through code. When a component is disabled, methods like OnUpdate, OnFixedUpdate, and more are skipped. Whenever you enable a component, OnStart and OnEnabled will be called (in that order). Disabling a component calls OnDisabled. ```cs var comp = Components.Get<Health>(); if ( comp.CurrentHealth <= 0 ) { // Will trigger OnDisabled on Health comp.Enabled = false; } ``` ## Managing a Component on a GameObject Most often, you will want to add components to a GameObject outside of the codebase (through the scene editor). But sometimes, there are cases you want to add to or remove from a GameObject directly. ```cs // Gets Health, or creates it if it does not exist. var comp = Components.GetOrCreate<Health>(); ``` From within a component, many properties of a GameObject (such as Transform, Components, Scene, etc) are exposed for you for convenience. ```cs public sealed class MyComponent : Component { protected override void OnStart() { // Changing the Transform on a Component simply adjusts the Transform of the GameObject. WorldPosition = new Vector3( 10f, 0f, 10f ); if ( Components.TryGet( out Health health, FindMode.EnabledInSelfAndChildren ) ) health.Destroy(); } } ```