#W# Initial Commit: Avatars Conquest
This commit is contained in:
commit
8eae46895e
7512 changed files with 416187 additions and 0 deletions
139
Scripts/Items/Skill Items/Camping/Bedroll.cs
Normal file
139
Scripts/Items/Skill Items/Camping/Bedroll.cs
Normal file
|
|
@ -0,0 +1,139 @@
|
|||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using Server;
|
||||
using Server.Network;
|
||||
using Server.Mobiles;
|
||||
|
||||
namespace Server.Items
|
||||
{
|
||||
public class Bedroll : Item
|
||||
{
|
||||
private Timer m_Timer;
|
||||
private DateTime m_Created;
|
||||
private Mobile m_Owner;
|
||||
|
||||
public Bedroll( Mobile owner ) : base( 0x0A55 )
|
||||
{
|
||||
ItemID = Utility.RandomMinMax( 0x0A55, 0x0A56 );
|
||||
m_Owner = owner;
|
||||
Movable = false;
|
||||
m_Created = DateTime.Now;
|
||||
m_Timer = Timer.DelayCall( TimeSpan.FromSeconds( 1.0 ), TimeSpan.FromSeconds( 1.0 ), new TimerCallback( OnTick ) );
|
||||
}
|
||||
|
||||
public Bedroll( Serial serial ) : base( serial )
|
||||
{
|
||||
}
|
||||
|
||||
[CommandProperty( AccessLevel.Counselor, AccessLevel.GameMaster )]
|
||||
public Mobile Owner
|
||||
{
|
||||
get
|
||||
{
|
||||
return m_Owner;
|
||||
}
|
||||
set{ m_Owner = value; InvalidateProperties(); }
|
||||
}
|
||||
|
||||
[CommandProperty( AccessLevel.GameMaster )]
|
||||
public DateTime Created
|
||||
{
|
||||
get{ return m_Created; }
|
||||
}
|
||||
|
||||
private bool EnemiesNearby()
|
||||
{
|
||||
foreach( Mobile m in GetMobilesInRange( 20 ) )
|
||||
{
|
||||
if ( m is PlayerMobile && m.Combatant != null && m.InRange( m.Combatant.Location, 20 ) && m.Combatant.InLOS( m ) )
|
||||
return true;
|
||||
else if ( m is BaseCreature && !((BaseCreature)m).Controlled && !((BaseCreature)m).Summoned && ((BaseCreature)m).FightMode == FightMode.Closest )
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
private void OnTick()
|
||||
{
|
||||
DateTime now = DateTime.Now;
|
||||
TimeSpan age = now - this.Created;
|
||||
|
||||
if ( age >= TimeSpan.FromSeconds( 100.0 ) )
|
||||
RollUp();
|
||||
|
||||
if ( this.Deleted )
|
||||
return;
|
||||
|
||||
List<Mobile> toRest = new List<Mobile>();
|
||||
if ( !EnemiesNearby() )
|
||||
{
|
||||
foreach( Mobile m in GetMobilesInRange( 3 ) )
|
||||
{
|
||||
if ( m is PlayerMobile && m == m_Owner )
|
||||
toRest.Add( m );
|
||||
}
|
||||
|
||||
for ( int i = 0; i < toRest.Count; i++ )
|
||||
Rest( toRest[i] );
|
||||
}
|
||||
}
|
||||
|
||||
public void RollUp()
|
||||
{
|
||||
if ( m_Owner != null )
|
||||
{
|
||||
Container cont = m_Owner.Backpack;
|
||||
if ( cont != null )
|
||||
m_Owner.AddToBackpack( new BedRolled() );
|
||||
}
|
||||
|
||||
this.Delete();
|
||||
}
|
||||
|
||||
public void Rest( Mobile m )
|
||||
{
|
||||
if ( m.Hunger > 4 && m.Thirst > 4 )
|
||||
{
|
||||
if ( m.Stam < m.StamMax )
|
||||
m.Stam++;
|
||||
if ( m.Hits < m.HitsMax )
|
||||
{
|
||||
int hits = (int)(1 * Server.Misc.Settings.HitPoints());
|
||||
if ( hits < 1 )
|
||||
hits = 1;
|
||||
|
||||
m.Hits = m.Hits + hits;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public override void OnDoubleClick( Mobile from )
|
||||
{
|
||||
if ( m_Owner == from )
|
||||
RollUp();
|
||||
}
|
||||
|
||||
public override void OnAfterDelete()
|
||||
{
|
||||
if ( m_Timer != null )
|
||||
m_Timer.Stop();
|
||||
}
|
||||
|
||||
public override void Serialize( GenericWriter writer )
|
||||
{
|
||||
base.Serialize( writer );
|
||||
writer.Write( (int) 0 ); // version
|
||||
writer.Write( (Mobile) m_Owner );
|
||||
}
|
||||
|
||||
public override void Deserialize( GenericReader reader )
|
||||
{
|
||||
base.Deserialize( reader );
|
||||
int version = reader.ReadInt();
|
||||
m_Owner = reader.ReadMobile();
|
||||
RollUp();
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue