Overwrite
Complete Overwrite of the Folder with the free shard. ServUO 57.3 has been added.
This commit is contained in:
130
Scripts/Items/Consumables/MessageInABottle.cs
Normal file
130
Scripts/Items/Consumables/MessageInABottle.cs
Normal file
@@ -0,0 +1,130 @@
|
||||
using System;
|
||||
|
||||
namespace Server.Items
|
||||
{
|
||||
public class MessageInABottle : Item
|
||||
{
|
||||
private Map m_TargetMap;
|
||||
private int m_Level;
|
||||
[Constructable]
|
||||
public MessageInABottle()
|
||||
: this(Map.Trammel)
|
||||
{
|
||||
}
|
||||
|
||||
public MessageInABottle(Map map)
|
||||
: this(map, GetRandomLevel())
|
||||
{
|
||||
}
|
||||
|
||||
[Constructable]
|
||||
public MessageInABottle(Map map, int level)
|
||||
: base(0x099F)
|
||||
{
|
||||
Weight = 1.0;
|
||||
m_TargetMap = map;
|
||||
m_Level = level;
|
||||
}
|
||||
|
||||
public MessageInABottle(Serial serial)
|
||||
: base(serial)
|
||||
{
|
||||
}
|
||||
|
||||
public override int LabelNumber
|
||||
{
|
||||
get
|
||||
{
|
||||
return 1041080;
|
||||
}
|
||||
}// a message in a bottle
|
||||
[CommandProperty(AccessLevel.GameMaster)]
|
||||
public Map TargetMap
|
||||
{
|
||||
get
|
||||
{
|
||||
return m_TargetMap;
|
||||
}
|
||||
set
|
||||
{
|
||||
m_TargetMap = value;
|
||||
}
|
||||
}
|
||||
[CommandProperty(AccessLevel.GameMaster)]
|
||||
public int Level
|
||||
{
|
||||
get
|
||||
{
|
||||
return m_Level;
|
||||
}
|
||||
set
|
||||
{
|
||||
m_Level = Math.Max(1, Math.Min(value, 4));
|
||||
}
|
||||
}
|
||||
public static int GetRandomLevel()
|
||||
{
|
||||
if (Core.AOS && 10 == Utility.RandomMinMax(1,25))
|
||||
return 4; // ancient
|
||||
|
||||
return Utility.RandomMinMax(1, 3);
|
||||
}
|
||||
|
||||
public override void Serialize(GenericWriter writer)
|
||||
{
|
||||
base.Serialize(writer);
|
||||
|
||||
writer.Write((int)3); // version
|
||||
|
||||
writer.Write((int)m_Level);
|
||||
|
||||
writer.Write(m_TargetMap);
|
||||
}
|
||||
|
||||
public override void Deserialize(GenericReader reader)
|
||||
{
|
||||
base.Deserialize(reader);
|
||||
|
||||
int version = reader.ReadInt();
|
||||
|
||||
switch ( version )
|
||||
{
|
||||
case 3:
|
||||
case 2:
|
||||
{
|
||||
m_Level = reader.ReadInt();
|
||||
goto case 1;
|
||||
}
|
||||
case 1:
|
||||
{
|
||||
m_TargetMap = reader.ReadMap();
|
||||
break;
|
||||
}
|
||||
case 0:
|
||||
{
|
||||
m_TargetMap = Map.Trammel;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (version < 2)
|
||||
m_Level = GetRandomLevel();
|
||||
|
||||
if (version < 3 && m_TargetMap == Map.Tokuno)
|
||||
m_TargetMap = Map.Trammel;
|
||||
}
|
||||
|
||||
public override void OnDoubleClick(Mobile from)
|
||||
{
|
||||
if (IsChildOf(from.Backpack))
|
||||
{
|
||||
ReplaceWith(new SOS(m_TargetMap, m_Level));
|
||||
from.LocalOverheadMessage(Network.MessageType.Regular, 0x3B2, 501891); // You extract the message from the bottle.
|
||||
}
|
||||
else
|
||||
{
|
||||
from.SendLocalizedMessage(1042001); // That must be in your pack for you to use it.
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user