2019-05-16 04:43:09 +08:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Linq;
|
|
|
|
using System.Text;
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
using Microsoft.Xna.Framework;
|
2019-05-16 05:27:33 +08:00
|
|
|
using Microsoft.Xna.Framework.Graphics;
|
2019-05-16 14:50:24 +08:00
|
|
|
using Microsoft.Xna.Framework.Input;
|
2019-08-28 10:42:05 +08:00
|
|
|
using Newtonsoft.Json;
|
2019-05-16 04:43:09 +08:00
|
|
|
using PyTK.CustomElementHandler;
|
|
|
|
using Revitalize.Framework.Objects.InformationFiles.Furniture;
|
2019-05-16 13:27:38 +08:00
|
|
|
using Revitalize.Framework.Utilities.Serialization;
|
2019-05-16 04:43:09 +08:00
|
|
|
using StardewValley;
|
|
|
|
|
|
|
|
namespace Revitalize.Framework.Objects.Furniture
|
|
|
|
{
|
|
|
|
public class TableTileComponent : FurnitureTileComponent
|
|
|
|
{
|
|
|
|
public TableInformation furnitureInfo;
|
|
|
|
|
2019-05-16 13:27:38 +08:00
|
|
|
|
2019-08-28 10:42:05 +08:00
|
|
|
[JsonIgnore]
|
2019-05-16 04:43:09 +08:00
|
|
|
public bool CanPlaceItemsHere
|
|
|
|
{
|
|
|
|
get
|
|
|
|
{
|
|
|
|
return this.furnitureInfo.canPlaceItemsHere;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-16 13:27:38 +08:00
|
|
|
public enum PickUpState
|
|
|
|
{
|
|
|
|
RemoveContainer,
|
|
|
|
DoNothing,
|
|
|
|
}
|
|
|
|
|
2019-05-16 04:43:09 +08:00
|
|
|
|
|
|
|
public TableTileComponent() : base()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-07-16 17:09:42 +08:00
|
|
|
public TableTileComponent(CustomObjectData PyTKData,BasicItemInformation Info, TableInformation FurnitureInfo) : base(PyTKData,Info)
|
2019-05-16 04:43:09 +08:00
|
|
|
{
|
|
|
|
this.furnitureInfo = FurnitureInfo;
|
2019-08-21 16:39:06 +08:00
|
|
|
this.Price = Info.price;
|
2019-05-16 04:43:09 +08:00
|
|
|
}
|
|
|
|
|
2019-07-16 17:09:42 +08:00
|
|
|
public TableTileComponent(CustomObjectData PyTKData,BasicItemInformation Info, Vector2 TileLocation, TableInformation FurnitureInfo) : base(PyTKData,Info, TileLocation)
|
2019-05-16 04:43:09 +08:00
|
|
|
{
|
|
|
|
this.furnitureInfo = FurnitureInfo;
|
2019-08-21 16:39:06 +08:00
|
|
|
this.Price = Info.price;
|
2019-05-16 04:43:09 +08:00
|
|
|
}
|
|
|
|
|
2019-08-28 06:10:56 +08:00
|
|
|
public override void updateWhenCurrentLocation(GameTime time, GameLocation environment)
|
|
|
|
{
|
|
|
|
base.updateWhenCurrentLocation(time, environment);
|
|
|
|
}
|
|
|
|
|
2019-05-17 04:00:43 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Forcefully clears the held object without much fuss.
|
|
|
|
/// </summary>
|
|
|
|
public void clearHeldObject()
|
2019-05-16 04:43:09 +08:00
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
if (this.heldObject.Value != null)
|
2019-05-16 13:27:38 +08:00
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
if (Game1.player.isInventoryFull() == false)
|
2019-05-18 00:43:50 +08:00
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
Game1.player.addItemToInventoryBool(this.heldObject.Value, false);
|
|
|
|
this.heldObject.Value = null;
|
|
|
|
return;
|
2019-05-16 13:27:38 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
Game1.createItemDebris(this.heldObject.Value, Vector2.Zero, 0);
|
2019-05-16 13:27:38 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-05-16 14:50:24 +08:00
|
|
|
|
2019-05-17 04:00:43 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Picks up the held item from this tile.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="justChecking"></param>
|
|
|
|
/// <returns></returns>
|
|
|
|
public PickUpState pickUpItem(bool justChecking = true)
|
2019-05-16 14:50:24 +08:00
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
if (this.heldObject.Value == null && Game1.player.ActiveObject != null)
|
2019-05-16 14:50:24 +08:00
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
if (justChecking == false)
|
2019-05-16 14:50:24 +08:00
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
this.heldObject.Value = (StardewValley.Object)Game1.player.ActiveObject.getOne();
|
|
|
|
Game1.player.reduceActiveItemByOne();
|
2019-05-16 14:50:24 +08:00
|
|
|
}
|
2019-05-17 04:00:43 +08:00
|
|
|
return PickUpState.DoNothing;
|
|
|
|
}
|
|
|
|
else if (this.heldObject.Value != null)
|
|
|
|
{
|
|
|
|
if (justChecking == false)
|
2019-05-16 14:50:24 +08:00
|
|
|
{
|
|
|
|
if (Game1.player.isInventoryFull() == false)
|
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
Game1.player.addItemToInventoryBool(this.heldObject.Value, false);
|
|
|
|
this.heldObject.Value = null;
|
2019-05-16 14:50:24 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
Game1.createItemDebris(this.heldObject.Value, Vector2.Zero, 0);
|
2019-05-16 14:50:24 +08:00
|
|
|
}
|
|
|
|
}
|
2019-05-17 04:00:43 +08:00
|
|
|
return PickUpState.DoNothing;
|
|
|
|
}
|
|
|
|
else if (this.heldObject.Value == null && Game1.player.ActiveObject == null)
|
|
|
|
{
|
|
|
|
return PickUpState.RemoveContainer;
|
2019-05-16 14:50:24 +08:00
|
|
|
}
|
2019-05-17 04:00:43 +08:00
|
|
|
|
|
|
|
|
2019-05-16 14:50:24 +08:00
|
|
|
return PickUpState.DoNothing;
|
2019-05-17 04:00:43 +08:00
|
|
|
|
2019-05-16 14:50:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-08-28 06:10:56 +08:00
|
|
|
public override bool placementAction(GameLocation location, int x, int y, Farmer who = null)
|
|
|
|
{
|
|
|
|
this.updateInfo();
|
|
|
|
return base.placementAction(location, x, y, who);
|
|
|
|
}
|
2019-05-16 13:27:38 +08:00
|
|
|
public override bool performObjectDropInAction(Item dropInItem, bool probe, Farmer who)
|
|
|
|
{
|
2019-05-16 14:50:24 +08:00
|
|
|
return false; //this.pickUpItem()==PickUpState.DoNothing;
|
2019-05-16 13:27:38 +08:00
|
|
|
//return base.performObjectDropInAction(dropInItem, probe, who);
|
2019-05-16 04:43:09 +08:00
|
|
|
}
|
|
|
|
|
2019-05-16 13:27:38 +08:00
|
|
|
public override bool performDropDownAction(Farmer who)
|
2019-05-16 04:43:09 +08:00
|
|
|
{
|
2019-05-16 13:27:38 +08:00
|
|
|
return base.performDropDownAction(who);
|
|
|
|
}
|
|
|
|
|
2019-05-17 04:00:43 +08:00
|
|
|
//Checks for any sort of interaction IF and only IF there is a held object on this tile.
|
2019-05-16 13:27:38 +08:00
|
|
|
public override bool checkForAction(Farmer who, bool justCheckingForActivity = false)
|
|
|
|
{
|
2019-05-16 14:50:24 +08:00
|
|
|
MouseState mState = Mouse.GetState();
|
|
|
|
KeyboardState keyboardState = Game1.GetKeyboardState();
|
|
|
|
|
|
|
|
if (mState.RightButton == ButtonState.Pressed && (keyboardState.IsKeyDown(Keys.LeftShift) || !keyboardState.IsKeyDown(Keys.RightShift)))
|
|
|
|
{
|
|
|
|
return this.rightClicked(who);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mState.RightButton == ButtonState.Pressed && (keyboardState.IsKeyDown(Keys.LeftShift) || keyboardState.IsKeyDown(Keys.RightShift)))
|
|
|
|
return this.shiftRightClicked(who);
|
|
|
|
|
|
|
|
|
|
|
|
//return base.checkForAction(who, justCheckingForActivity);
|
|
|
|
|
|
|
|
if (justCheckingForActivity)
|
|
|
|
return true;
|
2019-05-17 04:00:43 +08:00
|
|
|
|
2019-05-16 14:50:24 +08:00
|
|
|
this.pickUpItem(false);
|
|
|
|
return true;
|
|
|
|
|
|
|
|
//return this.clicked(who);
|
|
|
|
//return false;
|
2019-05-16 13:27:38 +08:00
|
|
|
}
|
|
|
|
|
2019-05-17 04:00:43 +08:00
|
|
|
public override bool performToolAction(Tool t, GameLocation location)
|
|
|
|
{
|
|
|
|
return base.performToolAction(t, location);
|
|
|
|
}
|
|
|
|
|
|
|
|
public override bool performUseAction(GameLocation location)
|
|
|
|
{
|
|
|
|
return base.performUseAction(location);
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Gets called when there is no actively held item on the tile.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="who"></param>
|
|
|
|
/// <returns></returns>
|
2019-05-16 13:27:38 +08:00
|
|
|
public override bool clicked(Farmer who)
|
|
|
|
{
|
2019-05-17 04:00:43 +08:00
|
|
|
if (this.pickUpItem() == PickUpState.DoNothing) return false;
|
2019-05-16 14:50:24 +08:00
|
|
|
return base.clicked(who);
|
2019-05-16 04:43:09 +08:00
|
|
|
}
|
|
|
|
|
2019-05-16 13:27:38 +08:00
|
|
|
|
2019-05-16 04:43:09 +08:00
|
|
|
public override bool shiftRightClicked(Farmer who)
|
|
|
|
{
|
|
|
|
return base.shiftRightClicked(who);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public override Item getOne()
|
|
|
|
{
|
2019-08-17 06:32:14 +08:00
|
|
|
TableTileComponent component = new TableTileComponent(this.data,this.info.Copy(), (TableInformation)this.furnitureInfo);
|
2019-05-16 04:43:09 +08:00
|
|
|
component.containerObject = this.containerObject;
|
|
|
|
component.offsetKey = this.offsetKey;
|
|
|
|
return component;
|
|
|
|
}
|
|
|
|
|
|
|
|
public override ICustomObject recreate(Dictionary<string, string> additionalSaveData, object replacement)
|
|
|
|
{
|
|
|
|
//instead of using this.offsetkey.x use get additional save data function and store offset key there
|
2019-08-22 10:06:17 +08:00
|
|
|
//ModCore.log("Recreate a table tile component!");
|
2019-05-16 04:43:09 +08:00
|
|
|
Vector2 offsetKey = new Vector2(Convert.ToInt32(additionalSaveData["offsetKeyX"]), Convert.ToInt32(additionalSaveData["offsetKeyY"]));
|
2019-08-22 10:06:17 +08:00
|
|
|
//ModCore.log("Got the offset key!");
|
|
|
|
string GUID = additionalSaveData["GUID"];
|
|
|
|
//ModCore.log("This tile has a parent guid of: " + additionalSaveData["ParentGUID"]);
|
2019-05-16 04:43:09 +08:00
|
|
|
TableTileComponent self = Revitalize.ModCore.Serializer.DeserializeGUID<TableTileComponent>(additionalSaveData["GUID"]);
|
2019-08-22 10:06:17 +08:00
|
|
|
|
|
|
|
if (ModCore.IsNullOrDefault<TableTileComponent>(self))
|
2019-05-16 04:43:09 +08:00
|
|
|
{
|
2019-08-22 10:06:17 +08:00
|
|
|
//ModCore.log("SELF IS NULL");
|
2019-05-16 04:43:09 +08:00
|
|
|
return null;
|
|
|
|
}
|
2019-08-22 10:06:17 +08:00
|
|
|
try
|
2019-05-16 04:43:09 +08:00
|
|
|
{
|
2019-08-22 10:06:17 +08:00
|
|
|
if (!Revitalize.ModCore.ObjectGroups.ContainsKey(additionalSaveData["ParentGUID"]))
|
|
|
|
{
|
|
|
|
//ModCore.log("Load in the parent!");
|
|
|
|
//Get new container
|
|
|
|
TableMultiTiledObject obj = (TableMultiTiledObject)Revitalize.ModCore.Serializer.DeserializeGUID<TableMultiTiledObject>(additionalSaveData["ParentGUID"]);
|
|
|
|
self.containerObject = obj;
|
|
|
|
self.containerObject.removeComponent(offsetKey);
|
|
|
|
self.containerObject.addComponent(offsetKey, self);
|
|
|
|
Revitalize.ModCore.ObjectGroups.Add(additionalSaveData["ParentGUID"], obj);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
//ModCore.log("Parent already exists!");
|
|
|
|
self.containerObject = Revitalize.ModCore.ObjectGroups[additionalSaveData["ParentGUID"]];
|
|
|
|
self.containerObject.removeComponent(offsetKey);
|
|
|
|
self.containerObject.addComponent(offsetKey, self);
|
|
|
|
//Revitalize.ModCore.log("READD AN OBJECT!!!!");
|
|
|
|
}
|
2019-05-16 04:43:09 +08:00
|
|
|
}
|
2019-08-22 10:06:17 +08:00
|
|
|
catch(Exception err)
|
2019-05-16 04:43:09 +08:00
|
|
|
{
|
2019-08-22 10:06:17 +08:00
|
|
|
ModCore.log(err);
|
2019-05-16 04:43:09 +08:00
|
|
|
}
|
|
|
|
|
2019-08-22 10:06:17 +08:00
|
|
|
return self;
|
2019-05-16 04:43:09 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public override Dictionary<string, string> getAdditionalSaveData()
|
|
|
|
{
|
|
|
|
Dictionary<string, string> saveData = base.getAdditionalSaveData();
|
2019-08-28 06:10:56 +08:00
|
|
|
if (this.containerObject.childrenGuids.ContainsKey(this.offsetKey))
|
|
|
|
{
|
|
|
|
Revitalize.ModCore.Serializer.SerializeGUID(this.containerObject.childrenGuids[this.offsetKey].ToString(), this);
|
|
|
|
}
|
2019-08-22 10:06:17 +08:00
|
|
|
this.containerObject.getAdditionalSaveData();
|
2019-05-16 04:43:09 +08:00
|
|
|
return saveData;
|
|
|
|
|
|
|
|
}
|
2019-05-16 05:27:33 +08:00
|
|
|
|
|
|
|
/// <summary>What happens when the object is drawn at a tile location.</summary>
|
|
|
|
public override void draw(SpriteBatch spriteBatch, int x, int y, float alpha = 1f)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
if (this.info.ignoreBoundingBox == true)
|
|
|
|
{
|
|
|
|
x *= -1;
|
|
|
|
y *= -1;
|
|
|
|
}
|
|
|
|
*/
|
2019-08-28 06:10:56 +08:00
|
|
|
this.updateInfo();
|
2019-05-16 05:27:33 +08:00
|
|
|
if (this.info == null)
|
|
|
|
{
|
|
|
|
Revitalize.ModCore.log("info is null");
|
|
|
|
if (this.syncObject == null) Revitalize.ModCore.log("DEAD SYNC");
|
|
|
|
}
|
2019-08-27 07:34:03 +08:00
|
|
|
if (this.animationManager == null) Revitalize.ModCore.log("Animation Manager Null");
|
2019-05-16 05:27:33 +08:00
|
|
|
if (this.displayTexture == null) Revitalize.ModCore.log("Display texture is null");
|
|
|
|
|
|
|
|
//The actual planter box being drawn.
|
|
|
|
if (this.animationManager == null)
|
|
|
|
{
|
|
|
|
if (this.animationManager.getExtendedTexture() == null)
|
|
|
|
ModCore.ModMonitor.Log("Tex Extended is null???");
|
|
|
|
|
|
|
|
spriteBatch.Draw(this.displayTexture, Game1.GlobalToLocal(Game1.viewport, new Vector2((float)(x * Game1.tileSize), y * Game1.tileSize)), new Rectangle?(this.animationManager.currentAnimation.sourceRectangle), this.info.drawColor * alpha, 0f, Vector2.Zero, (float)Game1.pixelZoom, this.flipped ? SpriteEffects.FlipHorizontally : SpriteEffects.None, Math.Max(0f, (float)(y * Game1.tileSize) / 10000f));
|
|
|
|
// Log.AsyncG("ANIMATION IS NULL?!?!?!?!");
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
{
|
|
|
|
//Log.AsyncC("Animation Manager is working!");
|
|
|
|
float addedDepth = 0;
|
|
|
|
|
|
|
|
|
|
|
|
if (Revitalize.ModCore.playerInfo.sittingInfo.SittingObject == this.containerObject && this.info.facingDirection == Enums.Direction.Up)
|
|
|
|
{
|
|
|
|
addedDepth += (this.containerObject.Height - 1) - ((int)(this.offsetKey.Y));
|
|
|
|
if (this.info.ignoreBoundingBox) addedDepth += 1.5f;
|
|
|
|
}
|
|
|
|
else if (this.info.ignoreBoundingBox)
|
|
|
|
{
|
|
|
|
addedDepth += 1.0f;
|
|
|
|
}
|
|
|
|
this.animationManager.draw(spriteBatch, this.displayTexture, Game1.GlobalToLocal(Game1.viewport, new Vector2((float)(x * Game1.tileSize), y * Game1.tileSize)), new Rectangle?(this.animationManager.currentAnimation.sourceRectangle), this.info.drawColor * alpha, 0f, Vector2.Zero, (float)Game1.pixelZoom, this.flipped ? SpriteEffects.FlipHorizontally : SpriteEffects.None, Math.Max(0f, (float)((y + addedDepth) * Game1.tileSize) / 10000f) + .00001f);
|
|
|
|
try
|
|
|
|
{
|
|
|
|
this.animationManager.tickAnimation();
|
|
|
|
// Log.AsyncC("Tick animation");
|
|
|
|
}
|
|
|
|
catch (Exception err)
|
|
|
|
{
|
|
|
|
ModCore.ModMonitor.Log(err.ToString());
|
|
|
|
}
|
2019-05-17 04:00:43 +08:00
|
|
|
if (this.heldObject.Value != null) SpriteBatchUtilities.Draw(spriteBatch, this, this.heldObject.Value, alpha, addedDepth);
|
2019-05-16 05:27:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// spriteBatch.Draw(Game1.mouseCursors, Game1.GlobalToLocal(Game1.viewport, new Vector2((float)((double)tileLocation.X * (double)Game1.tileSize + (((double)tileLocation.X * 11.0 + (double)tileLocation.Y * 7.0) % 10.0 - 5.0)) + (float)(Game1.tileSize / 2), (float)((double)tileLocation.Y * (double)Game1.tileSize + (((double)tileLocation.Y * 11.0 + (double)tileLocation.X * 7.0) % 10.0 - 5.0)) + (float)(Game1.tileSize / 2))), new Rectangle?(new Rectangle((int)((double)tileLocation.X * 51.0 + (double)tileLocation.Y * 77.0) % 3 * 16, 128 + this.whichForageCrop * 16, 16, 16)), Color.White, 0.0f, new Vector2(8f, 8f), (float)Game1.pixelZoom, SpriteEffects.None, (float)(((double)tileLocation.Y * (double)Game1.tileSize + (double)(Game1.tileSize / 2) + (((double)tileLocation.Y * 11.0 + (double)tileLocation.X * 7.0) % 10.0 - 5.0)) / 10000.0));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-08-28 06:10:56 +08:00
|
|
|
public override void draw(SpriteBatch spriteBatch, int xNonTile, int yNonTile, float layerDepth, float alpha = 1)
|
|
|
|
{
|
|
|
|
this.updateInfo();
|
|
|
|
base.draw(spriteBatch, xNonTile, yNonTile, layerDepth, alpha);
|
|
|
|
}
|
|
|
|
|
|
|
|
public override void drawInMenu(SpriteBatch spriteBatch, Vector2 location, float scaleSize, float transparency, float layerDepth, bool drawStackNumber, Color c, bool drawShadow)
|
|
|
|
{
|
|
|
|
this.updateInfo();
|
|
|
|
base.drawInMenu(spriteBatch, location, scaleSize, transparency, layerDepth, drawStackNumber, c, drawShadow);
|
|
|
|
}
|
|
|
|
|
|
|
|
public override void drawWhenHeld(SpriteBatch spriteBatch, Vector2 objectPosition, Farmer f)
|
|
|
|
{
|
|
|
|
this.updateInfo();
|
|
|
|
base.drawWhenHeld(spriteBatch, objectPosition, f);
|
|
|
|
}
|
2019-05-16 04:43:09 +08:00
|
|
|
}
|
|
|
|
}
|