| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The WindowBuilder propertysheet has been extracted and added as a
library in external/eclipse-windowbuilder/.
This changeset removes the old propertysheet code (which used the
builtin Eclipse property sheet page), and replaces it with the
WindowBuilder one, along with new code to aggregate the properties
into some categories, as well as tagging some of the properties as
advanced. (This was computed by running the same analysis scripts used
to produce the most-frequent attributes (sdk/attribute_stats) and
instead computing which attributes are used very infrequently or not
at all in some representative sample code.)
The WindowBuilder propertysheet gives us the following new features:
- Highlighting (bold) of important attributes
- Masking (and when included, shown in gray italic) of advanced
  attributes
- "Complex" attributes with nesting, used to for example aggregate all
  the layout parameters into a single node, and the margin layout
  attributes within those
- Tooltips over the attribute names, not values, so they never obscure
  content
In addition, this changeset adds custom implementations of properties,
property editors and property dialogs for the core Android property
types (XML strings, flags and booleans), which adds the following new
features:
- Preview rendering of color and image resources inline
- Display of -default- attributes (those not specified in XML) using
  the layoutlib facility getDefaultProperties() to render the implied
  attributes. For example, if you look at a Button, it will show you
  that the implied value of "Text Color Link" is
  "@android:color/holo_blue_light" even though it is not set.
  NOTE: This only happens for attributes that were actually queried by
  the widget during rendering. Attributes that are not used by the
  widget have no (displayed) value. Thus, EditText-specific attributes
  in a TextView are not shown when a non-EditText TextView is
  selected.
- Evaluation of the attributes. In the above example, in addition to
  showing @android:color/holo_blue_light, it will chase down the value
  of this to for example render a blue square next to the value.  For
  drawables it will render a thumbnail, and for String resources it
  will display the actual value in parentheses.
- Field completion in text fields, completing all resource strings
  (@string, @android:string, etc), as well as flag values. Enum values
  are chosen in a dropdown.
- Checkbox support for boolean values, allowing you to click through
  the three values true, false and null.
- Our custom version of the Property Sheet Page allows you to
  expand/collapse all properties, and it also has an option letting
  you switch between Alphabetical Sort (where all attributes are in a
  flat table, sorted alphabetically by property value), or
  hierarchical sorted "by category". Currently the categories are
  simply the defining views, plus 2 more (layout parameters and
  deprecated attributes). When we get more metadata, it would be nice
  to switch these to more logical categories, such as "text",
  "scrolling", "focus", etc. (There is some preliminary support for
  this in the code, but since the defining-view categories seem to
  work better those are used instead right now.)
Change-Id: Ie4959a3a2c36c083dcc1ba19a70f24b33739fe2f | 
|  | This changeset adds two forms of view attribute metadata:
* First, it records the most commonly used attributes for each
  view. This was determined by gathering statistics on as many layout
  files as I could find and then picking those that are used 10% or
  more.
* Second, it records in the attribute metadata which View defines a
  given attribute.
The context menu uses the above information to present the available
attributes in several ways:
* In the top level menu, where we had "Edit ID", and if applicable
  "Edit Text", it now lists the top attributes instead. For example,
  for a RatingBar the first handful of menu options are "Edit ID...",
  "Edit NumStars...", "Edit StepSize...", "Edit Style..." and
  "IsIndicator" (a boolean pull-right menu).
  Incidentally this automatically handles some cases which were
  manually handled before, so the code in LinearLayoutRule to add an
  "Orientation" menu is no longer needed; it's just one of the two
  common attributes handled by the new attribute list.
* The "Properties" menu is now called "Other Properties", and instead
  of showing all properties, it has a new level of menus:
  * "Recent". This is initially empty, but as you edit other attributes,
    it gets populated (in most recently used order, kept up to date)
    with recently edited properties.
  * One submenu for each defining View super class listing exactly
    the attributes defined by that view. This is useful for browsing
    and editing related attributes. If you are looking at a textual
    view like a Button for example, you can look at the "TextView"
    menu to find all the text related options (TextColor, TextSize,
    etc).  These menus are listed from the nearest to the further
    superclass, so for example if you right click on a CalendarView
    you'll see these menus:
       Recent                     >
       ----------------------------
       Defined by CalendarView    >
       Inherited from FrameLayout >
       Inherited from ViewGroup   >
       Inherited from View        >
       ----------------------------
       Layout Parameters          >
       ----------------------------
       All By Name                >
  * As you can see from the above, there are two more menus below the
    inherited menu items. "Layout Parameters" lists all the layout
    parameters available for the selected nodes (which is defined not
    by the view itself but the view that it is contained within).  And
    finally there is "All By Name", which is a complete menu
    containing all available attributes for the view (and this is what
    the Properties menu used to contain).
* The code which computes a display name from an attribute was also
  tweaked to capitalize not just the first letter but any first word
  letter, so for example when you look at the possible values for
  Gravity you now see "Clip Vertical" instead of "Clip vertical".
* The edit property dialog for the properties menus now uses @string
  or @style resource choosers for the text, hint and style attributes
  (used to just be a plain text box.)
Change-Id: I3b30d48b85fd13f0190c760756bf383a47b3f4a5 |