Может кто-нибудь объяснить attr?


89

Я смотрю пример кода Honeycomb Gallery ( здесь ) и натолкнулся на следующий код, пытаясь добавить элементы действий в свое собственное приложение:

<item android:id="@+id/camera"
    android:title="Camera"
    android:icon="?attr/menuIconCamera"
    android:showAsAction="ifRoom" />

Это ?attrменя зацикливает. Может кто-нибудь объяснить, что это делает? Как это связано с возможностью рисования? Кажется, я не могу найти никакой хорошей информации в Google. Также есть ли список или галерея атрибутов, которые мы можем использовать для значков, а не просто menuIconCamera?

Благодарность

Изменить: я еще немного осмотрелся и обнаружил, что attrs.xml выглядит так:

<resources>
<declare-styleable name="AppTheme">
    <attr name="listDragShadowBackground" format="reference" />
    <attr name="menuIconCamera" format="reference" />
    <attr name="menuIconToggle" format="reference" />
    <attr name="menuIconShare" format="reference" />
</declare-styleable>

К сожалению, это еще больше сбивает меня с толку. Что это делает?

Ответы:


64

В ?attr/menuIconCameraстоимость означает , что икона из menuIconCameraбудет использоваться атрибут текущей темы.

menuIconCameraГде-то в themes.xmlфайле атрибуту должен быть назначен объект для рисования . Если есть две темы с разными значениями этого атрибута, то фактический значок будет зависеть от темы, которая используется в настоящее время.

attrs.xmlФайл используется для определения пользовательских атрибутов. Без этого определения компилятор будет рассматривать неизвестные атрибуты как ошибочные.


1
Вы совершенно правы, <item name = "menuIconCamera"> @ drawable / ic_menu_camera_holo_light </item>, большое спасибо. Я вижу, что ic_menu_camera_holo_light - это локальный чертеж. В 3.x нет встроенных публичных иконок, как в 2.x?
FuegoFingers

Не думаю, что это как-то связано с версией Android. Это просто способ сделать атрибуты зависимыми от выбранной темы.
Майкл

51

?attr:Синтаксис используется для доступа к атрибутам текущей темы. См. Ссылку на атрибуты стиля .


3
Прилагаемая ссылка была очень и очень полезной. Благодарность!
sven

3
Очень полезно, но вы все равно должны публиковать основные части этой ссылки.
gustavohenke

1
Это была самая полезная часть связанной статьи: «Ресурс атрибута стиля позволяет вам ссылаться на значение атрибута в применяемой в данный момент теме. Ссылка на атрибут стиля позволяет вам настроить внешний вид элементов пользовательского интерфейса, стилизовав их в соответствии со стандартными вариантами, предоставляемыми текущей темой, вместо того, чтобы указывать жестко заданное значение. Ссылка на атрибут стиля, по сути, говорит: «Используйте стиль, который определен этим атрибутом в текущей теме».
bigtex777

24

Я знаю, что этот пост очень старый, но думаю, что следующее объяснение поможет новичкам легко его понять.

Итак, с точки зрения непрофессионала,

someAttribute="?attr/attributeName" означает -

установить значение someAttribute на любое значение attributeName в текущей теме

Типичный пример - стилизация панели инструментов

<style name="AppTheme" parent="@style/Theme.AppCompat.Light.NoActionBar">
        <item name="colorPrimary">@color/primary_color</item>
       //some more stuff here
</style>
<!-- custom toolbar style -->
<style name="myToolbar" parent="Widget.AppCompat.Toolbar">
      <item name="android:background">?attr/colorPrimary</item>
     //some code here
</style>

Здесь android:backgroundбудет установлено значение, @color/primary_colorпоскольку ?attr/colorPrimaryотносится к @color/primary_colorтекущей теме (AppTheme)


16

У меня плохой английский, извините. Но я знаю этот вопрос

android:icon="?attr/menuIconCamera" хочу использовать

attrs.xml

<resources>
    <declare-styleable name="AppTheme">
        <attr name="listDragShadowBackground" format="reference" />
        <attr name="menuIconCamera" format="reference" />
        <attr name="menuIconToggle" format="reference" />
        <attr name="menuIconShare" format="reference" />
    </declare-styleable>
</resources>

styles.xml

<style name="AppTheme.Light" parent="@android:style/Theme.Holo.Light">
        <item name="android:actionBarStyle">@style/ActionBar.Light</item>
        <item name="android:windowActionBarOverlay">true</item>
        <item name="listDragShadowBackground">@android:color/background_light</item>
        <item name="menuIconCamera">@drawable/ic_menu_camera_holo_light</item> //this....
        <item name="menuIconToggle">@drawable/ic_menu_toggle_holo_light</item>
        <item name="menuIconShare">@drawable/ic_menu_share_holo_light</item>
    </style>

использовать @drawable/ic_menu_camera_holo_light


4

Это относится к атрибутам стиля. см. R.attr

?[<package_name>:][<resource_type>/]<resource_name>

Ссылка на атрибуты стиля


3
Одна вещь, которая, похоже, нигде не задокументирована, - это то, что «<package_name>» - это полное имя пакета того, что объявлено ресурсом. Точнее говоря, это не префикс пространства имен XML, хотя синтаксис может предполагать это. Например, чтобы обратиться к attr, объявленному библиотекой appcompat, используйте android.support.v7.appcompat:.
Хватит вредить сообществу

4

В этом сообщении блога замечательно рассказывается, как ссылаться на значения атрибутов стиля, которые определены в текущей теме: https://trickyandroid.com/android-resources-and-style-attributes-cheatsheet/

  • Когда вы видите ?обозначение - это означает, что мы пытаемся ссылаться на атрибут стиля - значение, которое может варьироваться в зависимости от текущей темы. В каждой конкретной теме мы можем переопределить этот атрибут, поэтому макет XML не нужно менять, а нужно применять правильную тему.

  • Когда вы видите @обозначение - мы ссылаемся на фактическое значение ресурса (цвет, строка, размер и т. Д.). У этого ресурса должна быть реальная стоимость. В этом случае мы точно знаем, с какой ценностью имеем дело.

Вот пример:

    <style name="AppTheme" parent="Theme.AppCompat.NoActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

    <style name="LauncherButton" parent="TextAppearance.AppCompat.Medium">
        <item name="android:textColor">?colorAccent</item>
        <item name="android:layout_width">match_parent</item>
        <item name="android:layout_height">wrap_content</item>
        <item name="android:layout_centerHorizontal">true</item>
        <item name="android:textAllCaps">false</item>
    </style>
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.