1218 lines
48 KiB
VB.net
1218 lines
48 KiB
VB.net
Imports P3D.Screens.UI
|
|
|
|
''' <summary>
|
|
''' Displays the inventory and gives the player options to choose and use items.
|
|
''' </summary>
|
|
Public Class NewInventoryScreen
|
|
|
|
Inherits Screen
|
|
Implements ISelectionScreen
|
|
|
|
'Private _translation As Globalization.Classes.LOCAL_InventoryScreen
|
|
|
|
Private target_1 As RenderTarget2D
|
|
Private target_2 As RenderTarget2D
|
|
Private itemBatch As CoreSpriteBatch
|
|
Private infoBatch As CoreSpriteBatch
|
|
|
|
''' <summary>
|
|
''' Texture from file: GUI\Menus\General
|
|
''' </summary>
|
|
Private _texture As Texture2D
|
|
|
|
''' <summary>
|
|
''' Texture from file: GUI\Menus\Inventory
|
|
''' </summary>
|
|
Private _menuTexture As Texture2D
|
|
|
|
'Stores the current tab index and if the player is controlling the tab list:
|
|
Private _tabIndex As Integer = 0
|
|
Private _tabInControl As Boolean = True
|
|
|
|
'We have 8 indexes for the current page and item on that page (0-9) here, for each tab:
|
|
Private _itemindex As Integer() = {0, 0, 0, 0, 0, 0, 0, 0}
|
|
Private _pageIndex As Integer() = {0, 0, 0, 0, 0, 0, 0, 0}
|
|
|
|
'Shows amount window if tossing item when true
|
|
Private _tossingItems As Boolean = False
|
|
Private _tossValue As Integer = 1
|
|
|
|
'Stuff related to blurred PreScreens
|
|
Private _preScreenTexture As RenderTarget2D
|
|
Private _preScreenTarget As RenderTarget2D
|
|
Private _blurScreens As Identifications() = {Identifications.BattleScreen,
|
|
Identifications.OverworldScreen,
|
|
Identifications.MailSystemScreen}
|
|
|
|
''' <summary>
|
|
''' The item index of the current tab and page:
|
|
''' </summary>
|
|
Private Property ItemIndex As Integer
|
|
Get
|
|
Return _itemindex(_tabIndex)
|
|
End Get
|
|
Set(value As Integer)
|
|
_itemindex(_tabIndex) = value
|
|
End Set
|
|
End Property
|
|
|
|
''' <summary>
|
|
''' The page index for the current tab.
|
|
''' </summary>
|
|
Private Property PageIndex As Integer
|
|
Get
|
|
Return _pageIndex(_tabIndex)
|
|
End Get
|
|
Set(value As Integer)
|
|
_pageIndex(_tabIndex) = value
|
|
End Set
|
|
End Property
|
|
|
|
'Stores a value from 0-255 for each tab that determines their light state when scrolling over it.
|
|
Private _tabHighlight As Integer() = {0, 0, 0, 0, 0, 0, 0, 0}
|
|
|
|
'Interface animation state values:
|
|
Private _interfaceFade As Single = 0F
|
|
Private _closing As Boolean = False
|
|
Private _enrollY As Single = 0F
|
|
Private _itemIntro As Single = 0F
|
|
|
|
'Item animation:
|
|
Private Class ItemAnimation
|
|
Public _shakeV As Single
|
|
Public _shakeLeft As Boolean
|
|
Public _shakeCount As Integer
|
|
End Class
|
|
'The current state for the item animations:
|
|
Private _itemAnimation As ItemAnimation
|
|
|
|
'If the info popup is visible:
|
|
Private _isInfoShowing As Boolean = False
|
|
|
|
'Info popup state information:
|
|
Private _infoSide As Integer = 0 '0 = left, 1 = right
|
|
Private _infoSize As Integer = 0
|
|
Private _infoSizeTarget As Integer = 0
|
|
Private _infoPosition As Integer = 0
|
|
Private _infoPositionTarget As Integer = 0
|
|
|
|
Private _itemColumnLeft As Integer = 0 'Until which item column is considered left
|
|
Private _itemColumnLeftOffset As Integer = 0
|
|
Private _itemColumnLeftOffsetTarget As Integer = 0
|
|
Private _itemColumnRightOffset As Integer = 0
|
|
Private _itemColumnRightOffsetTarget As Integer = 0
|
|
|
|
'Selectable options for items.
|
|
' - Use
|
|
' - Give (to pokémon)
|
|
' - Toss
|
|
' - Select
|
|
|
|
'#EC_NO_TRANSLATION:
|
|
Private Const INFO_ITEM_OPTION_USE As String = "USE"
|
|
Private Const INFO_ITEM_OPTION_GIVE As String = "GIVE"
|
|
Private Const INFO_ITEM_OPTION_TOSS As String = "TOSS"
|
|
Private Const INFO_ITEM_OPTION_SELECT As String = "SELECT"
|
|
|
|
Private _infoItemOptions As New List(Of String)
|
|
Private _infoItemOptionsNormal As New List(Of String) 'Contains untranslated strings.
|
|
Private _infoItemOptionSize As Integer() = {0, 0, 0}
|
|
Private _infoItemOptionSelection As Integer = 0
|
|
|
|
'Items for the current tab:
|
|
Private _items As PlayerInventory.ItemContainer()
|
|
|
|
'Displays a message box:
|
|
Private _messageDelay As Single = 0F
|
|
Private _messageText As String = ""
|
|
|
|
'experiment
|
|
Public Delegate Sub DoStuff(ByVal ItemID As Integer)
|
|
Dim ReturnItem As DoStuff
|
|
Dim AllowedPages() As Integer
|
|
|
|
Public Sub New(ByVal currentScreen As Screen, ByVal AllowedPages As Integer(), ByVal StartPageIndex As Integer, ByVal DoStuff As DoStuff)
|
|
|
|
_preScreenTarget = New RenderTarget2D(GraphicsDevice, windowSize.Width, windowSize.Height)
|
|
_blur = New Resources.Blur.BlurHandler(windowSize.Width, windowSize.Height)
|
|
|
|
_tabIndex = StartPageIndex
|
|
_pageIndex = Player.Temp.BagPageIndex
|
|
_itemindex = Player.Temp.BagItemIndex
|
|
|
|
Me.AllowedPages = AllowedPages
|
|
ReturnItem = DoStuff
|
|
|
|
'JSON Stuff
|
|
'_translation = New Globalization.Classes.LOCAL_InventoryScreen()
|
|
target_1 = New RenderTarget2D(GraphicsDevice, 816, 400 - 32, False, SurfaceFormat.Color, DepthFormat.Depth24Stencil8, 0, RenderTargetUsage.PreserveContents)
|
|
target_2 = New RenderTarget2D(GraphicsDevice, 500, 368, False, SurfaceFormat.Color, DepthFormat.Depth24Stencil8)
|
|
itemBatch = New CoreSpriteBatch(GraphicsDevice)
|
|
infoBatch = New CoreSpriteBatch(GraphicsDevice)
|
|
|
|
Identification = Identifications.InventoryScreen
|
|
PreScreen = currentScreen
|
|
IsDrawingGradients = True
|
|
|
|
_texture = TextureManager.GetTexture("GUI\Menus\General")
|
|
_menuTexture = TextureManager.GetTexture("GUI\Menus\Inventory")
|
|
|
|
''DEBUG: Add all items in the game to the inventory:
|
|
'For i = 1 To 2500
|
|
' Dim cItem As Item = Item.GetItemByID(i)
|
|
' If Not cItem Is Nothing Then
|
|
' Core.Player.Inventory.AddItem(cItem.ID, 1)
|
|
' End If
|
|
'Next
|
|
|
|
ResetAnimation()
|
|
|
|
' Set up the default visible item types configuration:
|
|
_visibleItemTypes = New Items.ItemTypes() {Items.ItemTypes.Standard,
|
|
Items.ItemTypes.Medicine,
|
|
Items.ItemTypes.Plants,
|
|
Items.ItemTypes.Pokéballs,
|
|
Items.ItemTypes.Machines,
|
|
Items.ItemTypes.Mail,
|
|
Items.ItemTypes.BattleItems,
|
|
Items.ItemTypes.KeyItems}
|
|
|
|
'TODO: Load state information from the PlayerTemp.
|
|
|
|
_tabHighlight(_tabIndex) = 255
|
|
|
|
'Load the items once when loading up the inventory screen:
|
|
LoadItems()
|
|
End Sub
|
|
|
|
Public Sub New(ByVal currentScreen As Screen, ByVal AllowedPages() As Integer, ByVal DoStuff As DoStuff)
|
|
Me.New(currentScreen, AllowedPages, Player.Temp.BagIndex, DoStuff)
|
|
End Sub
|
|
|
|
Public Sub New(ByVal currentScreen As Screen)
|
|
Me.New(currentScreen, {}, Player.Temp.BagIndex, Nothing)
|
|
End Sub
|
|
|
|
Public Overrides Sub Draw()
|
|
If _blurScreens.Contains(PreScreen.Identification) Then
|
|
DrawPrescreen()
|
|
Else
|
|
PreScreen.Draw()
|
|
End If
|
|
DrawGradients(CInt(255 * _interfaceFade))
|
|
|
|
|
|
DrawMain()
|
|
DrawTabs()
|
|
|
|
DrawMessage()
|
|
|
|
PokemonImageView.Draw()
|
|
ImageView.Draw()
|
|
TextBox.Draw()
|
|
ChooseBox.Draw()
|
|
|
|
DrawAmount()
|
|
End Sub
|
|
|
|
Private _blur As Resources.Blur.BlurHandler
|
|
|
|
Private Sub DrawPrescreen()
|
|
If _preScreenTexture Is Nothing OrElse _preScreenTexture.IsContentLost Then
|
|
SpriteBatch.EndBatch()
|
|
Dim target As RenderTarget2D = _preScreenTarget
|
|
GraphicsDevice.SetRenderTarget(target)
|
|
GraphicsDevice.Clear(BackgroundColor)
|
|
SpriteBatch.BeginBatch()
|
|
PreScreen.Draw()
|
|
SpriteBatch.EndBatch()
|
|
GraphicsDevice.SetRenderTarget(Nothing)
|
|
SpriteBatch.BeginBatch()
|
|
_preScreenTexture = target
|
|
End If
|
|
SpriteBatch.Draw(_blur.Perform(_preScreenTexture), windowSize, Color.White)
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Draws the temporary message.
|
|
''' </summary>
|
|
Private Sub DrawMessage()
|
|
If _messageDelay > 0F Then
|
|
Dim textFade As Single = 1.0F
|
|
If _messageDelay <= 1.0F Then
|
|
textFade = _messageDelay
|
|
End If
|
|
|
|
Canvas.DrawRectangle(New Rectangle(CInt(Core.windowSize.Width / 2 - 150), CInt(Core.windowSize.Height - 200), 300, 100), New Color(0, 0, 0, CInt(150 * textFade * _interfaceFade)))
|
|
|
|
Dim text As String = _messageText.CropStringToWidth(FontManager.ChatFont, 250)
|
|
Dim size As Vector2 = FontManager.ChatFont.MeasureString(text)
|
|
|
|
SpriteBatch.DrawString(FontManager.ChatFont, text, New Vector2(CSng(Core.windowSize.Width / 2 - size.X / 2), CSng(Core.windowSize.Height - 150 - size.Y / 2)), New Color(255, 255, 255, CInt(255 * textFade * _interfaceFade)))
|
|
End If
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Draws the tabs on the top of the UI.
|
|
''' </summary>
|
|
Private Sub DrawTabs()
|
|
Dim halfWidth As Integer = CInt(Core.windowSize.Width / 2)
|
|
Dim halfHeight As Integer = CInt(Core.windowSize.Height / 2)
|
|
Dim mainBackgroundColor As Color = Color.White
|
|
If _closing = True Then
|
|
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
|
|
End If
|
|
|
|
For x = 0 To 368 Step 16
|
|
Dim cTabIndex As Integer = CInt(Math.Floor(x / 48))
|
|
Dim bgColor As Color = Color.White
|
|
|
|
If cTabIndex <> _tabIndex And cTabIndex < _tabHighlight.Length Then
|
|
Dim gC As Integer = 128 + CInt(128 * (_tabHighlight(cTabIndex) / 255))
|
|
bgColor = New Color(gC, gC, gC)
|
|
End If
|
|
|
|
If _closing Then
|
|
bgColor = New Color(bgColor.R, bgColor.G, bgColor.B, CInt(CInt(bgColor.A) * _interfaceFade))
|
|
End If
|
|
|
|
For y = 0 To 32 Step 16
|
|
SpriteBatch.Draw(_menuTexture, New Rectangle(halfWidth - 400 + x, halfHeight - 200 + y, 16, 16), New Rectangle(0, 0, 4, 4), bgColor)
|
|
Next
|
|
If x Mod 48 = 32 Then
|
|
SpriteBatch.Draw(_menuTexture, New Rectangle(halfWidth - 400 + x - 24, halfHeight - 200 + 8, 32, 32), GetTabImageRect(cTabIndex), bgColor)
|
|
End If
|
|
Next
|
|
|
|
Dim TabDesriptionWidth As Integer = 176
|
|
Dim TbgColor As New Color(128, 128, 128)
|
|
If _closing Then
|
|
TbgColor = New Color(TbgColor.R, TbgColor.G, TbgColor.B, CInt(CInt(TbgColor.A) * _interfaceFade))
|
|
End If
|
|
For x = 0 To TabDesriptionWidth Step 16
|
|
For y = 0 To 32 Step 16
|
|
SpriteBatch.Draw(_menuTexture, New Rectangle(halfWidth - 400 + x + 384, halfHeight - 200 + y, 16, 16), New Rectangle(0, 0, 4, 4), TbgColor)
|
|
Next
|
|
Next
|
|
Canvas.DrawGradient(Core.SpriteBatch, New Rectangle(halfWidth - 400 + 384 + TabDesriptionWidth + 16, halfHeight - 200, 800 - (384 + TabDesriptionWidth), 48), New Color(0, 0, 0, CInt(TbgColor.A * 0.5)), New Color(0, 0, 0, CInt(TbgColor.A * 0.00)), True, -1)
|
|
Dim TabName As String = ""
|
|
Select Case _tabIndex
|
|
Case 0 : TabName = Localization.GetString("item_category_Standard", "Standard")
|
|
Case 1 : TabName = Localization.GetString("item_category_Medicine", "Medicine")
|
|
Case 2 : TabName = Localization.GetString("item_category_Plants", "Plants")
|
|
Case 3 : TabName = Localization.GetString("item_category_Pokeballs", "Pokéballs")
|
|
Case 4 : TabName = Localization.GetString("item_category_Machines", "TM/HM")
|
|
Case 5 : TabName = Localization.GetString("item_category_Mail", "Mail")
|
|
Case 6 : TabName = Localization.GetString("item_category_BattleItems", "Battle Items")
|
|
Case 7 : TabName = Localization.GetString("item_category_KeyItems", "Key Items")
|
|
End Select
|
|
Dim gColor As New Color(164, 164, 164)
|
|
If _closing Then
|
|
gColor = New Color(gColor.R, gColor.G, gColor.B, CInt(CInt(gColor.A) * _interfaceFade))
|
|
End If
|
|
Dim fontWidth As Integer = CInt(FontManager.ChatFont.MeasureString(TabName).X)
|
|
SpriteBatch.DrawString(FontManager.ChatFont, TabName, New Vector2(halfWidth - 400 + 384 + CInt((TabDesriptionWidth - fontWidth) * 0.5), halfHeight - 200 + 12), gColor)
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Draws the main content.
|
|
''' </summary>
|
|
Private Sub DrawMain()
|
|
'Calculate the center of the screen:
|
|
Dim halfWidth As Integer = CInt(Core.windowSize.Width / 2)
|
|
Dim halfHeight As Integer = CInt(Core.windowSize.Height / 2)
|
|
|
|
'When the interface is fading in/out, use a custom alpha:
|
|
Dim mainBackgroundColor As Color = Color.White
|
|
If _closing = True Then
|
|
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
|
|
End If
|
|
|
|
Canvas.DrawRectangle(New Rectangle(halfWidth - 400, halfHeight - 232, 260, 32), New Color(84, 198, 216, mainBackgroundColor.A))
|
|
Canvas.DrawRectangle(New Rectangle(halfWidth - 140, halfHeight - 216, 16, 16), New Color(84, 198, 216, mainBackgroundColor.A))
|
|
SpriteBatch.Draw(_texture, New Rectangle(halfWidth - 140, halfHeight - 232, 16, 16), New Rectangle(80, 0, 16, 16), mainBackgroundColor)
|
|
SpriteBatch.Draw(_texture, New Rectangle(halfWidth - 124, halfHeight - 216, 16, 16), New Rectangle(80, 0, 16, 16), mainBackgroundColor)
|
|
|
|
SpriteBatch.DrawString(FontManager.ChatFont, "Inventory", New Vector2(halfWidth - 390, halfHeight - 228), mainBackgroundColor)
|
|
|
|
'Draw background pattern:
|
|
For y = 0 To CInt(_enrollY) Step 16
|
|
For x = 0 To 800 Step 16
|
|
SpriteBatch.Draw(_texture, New Rectangle(halfWidth - 400 + x, halfHeight - 200 + y, 16, 16), New Rectangle(64, 0, 4, 4), mainBackgroundColor)
|
|
Next
|
|
Next
|
|
|
|
'This draws the lowest row so the background is not cut off:
|
|
Dim modRes As Integer = CInt(_enrollY) Mod 16
|
|
If modRes > 0 Then
|
|
For x = 0 To 800 Step 16
|
|
SpriteBatch.Draw(_texture, New Rectangle(halfWidth - 400 + x, CInt(_enrollY + (halfHeight - 200)), 16, modRes), New Rectangle(64, 0, 4, 4), mainBackgroundColor)
|
|
Next
|
|
End If
|
|
|
|
'Create a render target and render the items to it.
|
|
'We do this because the items move to the left/right "outside" of the screen.
|
|
'So we don't need to fiddle around with the offset, we just move them outside the render target.
|
|
|
|
If CInt(_enrollY) - 32 > 0 Then 'Only draw, when the size is at least 1 pixel high.
|
|
|
|
'Bring back when Monogame begins supporting this stuff
|
|
' Dim target As New RenderTarget2D(GraphicsDevice, 816, CInt(_enrollY) - 32, False, GraphicsDevice.PresentationParameters.BackBufferFormat, DepthFormat.Depth24Stencil8, 0, RenderTargetUsage.PreserveContents)
|
|
GraphicsDevice.SetRenderTarget(target_1)
|
|
GraphicsDevice.Clear(Color.Transparent)
|
|
|
|
'Create a designated sprite batch:
|
|
|
|
itemBatch.BeginBatch()
|
|
|
|
Dim itemPanelAlpha As Integer = CInt(If(_tabInControl, 180, 255) * _interfaceFade)
|
|
|
|
Dim iX, iY As Integer
|
|
For i = 0 To 9
|
|
iX = CInt(Math.Floor(i / 2))
|
|
iY = i Mod 2
|
|
|
|
If _items.Length > i + (PageIndex * 10) Then
|
|
Dim cItem = Item.GetItemByID(_items(i + (PageIndex * 10)).ItemID)
|
|
|
|
If _itemIntro >= i / 10 Then
|
|
Dim Yoffset As Integer = 0
|
|
If _itemIntro < (i + 1) / 10 Then
|
|
Yoffset = CInt((_itemIntro - (i / 10)) * 80)
|
|
End If
|
|
|
|
Dim XOffset As Integer = ComputeXOffset(iX)
|
|
|
|
Dim itemLoc = New Vector2(iX * 160 + 32 + XOffset, 48 + iY * 160 + 32)
|
|
|
|
Dim size As Integer = If(i = ItemIndex, 96, 72)
|
|
|
|
itemBatch.Draw(cItem.Texture, New Rectangle(CInt(itemLoc.X) + 48, CInt(itemLoc.Y) + Yoffset, size, size), Nothing, New Color(255, 255, 255, itemPanelAlpha),
|
|
If(i = ItemIndex, _itemAnimation._shakeV, 0F), New Vector2(cItem.Texture.Width / 2.0F), SpriteEffects.None, 0F)
|
|
|
|
Dim nameTextHeight As Integer = 24
|
|
If _tabIndex = 4 Then
|
|
nameTextHeight = 40
|
|
End If
|
|
Canvas.DrawRectangle(itemBatch, New Rectangle(CInt(itemLoc.X) - 16 - 9, CInt(itemLoc.Y) + 48, 128 + 18, nameTextHeight), New Color(0, 0, 0, CInt(If(_tabInControl, 64, 128) * _interfaceFade)))
|
|
|
|
Dim fontWidth As Integer = CInt(FontManager.MiniFont.MeasureString(cItem.Name).X)
|
|
itemBatch.DrawString(FontManager.MiniFont, cItem.Name, itemLoc + New Vector2(48 - fontWidth / 2.0F, 51), New Color(255, 255, 255, itemPanelAlpha))
|
|
If _tabIndex <> 7 Then
|
|
itemBatch.DrawString(FontManager.MiniFont, "x" & _items(i + (PageIndex * 10)).Amount.ToString(), itemLoc + New Vector2(84, 26), New Color(40, 40, 40, itemPanelAlpha))
|
|
End If
|
|
|
|
If _tabIndex = 4 Then
|
|
Dim AttackName As String = CType(cItem, Items.TechMachine).Attack.Name
|
|
Dim TMfontWidth As Integer = CInt(FontManager.MiniFont.MeasureString(AttackName).X)
|
|
itemBatch.DrawString(FontManager.MiniFont, AttackName, itemLoc + New Vector2(48 - TMfontWidth / 2.0F, 51 + 16), New Color(255, 255, 255, itemPanelAlpha))
|
|
End If
|
|
End If
|
|
End If
|
|
Next
|
|
|
|
'When the info is visible, draw it:
|
|
If _infoSize > 0 Then
|
|
DrawInfo(itemBatch, target_1)
|
|
End If
|
|
|
|
itemBatch.EndBatch()
|
|
|
|
'Reset to back buffer and render the result:
|
|
GraphicsDevice.SetRenderTarget(Nothing)
|
|
|
|
Dim drawheight As Integer = 368
|
|
If _closing Then
|
|
drawheight = CInt(_enrollY) - 32
|
|
End If
|
|
|
|
SpriteBatch.Draw(target_1, New Rectangle(halfWidth - 400, halfHeight - 200 + 48, 816, drawheight), mainBackgroundColor)
|
|
|
|
End If
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Draws the info popup.
|
|
''' </summary>
|
|
Private Sub DrawInfo(ByVal preBatch As SpriteBatch, ByVal preTarget As RenderTarget2D)
|
|
If _items.Count = 0 Then
|
|
Exit Sub
|
|
End If
|
|
'Create a new render target and set it.
|
|
|
|
'Bring back when Monogame begins supporting this stuff
|
|
' Dim target As New RenderTarget2D(GraphicsDevice, _infoSize, 368, False, GraphicsDevice.PresentationParameters.BackBufferFormat, DepthFormat.Depth24Stencil8, 0, RenderTargetUsage.PreserveContents)
|
|
GraphicsDevice.SetRenderTarget(target_2)
|
|
GraphicsDevice.Clear(Color.Transparent)
|
|
|
|
'Render background:
|
|
infoBatch.BeginBatch()
|
|
Dim alpha = CInt(CSng(_infoSize) / 500 * 255)
|
|
|
|
For y = 0 To 368 Step 16
|
|
For x = 0 To _infoSize + 16 Step 16
|
|
If x < _infoSize - 16 Then
|
|
infoBatch.Draw(_menuTexture, New Rectangle(x, y, 16, 16), New Rectangle(0, 0, 4, 4), New Color(128, 128, 128, alpha))
|
|
End If
|
|
Next
|
|
Next
|
|
|
|
Canvas.DrawGradient(infoBatch, New Rectangle(0, 0, 100, 368), New Color(0, 0, 0, alpha), New Color(0, 0, 0, 0), True, -1)
|
|
Canvas.DrawGradient(infoBatch, New Rectangle(_infoSize - 100, 0, 100, 368), New Color(0, 0, 0, 0), New Color(0, 0, 0, alpha), True, -1)
|
|
|
|
'Get item and gets its display texts based on the item category:
|
|
Dim getIndex As Integer = ItemIndex + PageIndex * 10
|
|
Dim cItem As Item = Item.GetItemByID(_items(getIndex).ItemID)
|
|
|
|
infoBatch.Draw(cItem.Texture, New Rectangle(24, 24, 48, 48), Color.White)
|
|
|
|
Dim itemTitle As String = cItem.Name
|
|
Dim itemSubTitle As String = cItem.ItemType.ToString()
|
|
Dim itemDescription As String = cItem.GetDescription
|
|
|
|
Select Case cItem.ItemType
|
|
Case Items.ItemTypes.Machines
|
|
Dim techMachine = CType(cItem, Items.TechMachine)
|
|
|
|
itemTitle = techMachine.Attack.Name
|
|
|
|
If techMachine.IsTM Then
|
|
'JSON stuff
|
|
'itemSubTitle = _translation.TECH_MACHINE_TITLE(cItem.ItemType.ToString())
|
|
itemSubTitle = "Technical Machine"
|
|
Else
|
|
'JSON stuff
|
|
'itemSubTitle = _translation.HIDDEN_MACHINE_TITLE(cItem.ItemType.ToString())
|
|
itemSubTitle = "Hidden Machine"
|
|
End If
|
|
|
|
itemDescription &= Environment.NewLine & techMachine.Attack.Description
|
|
Case Items.ItemTypes.Standard
|
|
'JSON stuff
|
|
'itemSubTitle = _translation.STANDARD_ITEM_TITLE(cItem.ItemType.ToString())
|
|
itemSubTitle = cItem.ItemType.ToString() & " Item"
|
|
Case Items.ItemTypes.KeyItems
|
|
'JSON stuff
|
|
'itemSubTitle = _translation.KEYITEM_TITLE(cItem.ItemType.ToString())
|
|
itemSubTitle = "Key Item"
|
|
Case Items.ItemTypes.Pokéballs
|
|
'JSON stuff
|
|
'itemSubTitle = _translation.POKEBALL_TITLE(cItem.ItemType.ToString())
|
|
itemSubTitle = "Poké Ball"
|
|
Case Items.ItemTypes.Plants
|
|
'JSON stuff
|
|
'itemSubTitle = _translation.PLANT_TITLE(cItem.ItemType.ToString())
|
|
itemSubTitle = "Plant"
|
|
Case Items.ItemTypes.BattleItems
|
|
'JSON stuff
|
|
'itemSubTitle = _translation.BATTLEITEM_TITLE(cItem.ItemType.ToString())
|
|
itemSubTitle = "Battle Item"
|
|
End Select
|
|
|
|
infoBatch.DrawString(FontManager.TextFont, itemTitle, New Vector2(80, 20), Color.White, 0F, Vector2.Zero, 2.0F, SpriteEffects.None, 0F)
|
|
infoBatch.DrawString(FontManager.TextFont, itemSubTitle, New Vector2(80, 46), Color.LightGray, 0F, Vector2.Zero, 1.5F, SpriteEffects.None, 0F)
|
|
infoBatch.DrawString(FontManager.TextFont, itemDescription.CropStringToWidth(FontManager.TextFont, 1.0F, 430), New Vector2(28, 84), Color.LightGray, 0F, Vector2.Zero, 1.0F, SpriteEffects.None, 0F)
|
|
|
|
For i = 0 To _infoItemOptions.Count - 1
|
|
Canvas.DrawRectangle(infoBatch, New Rectangle(CInt(250 - _infoItemOptionSize(i) / 2), 158 + i * 64, _infoItemOptionSize(i), 48), New Color(255, 255, 255, 20))
|
|
|
|
infoBatch.DrawString(FontManager.TextFont, _infoItemOptions(i), New Vector2(CInt(250 - FontManager.TextFont.MeasureString(_infoItemOptions(i)).X), 168 + i * 64), Color.White, 0F, Vector2.Zero, 2.0F, SpriteEffects.None, 0F)
|
|
Next
|
|
|
|
infoBatch.EndBatch()
|
|
|
|
'Set the target that was previously active and render the new target on top of that:
|
|
GraphicsDevice.SetRenderTarget(preTarget)
|
|
preBatch.Draw(target_2, New Rectangle(_infoPosition + 80, 0, target_2.Width, target_2.Height), New Color(255, 255, 255, alpha))
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Draws the amount of items to be tossed.
|
|
''' </summary>
|
|
Private Sub DrawAmount()
|
|
If _tossingItems Then
|
|
Dim cItem As Item = Item.GetItemByID(_items(ItemIndex + PageIndex * 10).ItemID)
|
|
|
|
Dim CanvasTexture As Texture2D
|
|
CanvasTexture = TextureManager.GetTexture(TextureManager.GetTexture("GUI\Menus\Menu"), New Rectangle(0, 0, 48, 48))
|
|
|
|
Dim trashText As String = _tossValue & "/" & Core.Player.Inventory.GetItemAmount(cItem.ID)
|
|
Dim offsetX As Integer = 100
|
|
Dim offsetY As Integer = Core.windowSize.Height - 390
|
|
|
|
Canvas.DrawImageBorder(CanvasTexture, 2, New Rectangle(CInt(Core.windowSize.Width / 2) + 180 + offsetX, 240 + offsetY, 128, 64))
|
|
Core.SpriteBatch.DrawString(FontManager.InGameFont, trashText, New Vector2(CInt(Core.windowSize.Width / 2) - (FontManager.InGameFont.MeasureString(trashText).X / 2) + 256 + offsetX, 276 + offsetY), Color.Black)
|
|
End If
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Determines the x-offset of an item based on the <see cref="_itemColumnLeft"/> value.
|
|
''' </summary>
|
|
Private Function ComputeXOffset(ByVal itemPositionId As Integer) As Integer
|
|
Dim i As Integer = itemPositionId
|
|
|
|
'Determine if we are in the left or right portion:
|
|
Dim isLeft As Boolean = _itemColumnLeft >= i
|
|
|
|
If isLeft Then
|
|
Return _itemColumnLeftOffset
|
|
Else
|
|
Return _itemColumnRightOffset
|
|
End If
|
|
End Function
|
|
|
|
''' <summary>
|
|
''' Returns the texture rectangle that contains the tab image from GUI\Menus\Inventory.
|
|
''' </summary>
|
|
''' <param name="i">The tab index.</param>
|
|
Private Function GetTabImageRect(ByVal i As Integer) As Rectangle
|
|
Select Case _visibleItemTypes(i)
|
|
Case Items.ItemTypes.Standard
|
|
Return New Rectangle(0, 16, 16, 16)
|
|
Case Items.ItemTypes.Medicine
|
|
Return New Rectangle(16, 16, 16, 16)
|
|
Case Items.ItemTypes.Plants
|
|
Return New Rectangle(0, 32, 16, 16)
|
|
Case Items.ItemTypes.Pokéballs
|
|
Return New Rectangle(48, 16, 16, 16)
|
|
Case Items.ItemTypes.Machines
|
|
Return New Rectangle(32, 16, 16, 16)
|
|
Case Items.ItemTypes.Mail
|
|
Return New Rectangle(16, 32, 16, 16)
|
|
Case Items.ItemTypes.BattleItems
|
|
Return New Rectangle(48, 32, 16, 16)
|
|
Case Items.ItemTypes.KeyItems
|
|
Return New Rectangle(32, 32, 16, 16)
|
|
End Select
|
|
End Function
|
|
|
|
Public Overrides Sub Update()
|
|
'Updates the tab highlight:
|
|
For index = 0 To _tabHighlight.Length - 1
|
|
If index <> _tabIndex Then
|
|
If _tabHighlight(index) > 0 Then
|
|
_tabHighlight(index) -= 15
|
|
If _tabHighlight(index) < 0 Then
|
|
_tabHighlight(index) = 0
|
|
End If
|
|
End If
|
|
Else
|
|
_tabHighlight(index) = 255
|
|
End If
|
|
Next
|
|
|
|
'Update the message:
|
|
If _messageDelay > 0F Then
|
|
_messageDelay -= 0.1F
|
|
If _messageDelay <= 0F Then
|
|
_messageDelay = 0F
|
|
End If
|
|
End If
|
|
|
|
If _closing Then
|
|
' When the interface is closing, only update the closing animation
|
|
' Once the interface is completely closed, set to the previous screen.
|
|
|
|
If _interfaceFade > 0F Then
|
|
_interfaceFade = MathHelper.Lerp(0, _interfaceFade, 0.8F)
|
|
If _interfaceFade < 0F Then
|
|
_interfaceFade = 0F
|
|
End If
|
|
End If
|
|
If _enrollY > 0 Then
|
|
_enrollY = MathHelper.Lerp(0, _enrollY, 0.8F)
|
|
If _enrollY <= 0 Then
|
|
_enrollY = 0
|
|
End If
|
|
End If
|
|
If _enrollY <= 2.0F Then
|
|
'TODO: Set the interface state to PlayerTemp.
|
|
SetScreen(PreScreen)
|
|
End If
|
|
Else
|
|
'Update intro animation:
|
|
Dim maxWindowHeight As Integer = 400
|
|
If _enrollY < maxWindowHeight Then
|
|
_enrollY = MathHelper.Lerp(maxWindowHeight, _enrollY, 0.8F)
|
|
If _enrollY >= maxWindowHeight Then
|
|
_enrollY = maxWindowHeight
|
|
End If
|
|
End If
|
|
If _interfaceFade < 1.0F Then
|
|
_interfaceFade = MathHelper.Lerp(1.0F, _interfaceFade, 0.95F)
|
|
If _interfaceFade > 1.0F Then
|
|
_interfaceFade = 1.0F
|
|
End If
|
|
End If
|
|
If _itemIntro < 1.0F Then
|
|
_itemIntro += 0.05F
|
|
If _itemIntro > 1.0F Then
|
|
_itemIntro = 1.0F
|
|
End If
|
|
End If
|
|
|
|
'Control update:
|
|
UpdateShakeAnimation()
|
|
|
|
' Input update:
|
|
If TextBox.Showing = False And ChooseBox.Showing = False And PokemonImageView.Showing = False And ImageView.Showing = False Then
|
|
Dim isTabsSelected = _tabInControl
|
|
|
|
UpdateTabs()
|
|
|
|
If Not isTabsSelected Then
|
|
If _isInfoShowing Then
|
|
UpdateInfo()
|
|
Else
|
|
UpdateItems()
|
|
End If
|
|
End If
|
|
End If
|
|
|
|
'Update the Dialogues:
|
|
ChooseBox.Update()
|
|
If ChooseBox.Showing = False Then
|
|
TextBox.Update()
|
|
End If
|
|
If PokemonImageView.Showing = True Then
|
|
PokemonImageView.Update()
|
|
End If
|
|
If ImageView.Showing = True Then
|
|
ImageView.Update()
|
|
End If
|
|
|
|
UpdateInfoAnimation()
|
|
End If
|
|
|
|
'Update the toss amount indicator:
|
|
If _tossingItems Then
|
|
Dim cItem As Item = Item.GetItemByID(_items(ItemIndex + PageIndex * 10).ItemID)
|
|
If Controls.Right(True, True, True, True) Then
|
|
_tossValue += 1
|
|
End If
|
|
If Controls.Left(True, True, True, True) Then
|
|
_tossValue -= 1
|
|
End If
|
|
|
|
_tossValue = CInt(MathHelper.Clamp(_tossValue, 1, Core.Player.Inventory.GetItemAmount(cItem.ID)))
|
|
|
|
If Not TextBox.Showing Then
|
|
If Controls.Accept Then
|
|
SoundManager.PlaySound("select")
|
|
Core.Player.Inventory.RemoveItem(cItem.ID, _tossValue)
|
|
LoadItems()
|
|
_tossingItems = False
|
|
ElseIf Controls.Dismiss Then
|
|
SoundManager.PlaySound("select")
|
|
_tossingItems = False
|
|
End If
|
|
_tossValue = 1
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub UpdateTabs()
|
|
If Controls.Left(True, True, True, True, True, True) And _tabInControl Or ControllerHandler.ButtonPressed(Buttons.LeftShoulder) Then
|
|
_tabIndex -= 1
|
|
If AllowedPages.Count > 0 And AllowedPages.Contains(_tabIndex) = False Then
|
|
While AllowedPages.Contains(_tabIndex) = False
|
|
_tabIndex -= 1
|
|
|
|
If _tabIndex < 0 Then
|
|
_tabIndex = 7
|
|
ElseIf _tabIndex > 7 Then
|
|
_tabIndex = 0
|
|
End If
|
|
End While
|
|
End If
|
|
If _tabIndex < 0 Then
|
|
_tabIndex = 7
|
|
ElseIf _tabIndex > 7 Then
|
|
_tabIndex = 0
|
|
End If
|
|
_itemIntro = 0F
|
|
ResetAnimation()
|
|
LoadItems()
|
|
End If
|
|
If Controls.Right(True, True, True, True, True, True) And _tabInControl Or ControllerHandler.ButtonPressed(Buttons.RightShoulder) Then
|
|
_tabIndex += 1
|
|
If AllowedPages.Count > 0 And AllowedPages.Contains(_tabIndex) = False Then
|
|
While AllowedPages.Contains(_tabIndex) = False
|
|
_tabIndex += 1
|
|
|
|
If _tabIndex < 0 Then
|
|
_tabIndex = 7
|
|
ElseIf _tabIndex > 7 Then
|
|
_tabIndex = 0
|
|
End If
|
|
End While
|
|
End If
|
|
If _tabIndex < 0 Then
|
|
_tabIndex = 7
|
|
ElseIf _tabIndex > 7 Then
|
|
_tabIndex = 0
|
|
End If
|
|
_itemIntro = 0F
|
|
ResetAnimation()
|
|
LoadItems()
|
|
End If
|
|
If _tabInControl Then
|
|
If Controls.Dismiss() And CanExit Then
|
|
SoundManager.PlaySound("select")
|
|
_closing = True
|
|
End If
|
|
If Controls.Accept() And _items.Length > 0 Then
|
|
SoundManager.PlaySound("select")
|
|
_tabInControl = False
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub UpdateItems()
|
|
If Controls.Left(True, True, True, True, True, True) Then
|
|
ItemIndex -= 2
|
|
If ItemIndex < 0 And PageIndex > 0 Then
|
|
ItemIndex += 10
|
|
PageIndex -= 1
|
|
_itemIntro = 0F
|
|
ResetAnimation()
|
|
ElseIf ItemIndex < 0 And PageIndex = 0 Then
|
|
If ItemIndex = -1 Then
|
|
ItemIndex = 1
|
|
Else
|
|
ItemIndex = 0
|
|
End If
|
|
End If
|
|
End If
|
|
If Controls.Right(True, True, True, True, True, True) Then
|
|
If ItemIndex + 2 + (PageIndex * 10) < _items.Length Then
|
|
ItemIndex += 2
|
|
If ItemIndex > 9 Then
|
|
ItemIndex -= 10
|
|
PageIndex += 1
|
|
_itemIntro = 0F
|
|
ResetAnimation()
|
|
End If
|
|
End If
|
|
End If
|
|
If Controls.Up(True, True, False, True, True, True) Then
|
|
ItemIndex -= 1
|
|
If ItemIndex < 0 And PageIndex > 0 Then
|
|
ItemIndex += 10
|
|
PageIndex -= 1
|
|
_itemIntro = 0F
|
|
ResetAnimation()
|
|
ElseIf ItemIndex < 0 And PageIndex = 0 Then
|
|
ItemIndex = 0
|
|
End If
|
|
End If
|
|
If Controls.Down(True, True, False, True, True, True) Then
|
|
If ItemIndex + 1 + (PageIndex * 10) < _items.Length Then
|
|
ItemIndex += 1
|
|
If ItemIndex > 9 Then
|
|
ItemIndex -= 10
|
|
PageIndex += 1
|
|
_itemIntro = 0F
|
|
ResetAnimation()
|
|
End If
|
|
End If
|
|
End If
|
|
|
|
If Controls.Accept() AndAlso _items.Length > 0 Then
|
|
Dim cItem As Item = Item.GetItemByID(_items(ItemIndex + PageIndex * 10).ItemID)
|
|
SoundManager.PlaySound("select")
|
|
If Me.PreScreen.Identification = Screen.Identifications.BattleScreen Then
|
|
If cItem.CanBeUsedInBattle = True Then
|
|
_infoItemOptionSelection = 0
|
|
_isInfoShowing = True
|
|
SetInfoSettings()
|
|
SetItemOptions()
|
|
Else
|
|
TextBox.Show("This item can't~be used in Battle.")
|
|
End If
|
|
Else
|
|
_infoItemOptionSelection = 0
|
|
_isInfoShowing = True
|
|
SetInfoSettings()
|
|
SetItemOptions()
|
|
End If
|
|
|
|
End If
|
|
If Controls.Dismiss() Then
|
|
SoundManager.PlaySound("select")
|
|
_tabInControl = True
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub UpdateInfo()
|
|
For i = 0 To _infoItemOptionSize.Length - 1
|
|
If i = _infoItemOptionSelection Then
|
|
If _infoItemOptionSize(i) < 200 Then
|
|
_infoItemOptionSize(i) += 20
|
|
If _infoItemOptionSize(i) >= 200 Then
|
|
_infoItemOptionSize(i) = 200
|
|
End If
|
|
End If
|
|
Else
|
|
If _infoItemOptionSize(i) > 0 Then
|
|
_infoItemOptionSize(i) -= 20
|
|
If _infoItemOptionSize(i) <= 0 Then
|
|
_infoItemOptionSize(i) = 0
|
|
End If
|
|
End If
|
|
End If
|
|
Next
|
|
|
|
If Controls.Up(True) Then
|
|
_infoItemOptionSelection -= 1
|
|
If _infoItemOptionSelection < 0 Then
|
|
_infoItemOptionSelection = _infoItemOptions.Count - 1
|
|
End If
|
|
End If
|
|
If Controls.Down(True) Then
|
|
_infoItemOptionSelection += 1
|
|
If _infoItemOptionSelection > _infoItemOptions.Count - 1 Then
|
|
_infoItemOptionSelection = 0
|
|
End If
|
|
End If
|
|
|
|
If Controls.Accept() Then
|
|
SoundManager.PlaySound("select")
|
|
SelectedItemOption()
|
|
End If
|
|
|
|
If Controls.Dismiss() Then
|
|
SoundManager.PlaySound("select")
|
|
CloseInfoScreen()
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub CloseInfoScreen()
|
|
_infoSizeTarget = 0
|
|
_infoPositionTarget = GetInfoTargetPositionRollback()
|
|
_itemColumnRightOffsetTarget = 0
|
|
_itemColumnLeftOffsetTarget = 0
|
|
|
|
_isInfoShowing = False
|
|
End Sub
|
|
|
|
Private Sub SaveBagIndex()
|
|
Player.Temp.BagIndex = _tabIndex
|
|
Player.Temp.BagPageIndex = _pageIndex
|
|
Player.Temp.BagItemIndex = _itemindex
|
|
End Sub
|
|
|
|
Private Sub SelectedItemOption()
|
|
If _infoItemOptionsNormal.Count > 0 Then
|
|
Dim cItem As Item = Item.GetItemByID(_items(ItemIndex + PageIndex * 10).ItemID)
|
|
|
|
Select Case _infoItemOptionsNormal(_infoItemOptionSelection)
|
|
Case INFO_ITEM_OPTION_USE
|
|
cItem.Use()
|
|
LoadItems()
|
|
Case INFO_ITEM_OPTION_GIVE
|
|
Dim selScreen = New PartyScreen(Core.CurrentScreen) With {.Mode = ISelectionScreen.ScreenMode.Selection, .CanExit = True}
|
|
AddHandler selScreen.SelectedObject, AddressOf GiveItemHandler
|
|
|
|
Core.SetScreen(selScreen)
|
|
Case INFO_ITEM_OPTION_TOSS
|
|
TossItem(cItem)
|
|
Case INFO_ITEM_OPTION_SELECT
|
|
FireSelectionEvent(cItem.ID)
|
|
CloseInfoScreen()
|
|
_closing = True
|
|
End Select
|
|
SaveBagIndex()
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub TossItem(ByVal cItem As Item)
|
|
Dim text As String = "Are you sure you want to toss~this item?%Yes|No%"
|
|
TextBox.Show(text, AddressOf Me.TossManyItems, False, False, TextBox.DefaultColor)
|
|
End Sub
|
|
|
|
Private Sub TossManyItems(ByVal result As Integer)
|
|
If result = 0 Then
|
|
TextBox.Show("Select the amount to toss.", {})
|
|
_tossingItems = True
|
|
End If
|
|
End Sub
|
|
''' <summary>
|
|
''' A handler method to convert the incoming object array.
|
|
''' </summary>
|
|
Private Sub GiveItemHandler(ByVal params As Object())
|
|
GiveItem(CInt(params(0)))
|
|
End Sub
|
|
|
|
Private Sub GiveItem(ByVal PokeIndex As Integer)
|
|
Dim cItem As Item = Item.GetItemByID(_items(ItemIndex + PageIndex * 10).ItemID)
|
|
Dim Pokemon As Pokemon = Core.Player.Pokemons(PokeIndex)
|
|
|
|
If Pokemon.IsEgg() = False Then
|
|
Core.Player.Inventory.RemoveItem(cItem.ID, 1)
|
|
|
|
Dim reItem As Item = Nothing
|
|
If Not Pokemon.Item Is Nothing Then
|
|
reItem = Pokemon.Item
|
|
Core.Player.Inventory.AddItem(reItem.ID, 1)
|
|
End If
|
|
|
|
Pokemon.Item = Item.GetItemByID(cItem.ID)
|
|
|
|
If reItem Is Nothing Then
|
|
'JSON Stuff
|
|
'ShowMessage(_translation.MESSAGE_GIVE_ITEM(Pokemon.GetDisplayName(), cItem.Name))
|
|
ShowMessage("Gave " & Pokemon.GetDisplayName() & " a " & cItem.Name & ".")
|
|
Else
|
|
'JSON Stuff
|
|
'ShowMessage(_translation.MESSAGE_SWITCH_ITEM(Pokemon.GetDisplayName(), reItem.Name, cItem.Name))
|
|
ShowMessage("Switched " & Pokemon.GetDisplayName() & "'s " & reItem.Name & " with a " & cItem.Name & ".")
|
|
End If
|
|
|
|
LoadItems()
|
|
If ItemIndex + PageIndex * 10 > _items.Count - 1 Then
|
|
ItemIndex = 0
|
|
PageIndex = 0
|
|
CloseInfoScreen()
|
|
End If
|
|
Else
|
|
'JSON Stuff
|
|
'ShowMessage(_translation.MESSAGE_EGG_ERROR)
|
|
ShowMessage("Eggs cannot hold items.")
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub ShowMessage(ByVal text As String)
|
|
_messageDelay = CSng(text.Length / 1.75)
|
|
_messageText = text
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Resets the item animation.
|
|
''' </summary>
|
|
Private Sub ResetAnimation()
|
|
_itemAnimation = New ItemAnimation()
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Updates the item shake animation.
|
|
''' </summary>
|
|
Private Sub UpdateShakeAnimation()
|
|
If _itemAnimation._shakeLeft = True Then
|
|
_itemAnimation._shakeV -= 0.0275F
|
|
If _itemAnimation._shakeV <= -0.4F Then
|
|
_itemAnimation._shakeCount -= 1
|
|
_itemAnimation._shakeLeft = False
|
|
End If
|
|
Else
|
|
_itemAnimation._shakeV += 0.0275F
|
|
If _itemAnimation._shakeV >= 0.4F Then
|
|
_itemAnimation._shakeCount -= 1
|
|
_itemAnimation._shakeLeft = True
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Reloads the temporary item list.
|
|
''' </summary>
|
|
Public Sub LoadItems()
|
|
_items = Core.Player.Inventory.Where(Function(x) Item.GetItemByID(x.ItemID).ItemType = _visibleItemTypes(_tabIndex)).ToArray()
|
|
If _tabIndex = 4 Then 'TM/HM
|
|
_items = (From i In _items Order By Item.GetItemByID(i.ItemID).SortValue Ascending).ToArray()
|
|
Else
|
|
_items = (From i In _items Order By Item.GetItemByID(i.ItemID).Name Ascending).ToArray()
|
|
End If
|
|
If _items.Count <= ItemIndex + PageIndex * 10 Then
|
|
ItemIndex -= 1
|
|
If ItemIndex = -1 Then
|
|
If PageIndex > 0 Then
|
|
PageIndex -= 1
|
|
ItemIndex = 9
|
|
Else
|
|
ItemIndex = 0
|
|
PageIndex = 0
|
|
_tabInControl = True
|
|
End If
|
|
End If
|
|
CloseInfoScreen()
|
|
End If
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Sets the info interface state settings based on the selected item column.
|
|
''' </summary>
|
|
Private Sub SetInfoSettings()
|
|
Dim column As Integer = CInt(Math.Floor(ItemIndex / 2))
|
|
|
|
_infoSize = 0
|
|
_infoSizeTarget = 500 'Size is always 500.
|
|
_itemColumnLeftOffset = 0
|
|
_itemColumnRightOffset = 0
|
|
Select Case column
|
|
Case 0
|
|
_infoSide = 0
|
|
_infoPosition = column * 160 + 32 + 48
|
|
_infoPositionTarget = _infoPosition
|
|
_itemColumnLeft = 0
|
|
_itemColumnLeftOffsetTarget = 0
|
|
_itemColumnRightOffsetTarget = 500
|
|
Case 1
|
|
_infoSide = 0
|
|
_infoPosition = column * 160 + 32 + 48
|
|
_infoPositionTarget = _infoPosition - 160
|
|
_itemColumnLeft = 1
|
|
_itemColumnLeftOffsetTarget = -160
|
|
_itemColumnRightOffsetTarget = 340
|
|
Case 2
|
|
_infoSide = 0
|
|
_infoPosition = column * 160 + 32 + 48
|
|
_infoPositionTarget = _infoPosition - 320
|
|
_itemColumnLeft = 2
|
|
_itemColumnLeftOffsetTarget = -320
|
|
_itemColumnRightOffsetTarget = 180
|
|
Case 3
|
|
_infoSide = 1
|
|
_infoPosition = column * 160 - 80
|
|
_infoPositionTarget = _infoPosition - 320
|
|
_itemColumnLeft = 2
|
|
_itemColumnLeftOffsetTarget = -320
|
|
_itemColumnRightOffsetTarget = 180
|
|
Case 4
|
|
_infoSide = 1
|
|
_infoPosition = column * 160 - 80
|
|
_infoPositionTarget = _infoPosition - 500
|
|
_itemColumnLeft = 3
|
|
_itemColumnLeftOffsetTarget = -500
|
|
_itemColumnRightOffsetTarget = 0
|
|
End Select
|
|
End Sub
|
|
|
|
Private Sub SetItemOptions()
|
|
_infoItemOptions.Clear()
|
|
_infoItemOptionsNormal.Clear()
|
|
|
|
Dim cItem As Item = Item.GetItemByID(_items(ItemIndex + PageIndex * 10).ItemID)
|
|
|
|
If _mode = ISelectionScreen.ScreenMode.Default Then
|
|
If cItem.CanBeUsed Then
|
|
'JSON Stuff
|
|
'_infoItemOptions.Add(_translation.INFO_ITEM_OPTION_USE)
|
|
_infoItemOptions.Add("Use")
|
|
_infoItemOptionsNormal.Add(INFO_ITEM_OPTION_USE)
|
|
End If
|
|
If cItem.CanBeHold Then
|
|
'JSON Stuff
|
|
' _infoItemOptions.Add(_translation.INFO_ITEM_OPTION_GIVE)
|
|
_infoItemOptions.Add("Give")
|
|
_infoItemOptionsNormal.Add(INFO_ITEM_OPTION_GIVE)
|
|
End If
|
|
If cItem.CanBeTossed Then
|
|
'JSON Stuff
|
|
'_infoItemOptions.Add(_translation.INFO_ITEM_OPTION_TOSS)
|
|
_infoItemOptions.Add("Toss")
|
|
_infoItemOptionsNormal.Add(INFO_ITEM_OPTION_TOSS)
|
|
End If
|
|
ElseIf _mode = ISelectionScreen.ScreenMode.Selection Then
|
|
'JSON Stuff
|
|
'_infoItemOptions.Add(_translation.INFO_ITEM_OPTION_SELECT)
|
|
_infoItemOptions.Add("Select")
|
|
_infoItemOptionsNormal.Add(INFO_ITEM_OPTION_SELECT)
|
|
End If
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' Gets the target position of the info box for the rollback animation.
|
|
''' </summary>
|
|
Private Function GetInfoTargetPositionRollback() As Integer
|
|
Dim column As Integer = CInt(Math.Floor(ItemIndex / 2))
|
|
|
|
Select Case column
|
|
Case 0
|
|
Return column * 160 + 32 + 48
|
|
Case 1
|
|
Return column * 160 + 32 + 48
|
|
Case 2
|
|
Return column * 160 + 32 + 48
|
|
Case 3
|
|
Return column * 160 - 80
|
|
Case 4
|
|
Return column * 160 - 80
|
|
End Select
|
|
|
|
Return 0
|
|
End Function
|
|
|
|
Private Sub UpdateInfoAnimation()
|
|
'Make the size grow if needed:
|
|
Dim tempInfoSize As Integer = _infoSize
|
|
_infoSize = CInt(MathHelper.Lerp(_infoSize, _infoSizeTarget, 0.1F))
|
|
If tempInfoSize = _infoSize Then
|
|
_infoSize = _infoSizeTarget
|
|
End If
|
|
|
|
'Move the info position to its target:
|
|
Dim tempInfoPosition As Integer = _infoPosition
|
|
_infoPosition = CInt(MathHelper.Lerp(_infoPosition, _infoPositionTarget, 0.1F))
|
|
If tempInfoPosition = _infoPosition Then
|
|
_infoPosition = _infoPositionTarget
|
|
End If
|
|
|
|
'Move item offsets:
|
|
Dim tempItemColumnLeftOffset As Integer = _itemColumnLeftOffset
|
|
_itemColumnLeftOffset = CInt(MathHelper.Lerp(_itemColumnLeftOffset, _itemColumnLeftOffsetTarget, 0.1F))
|
|
If tempItemColumnLeftOffset = _itemColumnLeftOffset Then
|
|
_itemColumnLeftOffset = _itemColumnLeftOffsetTarget
|
|
End If
|
|
|
|
Dim tempItemColumnRightOffset As Integer = _itemColumnRightOffset
|
|
_itemColumnRightOffset = CInt(MathHelper.Lerp(_itemColumnRightOffset, _itemColumnRightOffsetTarget, 0.1F))
|
|
If tempItemColumnRightOffset = _itemColumnRightOffset Then
|
|
_itemColumnRightOffset = _itemColumnRightOffsetTarget
|
|
End If
|
|
End Sub
|
|
|
|
Private _mode As ISelectionScreen.ScreenMode = ISelectionScreen.ScreenMode.Default
|
|
Private _canExit As Boolean = True
|
|
Private _visibleItemTypes As Items.ItemTypes()
|
|
|
|
Public Event SelectedObject(params() As Object) Implements ISelectionScreen.SelectedObject
|
|
|
|
Private Sub FireSelectionEvent(ByVal itemId As Integer)
|
|
RaiseEvent SelectedObject(New Object() {itemId})
|
|
End Sub
|
|
|
|
''' <summary>
|
|
''' The current mode of this screen.
|
|
''' </summary>
|
|
Public Property Mode As ISelectionScreen.ScreenMode Implements ISelectionScreen.Mode
|
|
Get
|
|
Return _mode
|
|
End Get
|
|
Set(value As ISelectionScreen.ScreenMode)
|
|
_mode = value
|
|
End Set
|
|
End Property
|
|
|
|
''' <summary>
|
|
''' If the user can quit the screen in selection mode without choosing an item.
|
|
''' </summary>
|
|
Public Property CanExit As Boolean Implements ISelectionScreen.CanExit
|
|
Get
|
|
Return _canExit
|
|
End Get
|
|
Set(value As Boolean)
|
|
_canExit = value
|
|
End Set
|
|
End Property
|
|
|
|
''' <summary>
|
|
''' Sets the visible item type tabs.
|
|
''' </summary>
|
|
Public WriteOnly Property VisibleItemTypes As Items.ItemTypes()
|
|
Set(value As Items.ItemTypes())
|
|
_visibleItemTypes = value
|
|
End Set
|
|
End Property
|
|
|
|
End Class |