mirror of
https://github.com/bsnes-emu/bsnes.git
synced 2025-02-24 07:02:27 +01:00
byuu says: Changelog: - updated to newest hiro API - SFC performance profile builds once again - hiro: Qt port completed Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by crashing inside InputSettings because hiro/Qt isn't forcefully selecting the first item added to a ComboButton just yet. Even with a monkey patch to get around that, the UI is incredibly unstable. Lots of geometry calculation bugs, and a crash when you try and access certain folders in the browser dialog. Lots of work left to be done there, sadly. Errata 2: the hiro/Windows port has black backgrounds on all ListView items. It's because I need to test for unassigned colors and grab the default Windows brush colors in those cases. Note: alternating row colors on multi-column ListView widgets is gone now. Not a bug. May add it back later, but I'm not sure. It doesn't interact nicely with per-cell background colors. Things left to do: First, I have to fix the Windows and Qt target bugs. Next, I need to go through and revise the hiro API even more (nothing too major.) Next, I need to update icarus to use the new hiro API, and add support for the SFC games database. Next, I have to rewrite my TSV->BML cheat code tool. Next, I need to post a final WIP of higan+icarus publicly and wait a few days. Next, I need to fix any bugs reported from the final WIP that I can. Finally, I should be able to release v095.
76 lines
1.7 KiB
C++
76 lines
1.7 KiB
C++
#if defined(Hiro_ListView)
|
|
|
|
namespace hiro {
|
|
|
|
auto pListViewItem::construct() -> void {
|
|
if(auto parent = _parent()) {
|
|
parent->lock();
|
|
wchar_t text[] = L"";
|
|
LVITEM lvItem{0};
|
|
lvItem.mask = LVIF_TEXT;
|
|
lvItem.iItem = self().offset();
|
|
lvItem.iSubItem = 0;
|
|
lvItem.pszText = text;
|
|
ListView_InsertItem(parent->hwnd, &lvItem);
|
|
_setState();
|
|
parent->unlock();
|
|
}
|
|
}
|
|
|
|
auto pListViewItem::destruct() -> void {
|
|
if(auto parent = _parent()) {
|
|
parent->lock();
|
|
ListView_DeleteItem(parent->hwnd, self().offset());
|
|
parent->unlock();
|
|
}
|
|
}
|
|
|
|
auto pListViewItem::append(sListViewCell cell) -> void {
|
|
}
|
|
|
|
auto pListViewItem::remove(sListViewCell cell) -> void {
|
|
}
|
|
|
|
auto pListViewItem::setAlignment(Alignment alignment) -> void {
|
|
}
|
|
|
|
auto pListViewItem::setBackgroundColor(Color color) -> void {
|
|
}
|
|
|
|
auto pListViewItem::setFocused() -> void {
|
|
if(auto parent = _parent()) {
|
|
parent->lock();
|
|
ListView_SetItemState(parent->hwnd, self().offset(), LVIS_FOCUSED, LVIS_FOCUSED);
|
|
parent->unlock();
|
|
}
|
|
}
|
|
|
|
auto pListViewItem::setForegroundColor(Color color) -> void {
|
|
}
|
|
|
|
auto pListViewItem::setSelected(bool selected) -> void {
|
|
_setState();
|
|
}
|
|
|
|
auto pListViewItem::_parent() -> maybe<pListView&> {
|
|
if(auto parent = self().parentListView()) {
|
|
if(auto self = parent->self()) return *self;
|
|
}
|
|
return nothing;
|
|
}
|
|
|
|
auto pListViewItem::_setState() -> void {
|
|
if(auto parent = _parent()) {
|
|
parent->lock();
|
|
ListView_SetItemState(parent->hwnd, self().offset(), state().selected ? LVIS_SELECTED : 0, LVIS_SELECTED);
|
|
for(auto& cell : state().cells) {
|
|
if(auto self = cell->self()) self->_setState();
|
|
}
|
|
parent->unlock();
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|