Developer API
MCHockey provides a comprehensive API for developers to integrate with the plugin programmatically.
Installation Required
The API is not published to Maven Central. You must reference the MCHockey.jar file directly in your project.
🚀 Quick Setup
1. Plugin Dependency
Add MCHockey as a soft dependency in your plugin.yml:
softdepend: [ MCHockey ]
2. Basic Usage
Access MCHockey services through Bukkit's ServiceManager:
public class YourPlugin extends JavaPlugin {
@Override
public void onEnable() {
Player player = Bukkit.getPlayer("YourPlayerName");
// Creating a hockey ball independent of a game.
HockeyBallFactory hockeyBallFactory = Bukkit.getServicesManager().load(HockeyBallFactory.class);
HockeyBall hockeyBall = hockeyBallFactory.createHockeyBall(player.getLocation(), new HockeyBallSettings());
// The is no way to directly set the velocity, but you can kick it relative to the position the player.
hockeyBall.kickByPlayer(player);
// Letting a player join a game.
GameService gameService = Bukkit.getServicesManager().load(GameService.class);
HockeyGame game = gameService.getByName("myGameName");
game.join(player, Team.BLUE);
}
}
🎯 Core Services
| Service | Purpose |
|---|---|
| GameService | Manage games, get game instances, player management |
| HockeyBallFactory | Create and manage hockey balls outside of games |
📡 Event System
MCHockey broadcasts various events that you can listen to:
- Game Events: Start, end, goal scored, player join/leave
- Ball Events: Kick, pass, interaction
- Player Events: Team switch, respawn
View all available events in the GitHub repository.
📚 Documentation
For detailed API documentation and method signatures, refer to the MCHockey source code on GitHub or use your IDE's intellisense when the plugin is loaded.