Talk:RCOXML Objects

From PS3 Developer wiki
Jump to navigation Jump to search

Rcomage unknown object attributes

At the time of documenting the RCO format for wiki it was posible to identify some/lot of unknown attributes, in the link there are a few of them listed as dirty notes (later was identifyed some more that are not included in the link). At this point there is no need for that dirty notes because the new names of the identifyed attributes was used in the tables in wiki, the dirty notes are just kept to have a record of the changes, and liked here because are very related with this page

Menu lists and menu items

Type Name Displayed as Notes
Suggested names
for Wiki
In rcomage In official RCOXML code In official VSH Exports
0x08 0x04 XmBarList ? XMenu name="xmenu" XmBar XMB Main Menu, horizontal list placeholder Main XMB
0x08 0x05 XmBarItem ? XMList name="list_sysconf" XmList XMB Main Menu, horizontal list item
0x08 0x06 ??? XList name="xlist_video_config" XMB Main Menu, vertical list placeholder
0x08 0x09 MenuList MList name="mlist_select_update_method" MenuList Context Menu, vertical list placeholder Menu when pressing triangle
at right side of the screen
0x08 0x0A MenuItem MItem name="mitem_select_network" Context Menu, vertical list item
0x08 0x0B UnknownList ? ObjUnknown0xB 0x0B is the "List"
0x0C is the "Item"
0x08 0x0C UnknownItem ? XItem name="item_xlist_video_config_volume"
0x08 0x13 L???List LList name="list_edit_apcnf7" List Editable Menu, horizontal list placeholder Like in network settings
0x08 0x14 L???Item LItem name="litem_edit_apcnf7_0" Editable Menu, horizontal list item
0x08 0x17 InfoList IList name="ilist_ms_info" InfoList Information Menu, vertical list placeholder Like in audio file info
0x08 0x18 InfoItem IItem name="item_ms_info_size" Information Menu, vertical list item
0x08 0x1C CheckBoxList CheckboxGroup name="checkbox_list_npsignin" CheckBoxList Checkbox Menu, horizontal list placeholder Like in poweroff screen
0x08 0x1D CheckBoxItem CheckboxItem name="checkbox_item_select_auto_power_off" CheckBox ? Checkbox Menu, horizontal list item
  • Problematic names and values are marked in red
  • CheckboxGroup and CheckboxItem can be renamed to CList and CItem
  • The "Items" has only 3 specific attributes, and that atributes are either a "text" or a "image" only (this is and easy way to identify them)
  • The "Lists" has variable number of specific attributes based on its purpose, some of them matches partially

WidgetType

See the "paf" VSH Exports

It seems the WidgetType is an identifyer of what rcomage and this wiki page baptished as "objects". Of all them, or only a group

By looking at the internal RCO structure is obvious that the value used internally to identify every "object" is the first field of what we has been naming Template:RCO TOC entry common area, or in other words, the Template:RCO TOC entry types

So the question is... all "RCO TOC entry types" should be considered WidgetType ? (and consequentlly needed to be renamed in wiki pages)... or only a group of them are considered "widgets" ? and there is other group (no idea wich one by now, but RCOXML Animations could have a different name)

By looking at this list is posible to make a list of the exports that uses the keyword "WidgetType" and deduce the correspondency with the names we have been using in rcomage/wiki. Some of the "unnofficial" names we have been using matches exactlly, others partially, and there are a few "new" names hard to deduce to wich "object" corresponds, and probably are included the 2 infamous ObjUnknown0xB and ObjUnknown0x1B that are completlly unknown for rcomage and doesnt seems to be used in any of the official PSP and PS3 firmwares

VSH Exports string chunk name in RCOmage type ID Notes
ZN3paf8PhWidget10WidgetTypeEv ? ? weird, a WidgetType named Widget ?... this sounds too generic, maybe is the name of the "ObjectTree"
ZN3paf7PhScene10WidgetTypeEv Page ? 0x1 ?
ZN3paf7PhPlane10WidgetTypeEv Plane 0x02
0xE36C18F5 (returns PhPlaneDiv) ? ? only appears in the VSH Exports page in wiki, not in the github list
ZN3paf8PhButton10WidgetTypeEv Button 0x03
ZN3paf6PhText10WidgetTypeEv Text 0x0D
ZN3paf8PhScroll10WidgetTypeEv Scroll 0x08
ZN3paf11PhLabelPrim10WidgetTypeEv ? ? candidate to be ObjUnknown0xB or ObjUnknown0x1B
ZN3paf12PhLevelMeter10WidgetTypeEv Meter 0x1E
ZN3paf10PhProgress10WidgetTypeEv Progress 0x07
ZN3paf10PhCheckBox10WidgetTypeEv CheckBoxItem 0x1D
ZN3paf7PhXmBar10WidgetTypeEv XMenu ? 0x04 ?
ZN3paf8PhXmList10WidgetTypeEv XMList ? 0x05 ?
ZN3paf8PhXmItem10WidgetTypeEv ? ?
ZN3paf10PhItemSpin10WidgetTypeEv ItemSpin 0x11
ZN3paf9PhNumSpin10WidgetTypeEv Spin ? 0x0F ?
ZN3paf6PhList10WidgetTypeEv LList 0x013
ZN3paf10PhInfoList10WidgetTypeEv IList 0x17
ZN3paf10PhMenuList10WidgetTypeEv MList 0x09
ZN3paf14PhCheckBoxList10WidgetTypeEv CheckBoxGroup 0x1C
ZN3paf11PhLabelText10WidgetTypeEv EditBox ? 0x1F ?
ZN3paf7PhClock10WidgetTypeEv Clock 0x16
ZN3paf8PhIPAddr10WidgetTypeEv ? ? candidate to be ObjUnknown0xB or ObjUnknown0x1B. A widget only to display the IP address ?
  • Other unnofficial "object" names that are not in the table:
    • General
      • type=0x00 ObjectTree
      • type=0x12 Group
    • Lists and Items
      • type=0x06 XList
      • type=0x0C XItem
      • type=0x0A MItem
      • type=0x14 LItem
      • type=0x18 IItem
    • Others
      • type=0x19 Icon
      • type=0x10 Action
      • type=0x1A UButton
      • type=0x0E ModelObject
      • type=0x15 Edit
    • Unknowns
      • type=0x0B ObjUnknown0xB
      • type=0x1B ObjUnknown0x1B

ObjUnknown0xB

*Superbrainstorming based on smoke. This brainstorming seems to be wrong, because the object named "XMList" by rcomage seems to be an "item" so it cant have other xml "item" childrens **what about this ?, matches prety fine with how are grouped. Main menu separated because is an special object created specifically for top XMB menu, and the others grouped in pairs for "list" and "item". Also matches how are ordered in rcomage. All this attributes appears consecutivelly in groups of two, at top... XMList and XList... then MList MItem... then ObjUnknown0xB and XItem... then LList and LItem... then IList and IItem. Note how XMList doesnt seems to have an XMItem

XMenu

XMList
ObjUnknown0xB <------ is XMItem ?

XList
XItem

MList
MItem

LList
LItem

IList
IItem

If this is true and ObjUnknown0xB is actually XMItem it seems is posible to deduce the attributes because the other "item" objects uses pretty similar attributes (usually 3 attributes, either images or texts), to verify it are needed some/lot of tests by copying the attributes from the other items and creating a 100% custom object for the experiment also a good understanding of all the other rcoxml code, so is hard to know, im not skilled/brave to build this frankenstein but i think the theory is good enought--Sandungas (talk) 08:16, 8 December 2015 (UTC)

Objects using overrides in the "specific" attributes

The "standard" attributes contains 6 overrides and most objects uses the "standard" attributes, but additionally to this ones some of the objects (seems to) use more overrides in the "specific" attributes

  • Some menu builders
    • MList (3 ?)
    • LList (2 ?)
    • IList (1 ?)
  • Text based objects
    • Text (3 ?)
    • EditBox (3 ?)
  • Others
    • CheckboxGroup (1 ?)
    • Meter (1 ?)

anchorMode

Rcomage has some problems with this attribute from PS3 RCOs, it manages the value as 4 bytes length but in the internal RCO file structure is divided in 2 chunks of 2 bytes each. The anchor mode is specifyed by the first byte of the second chunk, is unknown why sony "reserved" 2 bytes for the first chunk (first chunk is always filled with zeroes). All this is a bit confusing and what im saying could not be completly accurate because the different endianess in between PSP and PS3 and what RCOmage does internally. RCOmage allows to choose a "data type" for every attribute by editing the file objectattribdef-ps3.ini. There is no way to extract the value accuratelly so the alternatives are to set it as "int", or you can set it to "unk" instead, this way it will be managed as raw data (no conversion applyed so you can see the real value when the info is extracted to XML)

  • Examples:
    • Extracted as "int"
      • anchorMode="0x320000"
    • Extracted as "unk"
      • anchorMode="0x3200"

Links, notes, etc...

Suggestions