Jump to content

Recommended Posts

Posted

Hey there.

 

This is a boss engine i created long ago, cause i always found every boss/grand boss engine difficult/weird to use. It's really easy to use. The code may be weird because i remember to be experimenting on stuff when creating this. Also, i know it could have been done in a better way(with saving each boss data and other stuff). Coded on aCis, can't remember revision.

 

There are also some boss examples i used.

 

 

/*
* This program is free software: you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later
* version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* this program. If not, see <http://www.gnu.org/licenses/>.
*/
package net.sf.l2j.gameserver.customs.custombosses;

import java.util.ArrayList;
import java.util.List;

import net.sf.l2j.gameserver.ThreadPoolManager;

/**
* @author Anarchy
*
*/
public class CustomBossManager
{
    private List<CustomBoss> _customBosses;
    
    public static CustomBossManager getInstance()
    {
        return SingletonHolder._instance;
    }
    
    protected CustomBossManager()
    {
        _customBosses = new ArrayList<>();
        
        _customBosses.add(new ForestGodBoss());
        
        initBosses();
        
        System.out.println("CustomBossesManager: Loaded "+_customBosses.size()+" custom bosses.");
    }
    
    private void initBosses()
    {
        for (final CustomBoss cb : _customBosses)
        {
            int respawnHours = Integer.parseInt(cb.getRespawnTime().split(":")[0]);
            int respawnMinutes = Integer.parseInt(cb.getRespawnTime().split(":")[1]);
            
            int totalMinutes = (respawnHours * 60) + respawnMinutes;
            
            long respawnMillis = totalMinutes * 1000 * 60;
            
            ThreadPoolManager.getInstance().scheduleGeneralAtFixedRate(new Runnable()
            {
                @Override
                public void run()
                {
                    cb.doSpawn();
                }
            }, respawnMillis/2, respawnMillis);
        }
    }
    
    public CustomBoss getCustomBoss(int id)
    {
        CustomBoss temp = null;
        
        for (CustomBoss cb : _customBosses)
        {
            if (cb.getNpcId() == id)
            {
                temp = cb;
                break;
            }
        }
        
        return temp;
    }
    
    private static class SingletonHolder
    {
        protected static final CustomBossManager _instance = new CustomBossManager();
    }
}

 

 

/*
* This program is free software: you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later
* version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* this program. If not, see <http://www.gnu.org/licenses/>.
*/
package net.sf.l2j.gameserver.customs.custombosses;

import net.sf.l2j.gameserver.Announcements;
import net.sf.l2j.gameserver.datatables.NpcTable;
import net.sf.l2j.gameserver.datatables.SpawnTable;
import net.sf.l2j.gameserver.model.L2Spawn;
import net.sf.l2j.gameserver.templates.chars.L2NpcTemplate;

/**
* @author Anarchy
*
*/
public abstract class CustomBoss
{
    private L2Spawn _lastSpawn = null;
    
    public void delete()
    {
        if (_lastSpawn == null)
        {
            return;
        }
        
        _lastSpawn.getLastSpawn().deleteMe();
        _lastSpawn.stopRespawn();
        SpawnTable.getInstance().deleteSpawn(_lastSpawn, false);
        
        _lastSpawn = null;
        
        Announcements.announceToAll("Custom Boss "+getName()+" has been killed!");
    }
    
    public void doSpawn()
    {
        if (_lastSpawn != null)
        {
            return;
        }
        
        L2NpcTemplate tmpl = NpcTable.getInstance().getTemplate(getNpcId());
        try
        {
            L2Spawn spawn = new L2Spawn(tmpl);
spawn.setLocx(getLocation()[0]);
spawn.setLocy(getLocation()[1]);
spawn.setLocz(getLocation()[2]);
spawn.setHeading(0);
spawn.setRespawnDelay(100);
SpawnTable.getInstance().addNewSpawn(spawn, false);
spawn.init();

_lastSpawn = spawn;
onSpawn();
        }
        catch (Exception e)
        {
            e.printStackTrace();
            System.out.println("Failed to spawn boss "+getName()+" with id "+getNpcId()+".");
        }
    }
    
    protected void onSpawn()
    {
        Announcements.announceToAll("Custom Boss "+getName()+" was spawned in the world!");
    }
    
    public abstract int[] getLocation();
    public abstract int getNpcId();
    public abstract String getName();
    public abstract String getRespawnTime();
}

 

 

/*
* This program is free software: you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later
* version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* this program. If not, see <http://www.gnu.org/licenses/>.
*/
package net.sf.l2j.gameserver.customs.custombosses;

/**
* @author Anarchy
*
*/
public class ForestGodBoss extends CustomBoss
{
    @Override
    public int[] getLocation()
    {
        return new int[] { 172830, -87707, -5108 };
    }
    
    @Override
    public int getNpcId()
    {
        return 65533;
    }

    @Override
    public String getName()
    {
        return "Forest God";
    }

    @Override
    public String getRespawnTime()
    {
        return "1:00";
    }
}

 

 

In L2MonsterInstance under doDie() method, add this check:

 

        if (isCustomBoss())
        {
            CustomBossManager.getInstance().getCustomBoss(getNpcId()).delete();
        }

 

and this method:

 

    public boolean isCustomBoss()
    {
        return CustomBossManager.getInstance().getCustomBoss(getNpcId()) != null;
    }

 

Also register the CustomBossManager in Gameserver.java.

 

How to use it:

Simple, create a normal monster with super stats and super drops, make a new class that extends CustomBoss, add it's data there, register it to CustomBossManager and you're done. The bosses must be type L2Monster in order to work properly.

 

About this ForestGod i won't share the npc data just make new ones.

 

HF.

  • 4 months later...
Posted (edited)

You can explain a little bit more

 make a new class that extends CustomBoss, add it's data there, register it to CustomBossManager and you're done

 

plz make example

Edited by pske
  • 2 months later...

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

  • Posts

    • never met a programmer that doesnt know english xD and as he said his knowledge and skills are beyond our imagination xD
    • nice work, welcome back to world of lineage development @melron 😄
    • He's likely baiting you to download his source full of backdoors indeed
    • Yeah inside router i had to enable udnp services 
    • Hello cheaters, As a team of avid developers and enthusiasts of Lineage 2, we are excited to present the L2 Control Hub, a groundbreaking plugin designed by myself and my collaborator, StinkyMadness. This innovative tool equips server administrators with powerful automation capabilities directly within the game's community board. L2 Control Hub simplifies the creation and management of automations, enabling you to customize your server operations without the need to modify the source code.   Key Features of L2 Control Hub: Robust Automation Triggers: Select from a plethora of triggers currently available, with continuous additions in the works to enhance your control options. Dynamic Conditions and Actions: Tailor your server operations with an extensive range of conditions and actions, ensuring flexible and precise control over game events and player interactions. Customizable Variables: Easily integrate server-specific variables from your database to further personalize and streamline your automations. Utilize these variables across various automation scenarios to cater to your specific server requirements. JavaScript Integration: Execute custom JavaScript codes that interact seamlessly with Java classes, bringing advanced functionalities to your server's ecosystem.   Explore L2 Control Hub in Action: We've prepared a series of video tutorials to demonstrate the capabilities of L2 Control Hub: Control Hub - Create a Simple Flow with 1 Condition and 1 Action: Get started with basic automations. Control Hub - Multiple Conditions with Multiple Actions: Explore more complex automations for detailed server management. Control Hub - Using Variables: Discover how to implement and use custom variables for tailored automations. Control Hub - Using JavaScript: Experience the power of custom scripts in enhancing your server functionality.   L2 Control Hub is currently about 70% complete, and we are actively developing and refining features. We invite you to join our ➡️ Discord community ⬅️ to engage with the development process, provide feedback, and be the first to test new features. Additionally, any updates or changes to the plugin are seamlessly delivered to all customers directly from our web server, ensuring your system is always up-to-date without the need for manual downloads.   Your game, your rules, automated. Join us in redefining server management in Lineage 2 and elevate your gaming community with unmatched automation capabilities. For more details, contact us directly to get started with L2 Control Hub.   Currently, the plugin is developed using aCis sources. We will continue with these sources until we finalize all the necessary details before proceeding to integrate with the more prominent sources available.       The L2 Control Hub is designed to extend beyond mere functional additions to your server. We are in the process of implementing a suite of advanced mechanisms, such as a vote manager capable of interfacing with any Lineage 2 voting site without requiring configuration, live statistics to provide admins with real-time insights, and an event engine that can generate any desired event within seconds. All these features will be seamlessly integrated into the module, enhancing your server management experience significantly.     Please note that L2 Control Hub will be a premium tool, reflecting the extensive features and benefits it offers. While we are finalizing the pricing structure, rest assured that we aim to deliver great value for your investment. We will announce the cost details soon on our platforms to ensure everyone is well-informed and can plan accordingly. Join us to take your server management to the next level with L2 Control Hub.     
  • Topics

×
×
  • Create New...