Jump to content

Recommended Posts

Posted

This is an unique Faction System. Same as the well-known GvE engines, but it's a bit different.

This is a gender-based GvE engine, with a really special reward.

We're recommend to use this engine with player Naked Mode without clothes.

 

/*
* This program is a private software, based on java source code.
* To share, distribute or redistribute this software is forbidden,
* except if someone approve it from RaveN Network INC. team.
* 
* Copyrights (c) 2012 RaveN Network INC. All rights reserved.
*/
package custom.genderGvE;

import net.l2emuproject.gameserver.gameobjects.L2Character;
import net.l2emuproject.gameserver.gameobjects.L2Player;
import net.l2emuproject.gameserver.model.restriction.global.AbstractRestriction;
import net.l2emuproject.gameserver.model.restriction.global.GlobalRestrictions;
import net.l2emuproject.gameserver.model.restriction.global.GlobalRestrictions.CombatState;
import net.l2emuproject.tools.random.Rnd;

/**
* @author lord_rex
* 	<br> This is an unique Faction System. Same as the well-known GvE engines, but it's a bit different.
* 	<br> This is a gender-based GvE engine, with a really special reward.
* 	<br> We're recommend to use this engine with player Naked Mode without clothes.
*/
public final class UniqueFactionRestriction extends AbstractRestriction
{
@Override
public CombatState getCombatState(L2Player activeChar, L2Player target)
{
	// feel free to attack players if the gender is different
	if (hasDifferentGender(activeChar, target))
		return CombatState.ENEMY;

	return CombatState.NEUTRAL;
}

@Override
public boolean canInviteToParty(L2Player activeChar, L2Player target)
{
	if (hasDifferentGender(activeChar, target))
	{
		activeChar.requestFailed("You cannot invite different gender players to your party!");
		return false;
	}

	return true;
}

@Override
public boolean playerKilled(L2Character activeChar, L2Player target, L2Player killer)
{
	if (hasDifferentGender(target, killer))
	{
		killer.sendMessage("Congratulation! You've killed one of the different gender! Your reward is a random porn URL: "
				+ getRandomPornURL());
		return true;
	}

	return true;
}

private String getRandomPornURL()
{
	switch (Rnd.get(3))
	{
		case 0:
			return "http://www.youngpornvideos.com/galleries/0515/69578/teenage-blonde-cutie-alyona-smashed-in-her-tight-a.php";
		case 1:
			return "http://www.youngpornvideos.com/galleries/0746/32082/teen-getting-fucked-and-taking-creampie.php";
		case 2:
			return "http://www.youngpornvideos.com/galleries/0215/69821/big-ass-blondie-girlfriend-tries-out-hardcore-anal.php";
		default:
			throw new InternalError();
	}
}

@Override
public int getNameColor(L2Player activeChar)
{
	return getGenderColor(activeChar);
}

@Override
public int getTitleColor(L2Player activeChar)
{
	return getGenderColor(activeChar);
}

private int getGenderColor(L2Player activeChar)
{
	if (isFemale(activeChar))
		return 0xFF00FF;

	if (isMale(activeChar))
		return 0xFF0033;

	return -1;
}

/**
 * @param activeChar
 * @param target
 * @return gender is different or no
 */
private boolean hasDifferentGender(L2Player activeChar, L2Player target)
{
	// activeChar is female and target is male
	if (isFemale(activeChar) && isMale(target))
		return true;

	// activeChar is male and target is female
	if (isMale(activeChar) && isFemale(target))
		return true;

	return false;
}

private boolean isFemale(L2Player activeChar)
{
	return activeChar.getAppearance().getSex();
}

private boolean isMale(L2Player activeChar)
{
	return !activeChar.getAppearance().getSex();
}

public static void main(String[] args)
{
	GlobalRestrictions.activate(new UniqueFactionRestriction());
}
}

Posted

private boolean hasDifferentGender(L2Player activeChar, L2Player target)
{
	// activeChar is female and target is male
	if (isFemale(activeChar) && isMale(target))
		return true;

	// activeChar is male and target is female
	if (isMale(activeChar) && isFemale(target))
		return true;

	return false;
}

==

private boolean hasDifferentGender(L2Player activeChar, L2Player target)
{
	return isMale(activeChar) != isMale(target);
}

 

thx for share :)

Posted

private boolean hasDifferentGender(L2Player activeChar, L2Player target)
{
	// activeChar is female and target is male
	if (isFemale(activeChar) && isMale(target))
		return true;

	// activeChar is male and target is female
	if (isMale(activeChar) && isFemale(target))
		return true;

	return false;
}

==

private boolean hasDifferentGender(L2Player activeChar, L2Player target)
{
	return isMale(activeChar) != isMale(target);
}

 

thx for share :)

np. btw mine one is more understandable :P

Posted

less code = better

Of course. But my version is more obviously for non-java-knowing-noobs.. and this changeset is a FUN section :)

 

PS: I could even use...

public boolean hasDifferentGender(final L2Player player, final L2Player target)
{
	return player.getAppearance().getSex() != target.getAppearance().getSex();
}

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • L2Elixir – Patch 4 Is Live!   We’re working non-stop, day and night, to deliver the best possible quality and bring back what made L2Elixir special. This project is built with passion, not shortcuts — for the old-school players who remember, and the new ones who want to experience it properly. Thank you for being part of the journey. Together, we’re making L2Elixir great again ❤️ The legends never fade.    ⚙️ General Enabled Class Change service (same class type only) ALT + B → Services → Character Development Enabled Shift + Click on Treasure Chests Players can now identify real chests (Adena, scroll drops) and use Key / Unlock Event deaths now cancel only debuffs, All self buffs are preserved, fixes issues with Root and similar effects Bladedancer class can now log in even when Max Clients (2) is reached. Since an active Bladedancer is not available for every damage dealer and some players tried to abuse this via VPN or a second PC, this feature was added to keep things fair. protections applies, requires testing!    🎒 Items Crystallizing enchanted items now gives the correct increased crystal amount (retail-like behavior) Removed Agathion Seal Bracelet: Rudolph from Santa rewards (Gracia Final item) Added Dualsword Craft Stamp into Milestone Exchange list    🧙 Skills Fixed Banish Undead lethal chance Hot Springs Malaria and similar effects now level up faster while being attacked
    • thats new SEO level tricks you know nothing of noob - bottom line: exposed.
    • Warning: This guy is a big scammer, trying to sell everything, advertising for servers etc. That's his mail address evgesha.nrnr@gmail.com , stay away!   @Atom @Celestine
    • Warning: This guy is a big scammer, trying to sell everything, advertising for servers etc. That's his mail address evgesha.nrnr@gmail.com , stay away! @Celestine @Atom
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock