mirror of
https://github.com/islehorse/HISP.git
synced 2025-04-21 20:25:51 +12:00
Add Horse Pawneer
and Pawneer Orders.
This commit is contained in:
parent
2345b302fc
commit
d9cdd05acb
12 changed files with 653 additions and 263 deletions
|
@ -28,11 +28,15 @@ namespace HISP.Server
|
|||
|
||||
|
||||
|
||||
public static Double PointsToDistance(int x1, int y1, int x2, int y2)
|
||||
public static double PointsToDistance(int x1, int y1, int x2, int y2)
|
||||
{
|
||||
return Math.Sqrt(Math.Pow((x2 - x1), 2) + Math.Pow((y2 - y1), 2));
|
||||
}
|
||||
|
||||
public static string CapitalizeFirstLetter(string str)
|
||||
{
|
||||
char firstChar = char.ToUpper(str[0]);
|
||||
return firstChar + str.Substring(1);
|
||||
}
|
||||
public static DateTime UnixTimeStampToDateTime(double unixTimeStamp)
|
||||
{
|
||||
// Unix timestamp is seconds past epoch
|
||||
|
|
|
@ -511,6 +511,17 @@ namespace HISP.Server
|
|||
HorseInfo.Breeds.Add(horseBreed);
|
||||
Logger.DebugPrint("Registered Horse Breed: #" + horseBreed.Id + ": " + horseBreed.Name);
|
||||
}
|
||||
// Register Breed Prices @ Pawneer Order
|
||||
int totalBreedPrices = gameData.horses.pawneer_base_price.Count;
|
||||
for(int i = 0; i < totalBreedPrices; i++)
|
||||
{
|
||||
int id = gameData.horses.pawneer_base_price[i].breed_id;
|
||||
int price = gameData.horses.pawneer_base_price[i].price;
|
||||
Pawneer pawneerPricing = new Pawneer(id, price);
|
||||
Pawneer.PawneerPriceModels.Add(pawneerPricing);
|
||||
Logger.DebugPrint("Registered Pawneer Base Price " + pawneerPricing.BreedId + " for $" + pawneerPricing.BasePrice.ToString("N0"));
|
||||
}
|
||||
|
||||
int totalCategories = gameData.horses.categorys.Count;
|
||||
for(int i = 0; i < totalCategories; i++)
|
||||
{
|
||||
|
@ -913,6 +924,25 @@ namespace HISP.Server
|
|||
Messages.FarrierPutOnSteelShoesAllMesssageFormat = gameData.messages.meta.farrier.put_on_steel_all;
|
||||
Messages.FarrierShoesCantAffordMessage = gameData.messages.meta.farrier.cant_afford_farrier;
|
||||
|
||||
// Pawneer
|
||||
Messages.PawneerUntackedHorsesICanBuy = gameData.messages.meta.pawneer.untacked_i_can_buy;
|
||||
Messages.PawneerHorseFormat = gameData.messages.meta.pawneer.pawn_horse;
|
||||
Messages.PawneerOrderMeta = gameData.messages.meta.pawneer.pawneer_order;
|
||||
Messages.PawneerHorseConfirmationFormat = gameData.messages.meta.pawneer.are_you_sure;
|
||||
Messages.PawneerHorseSoldMessagesFormat = gameData.messages.meta.pawneer.horse_sold;
|
||||
Messages.PawneerHorseNotFound = gameData.messages.meta.pawneer.horse_not_found;
|
||||
|
||||
Messages.PawneerOrderSelectBreed = gameData.messages.meta.pawneer.order.select_breed;
|
||||
Messages.PawneerOrderBreedEntryFormat = gameData.messages.meta.pawneer.order.breed_entry;
|
||||
|
||||
Messages.PawneerOrderSelectColorFormat = gameData.messages.meta.pawneer.order.select_color;
|
||||
Messages.PawneerOrderColorEntryFormat = gameData.messages.meta.pawneer.order.color_entry;
|
||||
|
||||
Messages.PawneerOrderSelectGenderFormat = gameData.messages.meta.pawneer.order.select_gender;
|
||||
Messages.PawneerOrderGenderEntryFormat = gameData.messages.meta.pawneer.order.gender_entry;
|
||||
|
||||
Messages.PawneerOrderHorseFoundFormat = gameData.messages.meta.pawneer.order.found;
|
||||
|
||||
// Vet
|
||||
Messages.VetServiceHorseFormat = gameData.messages.meta.vet.service_horse;
|
||||
Messages.VetSerivcesNotNeeded = gameData.messages.meta.vet.not_needed;
|
||||
|
@ -1010,8 +1040,10 @@ namespace HISP.Server
|
|||
Messages.HorsesHere = gameData.messages.meta.horse.horses_here;
|
||||
Messages.WildHorseFormat = gameData.messages.meta.horse.wild_horse;
|
||||
Messages.HorseCaptureTimer = gameData.messages.meta.horse.horse_timer;
|
||||
Messages.YouCapturedTheHorse = gameData.messages.meta.horse.hore_caught;
|
||||
|
||||
Messages.YouCapturedTheHorse = gameData.messages.meta.horse.horse_caught;
|
||||
Messages.HorseEvadedCapture = gameData.messages.meta.horse.horse_escaped;
|
||||
Messages.HorseEscapedAnyway = gameData.messages.meta.horse.horse_escaped_anyway;
|
||||
|
||||
Messages.HorsesMenuHeader = gameData.messages.meta.horse.horses_menu;
|
||||
Messages.TooManyHorses = gameData.messages.meta.horse.too_many_horses;
|
||||
|
|
|
@ -1203,16 +1203,16 @@ namespace HISP.Server
|
|||
WildHorse capturing = WildHorse.GetHorseById(sender.LoggedinUser.CapturingHorseId);
|
||||
sender.LoggedinUser.CapturingHorseId = 0;
|
||||
|
||||
capturing.Escape();
|
||||
Logger.InfoPrint(sender.LoggedinUser.Username + " Failed to capture: " + capturing.Instance.Breed.Name + " new location: " + capturing.X + ", " + capturing.Y);
|
||||
if (capturing.X == sender.LoggedinUser.X && capturing.Y == sender.LoggedinUser.Y)
|
||||
{
|
||||
capturing.Escape();
|
||||
Logger.InfoPrint(sender.LoggedinUser.Username + " Failed to capture: " + capturing.Instance.Breed.Name + " new location: " + capturing.X + ", " + capturing.Y);
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
byte[] metaPacket = PacketBuilder.CreateMetaPacket(Meta.BuildHorseEscapedMessage());
|
||||
sender.SendPacket(metaPacket);
|
||||
|
||||
UpdateAreaForAll(sender.LoggedinUser.X, sender.LoggedinUser.Y);
|
||||
}
|
||||
}
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
byte[] hoseEscaped = PacketBuilder.CreateMetaPacket(Meta.BuildHorseEscapedMessage());
|
||||
sender.SendPacket(hoseEscaped);
|
||||
break;
|
||||
case PacketBuilder.HORSE_CAUGHT:
|
||||
if (WildHorse.DoesHorseExist(sender.LoggedinUser.CapturingHorseId))
|
||||
|
@ -1220,33 +1220,38 @@ namespace HISP.Server
|
|||
WildHorse capturing = WildHorse.GetHorseById(sender.LoggedinUser.CapturingHorseId);
|
||||
sender.LoggedinUser.CapturingHorseId = 0;
|
||||
|
||||
try
|
||||
if (capturing.X == sender.LoggedinUser.X && capturing.Y == sender.LoggedinUser.Y)
|
||||
{
|
||||
capturing.Capture(sender.LoggedinUser);
|
||||
}
|
||||
catch(InventoryFullException)
|
||||
{
|
||||
byte[] chatMsg = PacketBuilder.CreateChat(Messages.TooManyHorses, PacketBuilder.CHAT_BOTTOM_RIGHT);
|
||||
sender.SendPacket(chatMsg);
|
||||
try
|
||||
{
|
||||
capturing.Capture(sender.LoggedinUser);
|
||||
}
|
||||
catch (InventoryFullException)
|
||||
{
|
||||
byte[] chatMsg = PacketBuilder.CreateChat(Messages.TooManyHorses, PacketBuilder.CHAT_BOTTOM_RIGHT);
|
||||
sender.SendPacket(chatMsg);
|
||||
break;
|
||||
}
|
||||
|
||||
sender.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.HorseCapture).Count++;
|
||||
|
||||
if (sender.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.HorseCapture).Count >= 100)
|
||||
sender.LoggedinUser.Awards.AddAward(Award.GetAwardById(24)); // Wrangler
|
||||
if (sender.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.HorseCapture).Count >= 1000)
|
||||
sender.LoggedinUser.Awards.AddAward(Award.GetAwardById(25)); // Pro Wrangler
|
||||
|
||||
Logger.InfoPrint(sender.LoggedinUser.Username + " Captured a: " + capturing.Instance.Breed.Name);
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
byte[] horseCaught = PacketBuilder.CreateMetaPacket(Meta.BuildHorseCaughtMessage());
|
||||
sender.SendPacket(horseCaught);
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
sender.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.HorseCapture).Count++;
|
||||
|
||||
if(sender.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.HorseCapture).Count >= 100)
|
||||
sender.LoggedinUser.Awards.AddAward(Award.GetAwardById(24)); // Wrangler
|
||||
if (sender.LoggedinUser.TrackedItems.GetTrackedItem(Tracking.TrackableItem.HorseCapture).Count >= 1000)
|
||||
sender.LoggedinUser.Awards.AddAward(Award.GetAwardById(25)); // Pro Wrangler
|
||||
|
||||
Logger.InfoPrint(sender.LoggedinUser.Username + " Captured a: " + capturing.Instance.Breed.Name + " new location: " + capturing.X + ", " + capturing.Y);
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
byte[] metaPacket = PacketBuilder.CreateMetaPacket(Meta.BuildHorseCaughtMessage());
|
||||
sender.SendPacket(metaPacket);
|
||||
|
||||
UpdateAreaForAll(sender.LoggedinUser.X, sender.LoggedinUser.Y);
|
||||
}
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
byte[] horseAllreadyCaught = PacketBuilder.CreateMetaPacket(Meta.BuildHorseEscapedAnyway());
|
||||
sender.SendPacket(horseAllreadyCaught);
|
||||
break;
|
||||
case PacketBuilder.HORSE_TRY_CAPTURE:
|
||||
randomId = 0;
|
||||
|
@ -1820,6 +1825,11 @@ namespace HISP.Server
|
|||
metaPacket = PacketBuilder.CreateMetaPacket(Meta.BuildBooksLibary());
|
||||
sender.SendPacket(metaPacket);
|
||||
break;
|
||||
case "47":
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
metaPacket = PacketBuilder.CreateMetaPacket(Meta.BuildPawneerOrderBreedList());
|
||||
sender.SendPacket(metaPacket);
|
||||
break;
|
||||
case "53": // Misc Stats / Tracked Items
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
metaPacket = PacketBuilder.CreateMetaPacket(Meta.BuildMiscStats(sender.LoggedinUser));
|
||||
|
@ -1887,7 +1897,7 @@ namespace HISP.Server
|
|||
}
|
||||
break;
|
||||
}
|
||||
if(buttonIdStr.StartsWith("32c")) // Horse Whisperer
|
||||
if (buttonIdStr.StartsWith("32c")) // Horse Whisperer
|
||||
{
|
||||
string idStr = buttonIdStr.Substring(3);
|
||||
int breedId = -1;
|
||||
|
@ -1895,12 +1905,13 @@ namespace HISP.Server
|
|||
{
|
||||
breedId = int.Parse(idStr);
|
||||
}
|
||||
catch (FormatException) {
|
||||
catch (FormatException)
|
||||
{
|
||||
Logger.DebugPrint(sender.LoggedinUser.Username + " Tried to whisper a horse with BreedId NaN.");
|
||||
break;
|
||||
break;
|
||||
};
|
||||
|
||||
if(sender.LoggedinUser.Money < 50000)
|
||||
|
||||
if (sender.LoggedinUser.Money < 50000)
|
||||
{
|
||||
byte[] cannotAffordMessage = PacketBuilder.CreateChat(Messages.WhispererServiceCannotAfford, PacketBuilder.CHAT_BOTTOM_RIGHT);
|
||||
sender.SendPacket(cannotAffordMessage);
|
||||
|
@ -1908,15 +1919,15 @@ namespace HISP.Server
|
|||
}
|
||||
|
||||
List<WildHorse> horsesFound = new List<WildHorse>();
|
||||
foreach(WildHorse horse in WildHorse.WildHorses)
|
||||
foreach (WildHorse horse in WildHorse.WildHorses)
|
||||
{
|
||||
if(horse.Instance.Breed.Id == breedId)
|
||||
if (horse.Instance.Breed.Id == breedId)
|
||||
{
|
||||
horsesFound.Add(horse);
|
||||
}
|
||||
}
|
||||
int cost = 0;
|
||||
if(horsesFound.Count >= 1)
|
||||
if (horsesFound.Count >= 1)
|
||||
{
|
||||
cost = 50000;
|
||||
}
|
||||
|
@ -1931,11 +1942,11 @@ namespace HISP.Server
|
|||
|
||||
byte[] serachResultMeta = PacketBuilder.CreateMetaPacket(Meta.BuildWhisperSearchResults(horsesFound.ToArray()));
|
||||
sender.SendPacket(serachResultMeta);
|
||||
|
||||
|
||||
sender.LoggedinUser.Money -= cost;
|
||||
break;
|
||||
}
|
||||
else if(buttonIdStr.StartsWith("4c")) // Libary Breed Search
|
||||
else if (buttonIdStr.StartsWith("4c")) // Libary Breed Search
|
||||
{
|
||||
string idStr = buttonIdStr.Substring(2);
|
||||
int breedId = -1;
|
||||
|
@ -1945,9 +1956,10 @@ namespace HISP.Server
|
|||
breedId = int.Parse(idStr);
|
||||
horseBreed = HorseInfo.GetBreedById(breedId);
|
||||
}
|
||||
catch (Exception) {
|
||||
catch (Exception)
|
||||
{
|
||||
Logger.DebugPrint(sender.LoggedinUser.Username + " Sent invalid libary breed viewer request.");
|
||||
break;
|
||||
break;
|
||||
};
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
string metaTag = Meta.BuildBreedViewerLibary(horseBreed);
|
||||
|
@ -1959,7 +1971,144 @@ namespace HISP.Server
|
|||
sender.SendPacket(loadSwf);
|
||||
|
||||
break;
|
||||
|
||||
|
||||
}
|
||||
else if(buttonIdStr.StartsWith("50c"))
|
||||
{
|
||||
string gender = buttonIdStr.Substring(3);
|
||||
if (sender.LoggedinUser.PawneerOrderBreed != null)
|
||||
{
|
||||
if (sender.LoggedinUser.PawneerOrderBreed.GenderTypes().Contains(gender))
|
||||
{
|
||||
if(sender.LoggedinUser.Inventory.HasItemId(Item.PawneerOrder))
|
||||
{
|
||||
sender.LoggedinUser.PawneerOrderGender = gender;
|
||||
|
||||
HorseInstance horseInstance = new HorseInstance(sender.LoggedinUser.PawneerOrderBreed);
|
||||
horseInstance.Color = sender.LoggedinUser.PawneerOrderColor;
|
||||
horseInstance.Sex = sender.LoggedinUser.PawneerOrderGender;
|
||||
horseInstance.Name = "Pawneer Order";
|
||||
|
||||
sender.LoggedinUser.Inventory.Remove(sender.LoggedinUser.Inventory.GetItemByItemId(Item.PawneerOrder).ItemInstances[0]);
|
||||
sender.LoggedinUser.HorseInventory.AddHorse(horseInstance);
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
metaPacket = PacketBuilder.CreateMetaPacket(Meta.BuildPawneerOrderFound(horseInstance));
|
||||
sender.SendPacket(metaPacket);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
Logger.ErrorPrint(sender.LoggedinUser.Username + " Error occured when doing a Pawneer Order.");
|
||||
break;
|
||||
}
|
||||
else if(buttonIdStr.StartsWith("49c"))
|
||||
{
|
||||
string color = buttonIdStr.Substring(3);
|
||||
if(sender.LoggedinUser.PawneerOrderBreed != null)
|
||||
{
|
||||
if(sender.LoggedinUser.PawneerOrderBreed.Colors.Contains(color))
|
||||
{
|
||||
sender.LoggedinUser.PawneerOrderColor = color;
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
metaPacket = PacketBuilder.CreateMetaPacket(Meta.BuildPawneerOrderGenderList(sender.LoggedinUser.PawneerOrderBreed, color));
|
||||
sender.SendPacket(metaPacket);
|
||||
break;
|
||||
}
|
||||
}
|
||||
Logger.ErrorPrint(sender.LoggedinUser.Username + " Asked for a horse of an unknown color " + color);
|
||||
break;
|
||||
}
|
||||
else if (buttonIdStr.StartsWith("48c")) // Pawneer Order Breed Select
|
||||
{
|
||||
string idStr = buttonIdStr.Substring(3);
|
||||
int breedId = -1;
|
||||
HorseInfo.Breed breed;
|
||||
try
|
||||
{
|
||||
breedId = int.Parse(idStr);
|
||||
breed = HorseInfo.GetBreedById(breedId);
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
Logger.DebugPrint(sender.LoggedinUser.Username + " Tried to pawner order a horse with id NaN.");
|
||||
break;
|
||||
}
|
||||
sender.LoggedinUser.PawneerOrderBreed = breed;
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
metaPacket = PacketBuilder.CreateMetaPacket(Meta.BuildPawneerOrderColorList(breed));
|
||||
sender.SendPacket(metaPacket);
|
||||
break;
|
||||
}
|
||||
else if (buttonIdStr.StartsWith("43c")) // Pawn Horse Confirm
|
||||
{
|
||||
string idStr = buttonIdStr.Substring(3);
|
||||
int horseId = -1;
|
||||
try
|
||||
{
|
||||
horseId = int.Parse(idStr);
|
||||
}
|
||||
catch (FormatException)
|
||||
{
|
||||
Logger.DebugPrint(sender.LoggedinUser.Username + " Tried to pawn a horse with id NaN.");
|
||||
break;
|
||||
}
|
||||
|
||||
if (sender.LoggedinUser.HorseInventory.HorseIdExist(horseId))
|
||||
{
|
||||
HorseInstance inst = sender.LoggedinUser.HorseInventory.GetHorseById(horseId);
|
||||
int price = Pawneer.CalculateTotalPrice(inst);
|
||||
string name = inst.Name;
|
||||
|
||||
sender.LoggedinUser.HorseInventory.DeleteHorse(inst); // 1000% a "distant land.."
|
||||
sender.LoggedinUser.LastViewedHorse = null;
|
||||
|
||||
sender.LoggedinUser.Money += price;
|
||||
byte[] soldHorseMessage = PacketBuilder.CreateChat(Messages.FormatPawneerSold(name, price), PacketBuilder.CHAT_BOTTOM_RIGHT);
|
||||
sender.SendPacket(soldHorseMessage);
|
||||
|
||||
UpdateArea(sender);
|
||||
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
byte[] cantFindHorse = PacketBuilder.CreateChat(Messages.PawneerHorseNotFound, PacketBuilder.CHAT_BOTTOM_RIGHT);
|
||||
sender.SendPacket(cantFindHorse);
|
||||
}
|
||||
break;
|
||||
}
|
||||
else if (buttonIdStr.StartsWith("51c")) // Pawn Horse
|
||||
{
|
||||
string idStr = buttonIdStr.Substring(3);
|
||||
int horseId = -1;
|
||||
try
|
||||
{
|
||||
horseId = int.Parse(idStr);
|
||||
}
|
||||
catch (FormatException)
|
||||
{
|
||||
Logger.DebugPrint(sender.LoggedinUser.Username + " Tried to pawn a horse with id NaN.");
|
||||
break;
|
||||
}
|
||||
|
||||
if (sender.LoggedinUser.HorseInventory.HorseIdExist(horseId))
|
||||
{
|
||||
HorseInstance inst = sender.LoggedinUser.HorseInventory.GetHorseById(horseId);
|
||||
|
||||
sender.LoggedinUser.MetaPriority = true;
|
||||
byte[] confirmScreen = PacketBuilder.CreateMetaPacket(Meta.BuildPawneerConfimation(inst));
|
||||
sender.SendPacket(confirmScreen);
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
byte[] cantFindHorse = PacketBuilder.CreateChat(Messages.PawneerHorseNotFound, PacketBuilder.CHAT_BOTTOM_RIGHT);
|
||||
sender.SendPacket(cantFindHorse);
|
||||
}
|
||||
break;
|
||||
}
|
||||
if(AbuseReport.DoesReasonExist(buttonIdStr))
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue