Overwrite
Complete Overwrite of the Folder with the free shard. ServUO 57.3 has been added.
This commit is contained in:
159
Scripts/Items/Consumables/RecipeScroll.cs
Normal file
159
Scripts/Items/Consumables/RecipeScroll.cs
Normal file
@@ -0,0 +1,159 @@
|
||||
using System;
|
||||
using Server.Engines.Craft;
|
||||
using Server.Mobiles;
|
||||
using Server.Network;
|
||||
|
||||
namespace Server.Items
|
||||
{
|
||||
public class RecipeScroll : Item
|
||||
{
|
||||
private int m_RecipeID;
|
||||
public RecipeScroll(Recipe r)
|
||||
: this(r.ID)
|
||||
{
|
||||
}
|
||||
|
||||
[Constructable]
|
||||
public RecipeScroll(int recipeID)
|
||||
: base(0x2831)
|
||||
{
|
||||
this.m_RecipeID = recipeID;
|
||||
}
|
||||
|
||||
public RecipeScroll(Serial serial)
|
||||
: base(serial)
|
||||
{
|
||||
}
|
||||
|
||||
public override int LabelNumber
|
||||
{
|
||||
get
|
||||
{
|
||||
return 1074560;
|
||||
}
|
||||
}// recipe scroll
|
||||
[CommandProperty(AccessLevel.GameMaster)]
|
||||
public int RecipeID
|
||||
{
|
||||
get
|
||||
{
|
||||
return this.m_RecipeID;
|
||||
}
|
||||
set
|
||||
{
|
||||
this.m_RecipeID = value;
|
||||
this.InvalidateProperties();
|
||||
}
|
||||
}
|
||||
public Recipe Recipe
|
||||
{
|
||||
get
|
||||
{
|
||||
if (Recipe.Recipes.ContainsKey(this.m_RecipeID))
|
||||
return Recipe.Recipes[this.m_RecipeID];
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
||||
public override void GetProperties(ObjectPropertyList list)
|
||||
{
|
||||
base.GetProperties(list);
|
||||
|
||||
Recipe r = this.Recipe;
|
||||
|
||||
if (r != null)
|
||||
list.Add(1049644, r.TextDefinition.ToString()); // [~1_stuff~]
|
||||
}
|
||||
|
||||
public override void OnDoubleClick(Mobile from)
|
||||
{
|
||||
if (!from.InRange(this.GetWorldLocation(), 2))
|
||||
{
|
||||
from.LocalOverheadMessage(MessageType.Regular, 0x3B2, 1019045); // I can't reach that.
|
||||
return;
|
||||
}
|
||||
|
||||
Recipe r = this.Recipe;
|
||||
|
||||
if (r != null && from is PlayerMobile)
|
||||
{
|
||||
PlayerMobile pm = from as PlayerMobile;
|
||||
|
||||
if (!pm.HasRecipe(r))
|
||||
{
|
||||
bool allRequiredSkills = true;
|
||||
double chance = r.CraftItem.GetSuccessChance(from, null, r.CraftSystem, false, ref allRequiredSkills);
|
||||
|
||||
if (allRequiredSkills && chance >= 0.0)
|
||||
{
|
||||
pm.SendLocalizedMessage(1073451, r.TextDefinition.ToString()); // You have learned a new recipe: ~1_RECIPE~
|
||||
pm.AcquireRecipe(r);
|
||||
this.Delete();
|
||||
}
|
||||
else
|
||||
{
|
||||
pm.SendLocalizedMessage(1044153); // You don't have the required skills to attempt this item.
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
pm.SendLocalizedMessage(1073427); // You already know this recipe.
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public override void Serialize(GenericWriter writer)
|
||||
{
|
||||
base.Serialize(writer);
|
||||
|
||||
writer.Write((int)0); // version
|
||||
|
||||
writer.Write((int)this.m_RecipeID);
|
||||
}
|
||||
|
||||
public override void Deserialize(GenericReader reader)
|
||||
{
|
||||
base.Deserialize(reader);
|
||||
|
||||
int version = reader.ReadInt();
|
||||
|
||||
switch( version )
|
||||
{
|
||||
case 0:
|
||||
{
|
||||
this.m_RecipeID = reader.ReadInt();
|
||||
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public class DoomRecipeScroll : RecipeScroll
|
||||
{
|
||||
[Constructable]
|
||||
public DoomRecipeScroll()
|
||||
: base(Utility.RandomList(355, 356, 456, 585))
|
||||
{
|
||||
}
|
||||
|
||||
public DoomRecipeScroll(Serial serial)
|
||||
: base(serial)
|
||||
{
|
||||
}
|
||||
|
||||
public override void Serialize(GenericWriter writer)
|
||||
{
|
||||
base.Serialize(writer);
|
||||
|
||||
writer.Write((int)0); // version
|
||||
}
|
||||
|
||||
public override void Deserialize(GenericReader reader)
|
||||
{
|
||||
base.Deserialize(reader);
|
||||
|
||||
int version = reader.ReadInt();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user