How to make a spigot plugin!
Installing Prerequisites
How to install Java
When we create a plugin we need the Java SE JDK. This is the development kit for Java. You can find the download here, make sure you install the correct version for your operating system.
How to install Eclipse
Eclipse is a Java IDE, we will be using eclipse to develop and build our plugins. You can find the download here.
Once you have downloaded eclipse,
select the first option, Eclipse IDE for Java Developers, to install our needed IDE.
How to download the Spigot Development Package (Build Tools)
We will also need the spigot package to be able to develop a plugin.
We will download the latest successful build, here. Put this file inside a folder somewhere accessible, I will put this on my desktop.
- Open the terminal by searching CMD inside the windows menu.
- Inside the terminal using cd, navigate to the folder you put the BuildTools.jar file in.
- cd ~YOUR PATH~
- Run the command `java -jar BuildTools.jar`
- This will probably open an installer for GIT, just be patient it might take awhile.
Lets create the actual plugin!
Open up eclipse. This will ask for a workspace folder, I recommend using the default folder.
Creating the project
- Press File - New - Java Project
- In the Project Name, type in the name of your project, I will just be using Test Plugin.
- Keep everything else the same and click next.
- Click the Libraries tab, and then Add External JARs
- Navigate to where you saved the BuildTools.jar file, then navigate to Spigot/Spigot-API/target
- Select the file called Spigot-api-%VERSION%-R0.1-SNAPSHOT-shaded.jar
- Toggle the dropdown next to the file you just imported
- In the Javadoc location type https://hub.spigotmc.org/javadocs/spigot/
- Click Finish
Creating a Package
- Press File - New - Package
- In the source folder, select Browse, then navigate to the project you just created, then src.
- Type in the name of your package. Packages are usually structured like com.name.plugin. But this is usually done when you have a website at name.com. I will just use me.Noordo.testplugin.
- Click Finish
Creating the main class
- Press File - New - Class
- In the name, type in Main
- Click on Browse next to the Superclass, and search for JavaPlugin. Select the one from org.bukkit.plugin.java.
- Click Finish
Lets get coding!
We will first add two classes for when the plugin is loaded, and when it is unloaded, and we will use the getServer().getConsoleSender() to reference our console. We can then use this to send a message to the console when the plugin is loaded, we can also use ChatColor.RED to make the text Red!
package me.noordo.testplugin;
import org.bukkit.command.ConsoleCommandSender;
import org.bukkit.plugin.java.JavaPlugin;
import net.md_5.bungee.api.ChatColor;
public class Main extends JavaPlugin {
@Override
public void onEnable() {
ConsoleCommandSender console = getServer().getConsoleSender();
console.sendMessage(ChatColor.RED + "Plugin works!");
}
@Override
public void onDisable() {
}
}
Creating the plugin.yml
We need a plugin.yml to tell the server about our plugin. This includes what commands we have, who the author is. what the name is and what the description is.
- Press File - New - File
- Select the src folder
- In the name type in plugin.yml
- This should open an external file editor, but if you wish to use eclipse double click on the plugin.yml and select OK. This should open the marketplace where you can download Yaml Editor.
- Type in the following, replace me.noordo.testplugin to what you called your package earlier, you can replace everything else to suit your needs.
main: me.noordo.testplugin.Main
name: TestPlugin
version: 1.0
author: Noordo
description: A Test Plugin
We will put commands in here in a later tutorial.Building the plugin!
- Right click on the project we created earlier, mine is called Test Plugin.
- Select Export
- Dropdown Java
- Select Jar File and click Next
- Make sure your plugin is selected
- Click Browse and navigate to where you want to save the file, and type the name as well
- Select Finish
Woohoo, we finished! You can now drop this plugin into your own server. If you start the server you should be able to see 'Plugin Works!' in the console
Comments
Post a Comment