Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/madsbangh/EasyButtons
Add buttons to your inspector in Unity super easily with this simple attribute
https://github.com/madsbangh/EasyButtons
unity unity-editor unity3d
Last synced: 2 months ago
JSON representation
Add buttons to your inspector in Unity super easily with this simple attribute
- Host: GitHub
- URL: https://github.com/madsbangh/EasyButtons
- Owner: madsbangh
- License: mit
- Created: 2017-03-08T21:19:10.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2023-09-14T19:12:30.000Z (over 1 year ago)
- Last Synced: 2024-10-29T17:11:57.610Z (2 months ago)
- Topics: unity, unity-editor, unity3d
- Language: C#
- Size: 198 KB
- Stars: 1,087
- Watchers: 26
- Forks: 83
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-unity3d-study - EasyButtons - argument method. (三 开源库 / Editor)
- awesome-unity3d - EasyButtons - Add buttons to your inspector in Unity super easily with this simple attribute (Open Source Repositories / Editor)
README
# Easy buttons for the Unity default inspector
[![openupm](https://img.shields.io/npm/v/com.madsbangh.easybuttons?label=openupm®istry_uri=https://package.openupm.com)](https://openupm.com/packages/com.madsbangh.easybuttons/)These tiny scripts add the ability to quickly show a button in the inspector for any method.
## Installation
### OpenUPM
Once you have the OpenUPM cli, run the following command:
```openupm install com.madsbangh.easybuttons```
Or if you don't have it, add the scoped registry to manifest.json with the desired version:
```json
"scopedRegistries": [
{
"name": "package.openupm.com",
"url": "https://package.openupm.com",
"scopes": [
"com.madsbangh.easybuttons",
"com.openupm"
]
}
],
"dependencies": {
"com.madsbangh.easybuttons": "1.4.0"
}
```### Git URL
Project supports Unity Package Manager. To install the project as a Git package do the following:
1. In Unity, open **Window** -> **Package Manager**.
2. Press the **+** button, choose "**Add package from git URL...**"
3. Enter "https://github.com/madsbangh/EasyButtons.git#upm" and press **Add**.### Unity Package
Alternatively, you can add the code directly to the project:1. Clone the repo or download the latest release.
2. Add the EasyButtons folder to your Unity project or import the .unitypackage## How To Use
1. Add the Button attribute to a method.```csharp
using EasyButtons; // 1. Import the namespace
using UnityEngine;
public class ButtonsExample : MonoBehaviour
{
// 2. Add the Button attribute to any method.
[Button]
public void SayHello()
{
Debug.Log("Hello");
}
}
```
2. You should now see a button at the top of the component with the same name as the method:![Button in the inspector](/Images/inspector.png)
![Result](/Images/console.png)
3. Add the Button attribute to a method with parameters.
```csharp
using EasyButtons;
using UnityEngine;
public class Test : MonoBehaviour
{
[Button]
public void ButtonWithParameters(string message, int number)
{
Debug.Log($"Your message #{number}: '{message}'");
}
}
```4. You can now enter parameter values and invoke the method in the inspector:
![Button with parameters](/Images/parameters.png)
## Attribute Options
The `Button` attribute has different options that allow customizing the button look.
***Mode*** - indicates when the button is enabled. You can choose between the following options:
- AlwaysEnabled - the button is enabled in edit mode and play mode.
- EnabledInPlayMode - the button is only enabled in play mode.
- DisabledInPlayMode - the button is only enabled in edit mode.
***Spacing*** - allows to have some space before or after the button. The following options can be used:
- None - no spacing at all.
- Before - adds space above the button.
- After - adds space below the button.
***Expanded*** - whether to expand the parameters foldout by default. It only works with buttons that have parameters.
## Custom Editors
If you want to show buttons in a custom editor, you can use the **ButtonsDrawer** class defined in EasyButtons.Editor.
Instantiate ButtonsDrawer in OnEnable if possible, then draw the buttons with help of the DrawButtons method, as in the example:
```csharp
[CustomEditor(typeof(Example))]
public class CustomEditor : ObjectEditor
{
private ButtonsDrawer _buttonsDrawer;private void OnEnable()
{
_buttonsDrawer = new ButtonsDrawer(target);
}public override void OnInspectorGUI()
{
DrawDefaultInspector();
_buttonsDrawer.DrawButtons(targets);
}
}
```You can also draw only specific buttons:
```csharp
// Draw only the button called "Custom Editor Example"
_buttonsDrawers.Buttons.First(button => button.DisplayName == "Custom Editor Example").Draw(targets);
```You can search for a specific button using its ***DisplayName*** or ***Method*** (MethodInfo object the button is attached to.)
## Notes
- Older versions of Unity might not understand the reference to EasyButtons runtime in the EasyButtons editor assembly definition. If you experience issues, you can re-add the reference, or remove the asmdefs completely.