Class FurniturePlacer
A helper class that represents a tool part which allows the placement and movement of furniture objects. This class is used by FurnitureTool and MoveTool.
public class FurniturePlacer
- Inheritance
-
FurniturePlacer
- Inherited Members
- Extension Methods
Constructors
FurniturePlacer(Action<Furniture, UndoableAction>)
Creates a new furniture placer with the given settings
public FurniturePlacer(Action<Furniture, UndoableAction> onPlaced = null)
Parameters
onPlaced
Action<Furniture, UndoableAction>An action that is invoked when the given furniture is placed by this placer
Properties
SelectedColors
The color indices that are currently selected for the SelectedFurniture
public int[] SelectedColors { get; }
Property Value
- int[]
SelectedFurniture
The FurnitureType that is currently selected for placement
public FurnitureType SelectedFurniture { get; }
Property Value
SelectedPreview
An instance of the SelectedFurniture
public Furniture SelectedPreview { get; }
Property Value
Methods
CanPlace()
Determines whether the currently selected furniture can be placed at the current position.
public CanPlaceResult CanPlace()
Returns
- CanPlaceResult
Whether the currently selected furniture can be placed at the current position.
Draw(GameTime, SpriteBatch)
Draws the SelectedPreview of this furniture placer
public void Draw(GameTime time, SpriteBatch batch)
Parameters
time
GameTimeThe game's time
batch
SpriteBatchThe sprite batch to use for drawing
GetCurrentCanPlaceResult()
Returns whether or not the tool should currently be considered to be able to place objects for a tooltip displayed to the player.
public CanPlaceResult GetCurrentCanPlaceResult()
Returns
- CanPlaceResult
A CanPlaceResult that represents whether the tool should be considered to be able to place objects.
GetCustomPrice(Furniture)
Returns the custom price that the given Furniture should be sold with on the furniture tool. This is influenced by the CurrentHousehold's people's personalities, as well as the OnGetCustomPrice event.
public static float? GetCustomPrice(Furniture furniture)
Parameters
furniture
FurnitureThe furniture whose price to get
Returns
- float?
The furniture's custom price, or null to use the default price
GetMouseCursor()
Returns the CursorType that this tool should currently display. By default, Default is returned.
public CursorType GetMouseCursor()
Returns
- CursorType
The cursor type
PlaceFurniture()
Causes the currently selected furniture to be placed at the current position, and returned.
public Furniture PlaceFurniture()
Returns
- Furniture
The placed furniture.
SelectFurniture(FurnitureType, Furniture, Action<Furniture>, Direction2, int[], bool)
Selects the given FurnitureType.
If exact
is enabled, the preview
is the exact furniture instance that will be placed. If it is false, a new instance of the given furniture
will be created upon placement.
public void SelectFurniture(FurnitureType furniture, Furniture preview, Action<Furniture> variation, Direction2 rotation, int[] colors, bool exact = false)
Parameters
furniture
FurnitureTypeThe furniture type to select
preview
FurnitureAn instance of the given
furniture
variation
Action<Furniture>A function that represents a furniture variation to place
rotation
Direction2The rotation to select
colors
int[]The colors to select
exact
boolWhether or not the
preview
is the exact instance that should be placed
ShouldHighlightSelectedObject(object)
Whether or not the SelectedObject should currently have a white highlight around it. This method defaults to return true if IsCursorOnUi() is false.
public bool ShouldHighlightSelectedObject(object obj)
Parameters
Returns
- bool
Whether or not the selected object should be highlighted
UnselectFurniture()
Unselects the currently SelectedFurniture
public void UnselectFurniture()
Update()
Updates this furniture placer. This should be called in Update(GameTime, bool) each frame.
public void Update()
Events
OnFurniturePlaced
An event that is invoked when a furniture item is placed using this furniture placer. The passed UndoableAction can optionally be used to add additional things that should be undone/redone when the action is undone/redone.
public static event Action<Furniture, UndoableAction> OnFurniturePlaced
Event Type
OnGetCustomPrice
An event that is invoked when GetCustomPrice(Furniture) is called. Use this event to change the custom price of a furniture item bought in the furniture tool.
public static event FurniturePlacer.GetCustomPriceDelegate OnGetCustomPrice