Как программно изменить цвет значка меню гамбургера, используя шестнадцатеричные значения в формах xamarin? - PullRequest
0 голосов
/ 01 февраля 2020

Я работаю над приложением mvvm light xamarin forms, в котором я разрешаю пользователю создавать собственную тему в самом приложении. На данный момент у меня все работает как задумано, за исключением кнопки отправки (значок изображения), кнопки добавления (значок изображения) и значка меню гамбургера.

Пользователь выбирает изображение / имя, затем шестнадцатеричное значение этого цвета применяется к элементу управления / шрифту. Но я столкнулся с проблемой при попытке программно установить цвет меню гамбургера. Я начал со стороны android. Я могу установить цвет один раз, используя стили. xml.

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

Мне также нужно, чтобы такое же действие происходило с iOS (изменяемое меню цветного гамбургера). Я не хочу предоставлять изображения, потому что пользователь будет устанавливать цвет на основе шестнадцатеричного значения ... какой мой лучший вариант? То, что я пытаюсь сделать, даже возможно в этот момент?

   public class MainActivity : global::Xamarin.Forms.Platform.Android.FormsAppCompatActivity
    {
        protected ActionBarDrawerToggle drawerToggle;
        protected override void OnCreate(Bundle savedInstanceState)
        {
            TabLayoutResource = Resource.Layout.Tabbar;
            ToolbarResource = Resource.Layout.Toolbar;

            base.OnCreate(savedInstanceState);
            Rg.Plugins.Popup.Popup.Init(this, savedInstanceState);
            global::Xamarin.Forms.Forms.Init(this, savedInstanceState);
            LoadApplication(new App());

    drawerToggle.getDrawerArrowDrawable().setColor(getResources().getColor(R.color.white));
        }
    }

Я нашел этот код здесь:

drawerToggle.getDrawerArrowDrawable().setColor(getResources().getColor(R.color.white));

Это было бы идеально, но у меня нет ссылки to boxToggle ... (объект имеет значение null)

Я также попытался установить его с помощью стилей. xml, как показано ниже:

<?xml version="1.0" encoding="utf-8" ?>
<resources>

  <style name="MainTheme" parent="MainTheme.Base">
  </style>
  <!-- Base theme applied no matter what API -->
  <style name="MainTheme.Base" parent="Theme.AppCompat.Light.DarkActionBar">
    <!--If you are using revision 22.1 please use just windowNoTitle. Without android:-->
    <item name="windowNoTitle">true</item>
    <!--We will be using the toolbar so no need to show ActionBar-->
    <item name="windowActionBar">false</item>
    <!-- Set theme colors from http://www.google.com/design/spec/style/color.html#color-color-palette -->
    <!-- colorPrimary is used for the default action bar background -->
    <item name="colorPrimary">#2196F3</item>
    <!-- colorPrimaryDark is used for the status bar -->
    <item name="colorPrimaryDark">#1976D2</item>
    <!-- colorAccent is used as the default value for colorControlActivated
         which is used to tint widgets -->
    <item name="colorAccent">#FF4081</item>
    <!-- You can also set colorControlNormal, colorControlActivated
         colorControlHighlight and colorSwitchThumbNormal. -->
    <item name="windowActionModeOverlay">true</item>

    <item name="android:datePickerDialogTheme">@style/AppCompatDialogStyle</item>
  <item name="drawerArrowStyle">@style/DrawerArrowStyle</item>
  </style>

  <style name="DrawerArrowStyle" parent="@style/Widget.AppCompat.DrawerArrowToggle">
    <item name="spinBars">true</item>
    <item name="color">@android:color/green</item>
  </style>

  <style name="AppCompatDialogStyle" parent="Theme.AppCompat.Light.Dialog">
    <item name="colorAccent">#FF4081</item>
  </style>
</resources>

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

1 Ответ

0 голосов
/ 20 февраля 2020
  1. добавить значок меню гамбургера в папку для рисования hamburger menu icon

  2. Добавить код, где вы будете sh, чтобы изменить его.

    var toolbar = FindViewById (Resource.Id.toolbar); var view = (AppCompatImageButton) toolbar.GetChildAt (2); // 1. actionmenuview (значки основного / дополнительного меню), // 2. appcompattextview (title), // 3. appcompatimagebutton (значок гамбургера) view.SetImageDrawable (d); // view.SetImageDrawable (d);

в моем случае у меня есть значки меню, поэтому я выбираю GetChildAt (2) [третий элемент]

...