Jump to content

Recommended Posts

Posted

Hello boys!
I was thinking ways that someone can make a balance into a server...
Lineage is a game with many different characters and skills... So the balance is really hard some times...
I thought that by balancing skills and stats only, doesn't fix the problem on a point of view...
so I created a code that is changing the final outcome damage to a higher or lower percentage..
I think is better to check the code by yourself and give me a feedback.

   public static double calcPhysDam(L2Character attacker, L2Character target)
   {
      L2PcInstance targetPlayer = target.getActingPlayer();
      L2PcInstance attackerPlayer = attacker.getActingPlayer();
      
      boolean isPvP = attacker.isPlayable() && target.isPlayable();
      
      final L2Weapon weapon = attacker.getActiveWeaponItem();
      L2Armor armor = targetPlayer.getActiveChestArmorItem();
      
      if (isPvP)
      {
         if (weapon != null)
         {
            if (armor != null)
            {
               switch (attackerPlayer.getClassId())
               {
               /**
                * HUMAN CLASSES
                */
                  case duelist:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUAL:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case dreadnought:
                  {
                     switch (weapon.getItemType())
                     {
                        case POLE:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case phoenixKnight:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case hellKnight:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case sagittarius:
                  {
                     switch (weapon.getItemType())
                     {
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case adventurer:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUALDAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 0.9 : targetPlayer.isWearingLightArmor() ? 0.9 : targetPlayer.isWearingMagicArmor() ? 0.9 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * ELF CLASSES
                   */
                  case evaTemplar:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case swordMuse:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case windRider:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUALDAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 0.9 : targetPlayer.isWearingLightArmor() ? 0.9 : targetPlayer.isWearingMagicArmor() ? 0.9 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case moonlightSentinel:
                  {
                     switch (weapon.getItemType())
                     {
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * DARK ELF CLASSES
                   */
                  case shillienTemplar:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case spectralDancer:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUAL:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case ghostHunter:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUALDAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 0.9 : targetPlayer.isWearingLightArmor() ? 0.9 : targetPlayer.isWearingMagicArmor() ? 0.9 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case ghostSentinel:
                  {
                     switch (weapon.getItemType())
                     {
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 0.9 : targetPlayer.isWearingLightArmor() ? 0.9 : targetPlayer.isWearingMagicArmor() ? 0.9 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * ORC CLASSES
                   */
                  case titan:
                  {
                     switch (weapon.getItemType())
                     {
                        case TWOHAND_SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case grandKhavatari:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUALFIST:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * DWARF CLASSES
                   */
                  case fortuneSeeker:
                  {
                     switch (weapon.getItemType())
                     {
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case maestro:
                  {
                     switch (weapon.getItemType())
                     {
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * KAMAEL CLASSES
                   */
                  case doombringer:
                  {
                     switch (weapon.getItemType())
                     {
                        case ANCIENTSWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case maleSoulhound:
                  {
                     switch (weapon.getItemType())
                     {
                        case RAPIER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case femaleSoulhound:
                  {
                     switch (weapon.getItemType())
                     {
                        case RAPIER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case trickster:
                  {
                     switch (weapon.getItemType())
                     {
                        case CROSSBOW:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case judicator:
                  {
                     switch (weapon.getItemType())
                     {
                        case RAPIER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
               }
            }
            return 0.7; // if armor == null, return this.
         }
         return 1.0; // if weapon == null, return this.
      }
      return 1.0; // Never change this value.
   }
   
   /**
    * @param attacker
    * @param target
    * @param skill
    * @return double
    */
   public static double calcMagicDam(L2Character attacker, L2Character target, Skill skill)
   {
      L2PcInstance targetPlayer = (L2PcInstance) target;
      L2PcInstance attackerPlayer = (L2PcInstance) attacker;
      
      boolean isPvP = attacker.isPlayable() && target.isPlayable();
      
      L2Armor armor = targetPlayer.getActiveChestArmorItem();
      
      if (isPvP)
      {
         if ((skill != null) && skill.isMagic())
         {
            if (armor != null)
            {
               switch (attackerPlayer.getClassId())
               {
               /**
                * HUMAN CLASSES
                */
                  case archmage:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case soultaker:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case arcanaLord:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case cardinal:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case hierophant:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  
                  /**
                   * ELF CLASSES
                   */
                  case mysticMuse:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case elementalMaster:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case evaSaint:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  
                  /**
                   * DARK ELF CLASSES
                   */
                  case stormScreamer:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case spectralMaster:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case shillienSaint:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  
                  /**
                   * ORC CLASSES
                   */
                  case dominator:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case doomcryer:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
               }
            }
            return 0.7; // if armor == null, return this.
         }
         return 1.0; // if skill == null, return this.
      }
      return 1.0; // Never change this value.
   }

With this code i can either control the OP damage from classes with other weapons like the common issue with tanks with bow...
with less words... Each character is able to deal the maximum damage he can ONLY with his weapon... not another class's weapon.

Posted

Hello boys!

I was thinking ways that someone can make a balance into a server...

Lineage is a game with many different characters and skills... So the balance is really hard some times...

I thought that by balancing skills and stats only, doesn't fix the problem on a point of view...

so I created a code that is changing the final outcome damage to a higher or lower percentage..

I think is better to check the code by yourself and give me a feedback.

   public static double calcPhysDam(L2Character attacker, L2Character target)
   {
      L2PcInstance targetPlayer = target.getActingPlayer();
      L2PcInstance attackerPlayer = attacker.getActingPlayer();
      
      boolean isPvP = attacker.isPlayable() && target.isPlayable();
      
      final L2Weapon weapon = attacker.getActiveWeaponItem();
      L2Armor armor = targetPlayer.getActiveChestArmorItem();
      
      if (isPvP)
      {
         if (weapon != null)
         {
            if (armor != null)
            {
               switch (attackerPlayer.getClassId())
               {
               /**
                * HUMAN CLASSES
                */
                  case duelist:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUAL:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case dreadnought:
                  {
                     switch (weapon.getItemType())
                     {
                        case POLE:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case phoenixKnight:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case hellKnight:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case sagittarius:
                  {
                     switch (weapon.getItemType())
                     {
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case adventurer:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUALDAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 0.9 : targetPlayer.isWearingLightArmor() ? 0.9 : targetPlayer.isWearingMagicArmor() ? 0.9 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * ELF CLASSES
                   */
                  case evaTemplar:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case swordMuse:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case windRider:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUALDAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 0.9 : targetPlayer.isWearingLightArmor() ? 0.9 : targetPlayer.isWearingMagicArmor() ? 0.9 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case moonlightSentinel:
                  {
                     switch (weapon.getItemType())
                     {
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * DARK ELF CLASSES
                   */
                  case shillienTemplar:
                  {
                     switch (weapon.getItemType())
                     {
                        case SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case spectralDancer:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUAL:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case ghostHunter:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUALDAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 0.9 : targetPlayer.isWearingLightArmor() ? 0.9 : targetPlayer.isWearingMagicArmor() ? 0.9 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case ghostSentinel:
                  {
                     switch (weapon.getItemType())
                     {
                        case BOW:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        case DAGGER:
                           return targetPlayer.isWearingHeavyArmor() ? 0.9 : targetPlayer.isWearingLightArmor() ? 0.9 : targetPlayer.isWearingMagicArmor() ? 0.9 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * ORC CLASSES
                   */
                  case titan:
                  {
                     switch (weapon.getItemType())
                     {
                        case TWOHAND_SWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case grandKhavatari:
                  {
                     switch (weapon.getItemType())
                     {
                        case DUALFIST:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * DWARF CLASSES
                   */
                  case fortuneSeeker:
                  {
                     switch (weapon.getItemType())
                     {
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case maestro:
                  {
                     switch (weapon.getItemType())
                     {
                        case BLUNT:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  
                  /**
                   * KAMAEL CLASSES
                   */
                  case doombringer:
                  {
                     switch (weapon.getItemType())
                     {
                        case ANCIENTSWORD:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case maleSoulhound:
                  {
                     switch (weapon.getItemType())
                     {
                        case RAPIER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case femaleSoulhound:
                  {
                     switch (weapon.getItemType())
                     {
                        case RAPIER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case trickster:
                  {
                     switch (weapon.getItemType())
                     {
                        case CROSSBOW:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
                  case judicator:
                  {
                     switch (weapon.getItemType())
                     {
                        case RAPIER:
                           return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                        default:
                           return 0.6;
                     }
                  }
               }
            }
            return 0.7; // if armor == null, return this.
         }
         return 1.0; // if weapon == null, return this.
      }
      return 1.0; // Never change this value.
   }
   
   /**
    * @param attacker
    * @param target
    * @param skill
    * @return double
    */
   public static double calcMagicDam(L2Character attacker, L2Character target, Skill skill)
   {
      L2PcInstance targetPlayer = (L2PcInstance) target;
      L2PcInstance attackerPlayer = (L2PcInstance) attacker;
      
      boolean isPvP = attacker.isPlayable() && target.isPlayable();
      
      L2Armor armor = targetPlayer.getActiveChestArmorItem();
      
      if (isPvP)
      {
         if ((skill != null) && skill.isMagic())
         {
            if (armor != null)
            {
               switch (attackerPlayer.getClassId())
               {
               /**
                * HUMAN CLASSES
                */
                  case archmage:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case soultaker:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case arcanaLord:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case cardinal:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case hierophant:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  
                  /**
                   * ELF CLASSES
                   */
                  case mysticMuse:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case elementalMaster:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case evaSaint:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  
                  /**
                   * DARK ELF CLASSES
                   */
                  case stormScreamer:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case spectralMaster:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case shillienSaint:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  
                  /**
                   * ORC CLASSES
                   */
                  case dominator:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case doomcryer:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
               }
            }
            return 0.7; // if armor == null, return this.
         }
         return 1.0; // if skill == null, return this.
      }
      return 1.0; // Never change this value.
   }

With this code i can either control the OP damage from classes with other weapons like the common issue with tanks with bow...

with less words... Each character is able to deal the maximum damage he can ONLY with his weapon... not another class's weapon.

achievable with just passing a skill on each class and playing with xmls, why to create so must useless stuff when you have the option to just add either mastery penalty or xml: using kind "Sword,Blunt ... etc

Posted

achievable with just passing a skill on each class and playing with xmls, why to create so must useless stuff when you have the option to just add either mastery penalty or xml: using kind "Sword,Blunt ... etc

1. Perhaps this code does something that's not that simple by editing skills, items, stats etc 1 by 1.

2. As i already said in the topic "I thought that by balancing skills and stats only, doesn't fix the problem on a point of view..."

 

The skills are skills... You can handle a weak or strong skill... but it's difficult to handle the overall damage of some character to another (e.g a good warrior like duelist and a skilled player can sometimes almost achieve a 2v1 fight with 2 mages | a good archer can kill a mage without even let him react | a good dagger can face everyone except mages because of her evasion.)

 

The balance doesn't come always from the skills and the skills doesn't always bring you balance.... Plus... with this code you can handle a part of balance really quick and easy!

Posted

Interesting code, and how you check ingame  ?

Sorry, I don't share it... yet.

Atm I just want to hear some feedback from the community :)

Posted

Sorry, I don't share it... yet.

Atm I just want to hear some feedback from the community :)

Acctualy i had a bit same idea, but to use bots and statistic from theyr fights, to make some sort of graphic - that would show the dependence of low class vs>> over powerd class(with different items, skills, buffs, attrs, and etc)

If you're interested to cooperate - can you send me pm ?

Posted

Acctualy i had a bit same idea, but to use bots and statistic from theyr fights, to make some sort of graphic - that would show the dependence of low class vs>> over powerd class(with different items, skills, buffs, attrs, and etc)

If you're interested to cooperate - can you send me pm ?

Creating bots to test stats is so much waste of time...

and you'll never achieve something good from that...

You'll waste so much time create a code and make bots fighting like real players and it's literally much faster to finish whatever you want and open a public beta server to fix the balance + skills + stats items etc.

Posted

Creating bots to test stats is so much waste of time...

and you'll never achieve something good from that...

You'll waste so much time create a code and make bots fighting like real players and it's literally much faster to finish whatever you want and open a public beta server to fix the balance + skills + stats items etc.

The bots idea - is to not make Open beta server, cause if server is very custom and it should be noticed to earlier, then its maybe only way, i still dont get how you test your balance ? On real players ?

Posted

The bots idea - is to not make Open beta server, cause if server is very custom and it should be noticed to earlier, then its maybe only way, i still dont get how you test your balance ? On real players ?

of course.. an Open Beta server is the best way to balance your server and test for bugs/glitches etc.

BETA is this only way.. especially if you have a couple of events/codes/areas and plus to test your farm rewards, xp etc. + the balance...

By fixing all the possible bugs and balance issues by yourself or with only 2-3 people and then opening a live server... It's kinda so waste of advertisement and money for it because when people will see the bugs and the balance issues, they won't care about fixing them... they'll start hating and flaming about the server and then you've just created 1 more dead-server!

not worthy at all

Posted

                  case archmage:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case soultaker:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case arcanaLord:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case cardinal:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case hierophant:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }

use

case blabla:

case blabla:

do blabla;

 

because they all do the same:)

Posted

of course.. an Open Beta server is the best way to balance your server and test for bugs/glitches etc.

BETA is this only way.. especially if you have a couple of events/codes/areas and plus to test your farm rewards, xp etc. + the balance...

By fixing all the possible bugs and balance issues by yourself or with only 2-3 people and then opening a live server... It's kinda so waste of advertisement and money for it because when people will see the bugs and the balance issues, they won't care about fixing them... they'll start hating and flaming about the server and then you've just created 1 more dead-server!

not worthy at all

Got to agree with that.

So a possible solution is to give people live Beta since none (mby) will join a beta server to support you.

Posted
                  case archmage:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case soultaker:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case arcanaLord:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case cardinal:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }
                  case hierophant:
                  {
                     return targetPlayer.isWearingHeavyArmor() ? 1.0 : targetPlayer.isWearingLightArmor() ? 1.0 : targetPlayer.isWearingMagicArmor() ? 1.0 : 0.7;
                  }

use

case blabla:

case blabla:

do blabla;

 

because they all do the same:)

 

they do but every class is different... and i want to change their values differently from the other's if they're weak or too strong

 

 

 

Got to agree with that.

So a possible solution is to give people live Beta since none (mby) will join a beta server to support you.

advertisement for BETA. If the server is BETA and people would join, you have an excuse for the unfixed balance and bugs and people will understand and will help you.. They'd do on live server too... but there'd be much more haters and tears!

Posted

You could, indeed, get this done simply by giving characters a passive skill and applying the bonuses depending on the character class, as Kelrzher said. But you're not really going to balance anything that way.

 

Lineage II always have had its very own meaning of balance.

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

    • Hi everyone, Since I’m no longer interested in L2 servers, if anyone is willing to continue the project, let me know. I’m currently selling the entire project. DM me for more information if you’re genuinely interested. I can offer limited free support for the first couple of months. It is not cheap. The sale includes the domain, the recently fully redesigned website, the updater, the interface, server files with Lucera ext source, and the database (excluding account passwords, emails, and other private information; character data can remain).   Server for test: https://lineage2.gold/download Server Info: https://lineage2.gold/info Over 110 videos YouTube playlist: https://www.youtube.com/watch?v=HO7BZaxUv2U&list=PLD9WZ0Nj-zstZaYeWxAxTKbX7ia2M_DUu&index=113  
    • You invent yourself a life - bad for you, one of the inner core dev, fernandopm, which worked hard over aCis quests from 2011 to 2016 is argentinian. I teached him back in time to work and make proper quests. My dev team comes from 10+ countries and I'm myself french. "Racist/nationalist" card ? Not working bro.   Not sure why I should thank you to send me questions, and regarding bug reports, so far, I got none of yours in either discord, gitlab, or forums. I'm sorry if you feel "ignored", but that's more a psychanalyst you need to speak with if you put emotions towards someones' appreciation over a forum. I never ignore a bug report, and if so (like skills reports), it's because I got a bigger plan (skills refactor, in that case). In any case, I delivered cookies for the bug report/fix, even if it dated of months, with proper credits over changesets. "Victim card" ? Not really working, but ok, maybe you're "emotional".   I barely make money out of aCis, for the spent time - simply selling my services, or even coding/administrating a minecraft/L2J server would make far more money. Breaking intentionally things would be stupid. If you don't understand I'm not the only one working on that pack, I can't help you. Also, the scale of edits is sometimes extreme - AI L2OFF ? 1800 files added. How do you want everything works in a single shot ? "Exploiting noobz for money" card ? Still not working, or I'm a terrible businessman.   Meanwhile - you shadow advertise your project, L2JOne (since 2017 btw) - you should maybe start by the beginning saying you're a competitor and aCis is actually a spike in your foot. That also explains why you act like that. RusAcis got the exact same strategy, speaking bad of me, saying they got unique fixes (you speak about I break things, they break and recode things 4 times sometimes, btw), but successfully reselling latest revision with poorly executed stuff. "aCis is good, Tryskell is ok, but I solve all issues in extreme low time so I can piss over him" card ? Mmmmhhhh.   Our conversation ends here if you want, I don't force ppl to speak with me if they don't want - hopefully, people would understand I'm not the arrogant one and the one who doesn't want to talk, or even collaborate. :). I understand you got your own project and got no will to improve aCis.   NOTE : I'm extremely happy for your call of ExShowServerPrimitive with getValidGeoLocation, extremely impressive. Arrogant, no. Sarcastic ? Maybe.   Good night everyone.
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..

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