mirror of https://github.com/OpenRCT2/OpenRCT2.git
Merge pull request #18292 from Gymnasiast/fix/18290
Fix #18290: Ride and plug-in window colours not appearing
This commit is contained in:
commit
7be8f475f3
|
@ -1189,5 +1189,5 @@ static void WidgetTextBoxDraw(rct_drawpixelinfo* dpi, rct_window& w, WidgetIndex
|
|||
|
||||
ImageId GetColourButtonImage(colour_t colour)
|
||||
{
|
||||
return ImageId(SPR_PALETTE_BTN).WithTransparency(colour);
|
||||
return ImageId(SPR_PALETTE_BTN, colour).WithBlended(true);
|
||||
}
|
||||
|
|
|
@ -288,7 +288,7 @@ public:
|
|||
disabled_widgets |= (1ULL << WIDX_BANNER_TEXT) | (1ULL << WIDX_TEXT_COLOUR_DROPDOWN)
|
||||
| (1ULL << WIDX_TEXT_COLOUR_DROPDOWN_BUTTON);
|
||||
}
|
||||
colourBtn->image = SPRITE_ID_PALETTE_COLOUR_1(banner->colour) | IMAGE_TYPE_TRANSPARENT | SPR_PALETTE_BTN;
|
||||
colourBtn->image = GetColourButtonImage(banner->colour).ToUInt32();
|
||||
rct_widget* dropDownWidget = &window_banner_widgets[WIDX_TEXT_COLOUR_DROPDOWN];
|
||||
dropDownWidget->text = BannerColouredTextFormats[banner->text_colour];
|
||||
}
|
||||
|
|
|
@ -456,7 +456,7 @@ void WindowDropdownShowColour(rct_window* w, rct_widget* widget, uint8_t dropdow
|
|||
defaultIndex = i;
|
||||
|
||||
gDropdownItems[i].Format = Dropdown::FormatColourPicker;
|
||||
gDropdownItems[i].Args = (i << 32) | (SPRITE_ID_PALETTE_COLOUR_1(i) | SPR_PALETTE_BTN);
|
||||
gDropdownItems[i].Args = (i << 32) | ImageId(SPR_PALETTE_BTN, i).ToUInt32();
|
||||
}
|
||||
|
||||
// Show dropdown
|
||||
|
|
|
@ -1652,7 +1652,7 @@ private:
|
|||
{
|
||||
case ShopItem::Balloon:
|
||||
ft.Rewind();
|
||||
ft.Add<uint32_t>(SPRITE_ID_PALETTE_COLOUR_1(guest.BalloonColour) | GetShopItemDescriptor(item).Image);
|
||||
ft.Add<uint32_t>(ImageId(GetShopItemDescriptor(item).Image, (guest.BalloonColour)).ToUInt32());
|
||||
break;
|
||||
case ShopItem::Photo:
|
||||
invRide = get_ride(guest.Photo1RideRef);
|
||||
|
@ -1666,7 +1666,7 @@ private:
|
|||
break;
|
||||
case ShopItem::Umbrella:
|
||||
ft.Rewind();
|
||||
ft.Add<uint32_t>(SPRITE_ID_PALETTE_COLOUR_1(guest.UmbrellaColour) | GetShopItemDescriptor(item).Image);
|
||||
ft.Add<uint32_t>(ImageId(GetShopItemDescriptor(item).Image, (guest.UmbrellaColour)).ToUInt32());
|
||||
break;
|
||||
case ShopItem::Voucher:
|
||||
switch (guest.VoucherType)
|
||||
|
@ -1705,11 +1705,11 @@ private:
|
|||
break;
|
||||
case ShopItem::Hat:
|
||||
ft.Rewind();
|
||||
ft.Add<uint32_t>(SPRITE_ID_PALETTE_COLOUR_1(guest.HatColour) | GetShopItemDescriptor(item).Image);
|
||||
ft.Add<uint32_t>(ImageId(GetShopItemDescriptor(item).Image, (guest.HatColour)).ToUInt32());
|
||||
break;
|
||||
case ShopItem::TShirt:
|
||||
ft.Rewind();
|
||||
ft.Add<uint32_t>(SPRITE_ID_PALETTE_COLOUR_1(guest.TshirtColour) | GetShopItemDescriptor(item).Image);
|
||||
ft.Add<uint32_t>(ImageId(GetShopItemDescriptor(item).Image, (guest.TshirtColour)).ToUInt32());
|
||||
break;
|
||||
case ShopItem::Photo2:
|
||||
invRide = get_ride(guest.Photo2RideRef);
|
||||
|
|
|
@ -542,12 +542,9 @@ public:
|
|||
}
|
||||
}
|
||||
|
||||
widgets[WIDX_SCENERY_PRIMARY_COLOUR_BUTTON].image = SPRITE_ID_PALETTE_COLOUR_1(gWindowSceneryPrimaryColour)
|
||||
| IMAGE_TYPE_TRANSPARENT | SPR_PALETTE_BTN;
|
||||
widgets[WIDX_SCENERY_SECONDARY_COLOUR_BUTTON].image = SPRITE_ID_PALETTE_COLOUR_1(gWindowScenerySecondaryColour)
|
||||
| IMAGE_TYPE_TRANSPARENT | SPR_PALETTE_BTN;
|
||||
widgets[WIDX_SCENERY_TERTIARY_COLOUR_BUTTON].image = SPRITE_ID_PALETTE_COLOUR_1(gWindowSceneryTertiaryColour)
|
||||
| IMAGE_TYPE_TRANSPARENT | SPR_PALETTE_BTN;
|
||||
widgets[WIDX_SCENERY_PRIMARY_COLOUR_BUTTON].image = GetColourButtonImage(gWindowSceneryPrimaryColour).ToUInt32();
|
||||
widgets[WIDX_SCENERY_SECONDARY_COLOUR_BUTTON].image = GetColourButtonImage(gWindowScenerySecondaryColour).ToUInt32();
|
||||
widgets[WIDX_SCENERY_TERTIARY_COLOUR_BUTTON].image = GetColourButtonImage(gWindowSceneryTertiaryColour).ToUInt32();
|
||||
|
||||
widgets[WIDX_SCENERY_PRIMARY_COLOUR_BUTTON].type = WindowWidgetType::Empty;
|
||||
widgets[WIDX_SCENERY_SECONDARY_COLOUR_BUTTON].type = WindowWidgetType::Empty;
|
||||
|
|
|
@ -275,8 +275,8 @@ public:
|
|||
}
|
||||
}
|
||||
|
||||
main_colour_btn->image = SPRITE_ID_PALETTE_COLOUR_1(_mainColour) | IMAGE_TYPE_TRANSPARENT | SPR_PALETTE_BTN;
|
||||
text_colour_btn->image = SPRITE_ID_PALETTE_COLOUR_1(_textColour) | IMAGE_TYPE_TRANSPARENT | SPR_PALETTE_BTN;
|
||||
main_colour_btn->image = GetColourButtonImage(_mainColour).ToUInt32();
|
||||
text_colour_btn->image = GetColourButtonImage(_textColour).ToUInt32();
|
||||
}
|
||||
|
||||
void OnDraw(rct_drawpixelinfo& dpi) override
|
||||
|
|
|
@ -252,8 +252,9 @@ public:
|
|||
if (GetSelectedStaffType() != StaffType::Entertainer)
|
||||
{
|
||||
widgets[WIDX_STAFF_LIST_UNIFORM_COLOUR_PICKER].type = WindowWidgetType::ColourBtn;
|
||||
auto spriteIdPalette = SPRITE_ID_PALETTE_COLOUR_1(static_cast<uint32_t>(staff_get_colour(GetSelectedStaffType())));
|
||||
widgets[WIDX_STAFF_LIST_UNIFORM_COLOUR_PICKER].image = spriteIdPalette | IMAGE_TYPE_TRANSPARENT | SPR_PALETTE_BTN;
|
||||
widgets[WIDX_STAFF_LIST_UNIFORM_COLOUR_PICKER].image = GetColourButtonImage(
|
||||
staff_get_colour(GetSelectedStaffType()))
|
||||
.ToUInt32();
|
||||
}
|
||||
SetWidgetPressed(WIDX_STAFF_LIST_QUICK_FIRE, _quickFireMode);
|
||||
|
||||
|
|
|
@ -461,8 +461,6 @@ void FASTCALL BlitPixels(const uint8_t* src, uint8_t* dst, const PaletteMap& pal
|
|||
}
|
||||
}
|
||||
|
||||
#define SPRITE_ID_PALETTE_COLOUR_1(colourId) (IMAGE_TYPE_REMAP | ((colourId) << 19))
|
||||
|
||||
#define PALETTE_TO_G1_OFFSET_COUNT 144
|
||||
|
||||
#define INSET_RECT_F_30 (INSET_RECT_FLAG_BORDER_INSET | INSET_RECT_FLAG_FILL_NONE)
|
||||
|
|
Loading…
Reference in New Issue