ImplementationSelector
ImplementationSelector copied to clipboard
Open-source unity editor extension that allows you to automatically select inherited implementations of a base class directly on the editor.
Welcome to Implementation Selector
Welcome to Implementation Selector: a small Unity editor extension that allows you to automatically select an interface/base class's implementations directly on the editor. This is very useful for rapdily create configuration files for your applications.
data:image/s3,"s3://crabby-images/6ff3c/6ff3c98293c3d024f514275f33eab8180e1886f8" alt="Logo"
Contents
Installing
- Via Github
Download the full repositories, and then place it under the Assets folder of your Unity project.
And that's all, with that you should be ready to go!
- Via UPM
Add the following line to your manifest.json.
"dependencies": {
"com.juce.implementationselector": "git+https://github.com/Juce-Assets/Juce-ImplementationSelector",
},
Basic Usage
- SelectImplementationAttribute
You can turn an interface/base class to a selectable one using the attribute SelectImplementationAttribute. You also need to use the SerializeReference Unity attribute.
[SelectImplementation(typeof(IFood))]
[SerializeField, SerializeReference] private IFood food = default;
data:image/s3,"s3://crabby-images/10580/105804c85d777c9d0e27ab109b1949a95389dd2b" alt="Logo"
data:image/s3,"s3://crabby-images/6ff3c/6ff3c98293c3d024f514275f33eab8180e1886f8" alt="Logo"
data:image/s3,"s3://crabby-images/80b5a/80b5a283438993bf904a8570d860399c2b93e727" alt="Logo"
It works with lists too!
[SelectImplementation(typeof(IFood))]
[SerializeField, SerializeReference] private List<IFood> food = default;
data:image/s3,"s3://crabby-images/f0330/f0330c3426b7ebbb8299875caf902372a8d753ea" alt="Logo"
SelectImplementation has two default values that can be changed:
- DisplayLabel: determines if the variable name is shown on the inspector. It's enabled by default.
- ForceExpanded: determines if the properties of the class can be collapsed with a dropdown, or ar shown all the time. It's disabled by default.
[SelectImplementation(typeof(IFood), displayLabel: true, forceExpanded: false)]
[SerializeField, SerializeReference] private IFood food = default;
The classes that inherit from the base one need to be marked as serializable with the System.Serializable attribute. They also need to have the default constructor, or a public parameterless one.
[System.Serializable]
public class AppleFood : IFood
{
[SerializeField] private string appleName = default;
}
- SelectImplementationTrimDisplayName
You can use the attribute SelectImplementationTrimDisplayName, on the base interface/class, to define a string that will always be trimmed from the name displayed of the classes that implement this interface.
For example, if you have a base interface named IFood, and classes that inherit from it, like AppleFood, GrapesFood, PizzaFood, by using the SelectImplementationTrimDisplayName("Food"), the class names will be desplayed as Apple, Grapes, Pizza.
[SelectImplementationTrimDisplayName("Food")]
public interface IFood
{
}
- SelectImplementationDefaultType
You can use the attribute SelectImplementationDefaultType, on one of the classes that inherits from the base interface/class, to mark it as the default one that's going to appear on the editor the first time the user sees it.
[System.Serializable]
[SelectImplementationDefaultType]
public class AppleFood : IFood
{
[SerializeField] private string appleName = default;
}
- SelectImplementationTooltip
You can use the attribute SelectImplementationTooltip, on one of the classes that inherits from the base interface/class, to show a tooltip when the user hovers this specific type with the mouse
[System.Serializable]
[SelectImplementationTooltip("Apple tooltip")]
public class AppleFood : IFood
{
[SerializeField] private string appleName = default;
}
data:image/s3,"s3://crabby-images/9674f/9674fd66d92190cc6e95250459103687a90e4cd2" alt="Logo"
- SelectImplementationCustomDisplayName
You can use the attribute SelectImplementationCustomDisplayName, on one of the classes that inherits from the base interface/class, to show a specific name on the selection dropdown.
[System.Serializable]
[SelectImplementationCustomDisplayName("Custom Apple display")]
public class AppleFood : IFood
{
[SerializeField] private string appleName = default;
}
data:image/s3,"s3://crabby-images/3ca08/3ca080e56bd7e065e1d1e601d34f9dfa40c9dd63" alt="Logo"
We are always aiming to improve this tool. You can always leave suggestions here.
Want to contribute?
Please follow these steps to get your work merged in.
-
Clone the repo and make a new branch:
$ git checkout https://github.com/Juce-Assets/Juce-ImplementationSelector/tree/main -b [name_of_new_branch]
. -
Add a feature, fix a bug, or refactor some code :)
-
Update
README.md
contributors, if necessary. -
Open a Pull Request with a comprehensive description of changes.
Contributors
- Guillem SC - @Guillemsc
- Pere Viader - @PereViader
- Balázs K - @BallerJColt
- IvanPolovyi - @IvanPolovyi