簡體   English   中英

工具欄不顯示微調器

[英]Toolbar doesn't show Spinner

更新
我嘗試以編程方式將Spinner添加到Toolbar 所以,我寫了下一個代碼: ToolbarSpinnerAdapter

public class ToolbarSpinnerAdapter extends BaseAdapter {

    public static final int NONE = -1;

    private final LayoutInflater mInflater;
    private List<String> mItems = new ArrayList<>();
    private int mSelectedPosition = NONE;
    private Drawable mSelector;

    public ToolbarSpinnerAdapter(Context context) {
        mInflater = LayoutInflater.from(context);
        mSelector = VectorDrawable.getDrawable(context, R.drawable.ic_done_green_24dp);
        final int color = ContextCompat.getColor(context, R.color.primary);
        mSelector.setColorFilter(new PorterDuffColorFilter(color, PorterDuff.Mode.SRC_ATOP));
    }

    public void setSelection(final int position) {
        mSelectedPosition = position;
    }

    public int getSelection() {
        return mSelectedPosition;
    }

    public void add(final String item) {
        mItems.add(item);
    }

    public void addAll(String[] items) {
        Collections.addAll(this.mItems, items);
    }

    @Override
    public int getCount() {
        return mItems.size();
    }

    @Override
    public Object getItem(final int position) {
        return mItems.get(position);
    }

    @Override
    public long getItemId(final int position) {
        return position;
    }

    @Override
    public View getDropDownView(final int position, View view, ViewGroup parent) {

        if (view == null || !view.getTag().toString().equals("DROPDOWN")) {
            view = mInflater.inflate(R.layout.toolbar_spinner_dropdown_item, parent, false);
            view.setTag("DROPDOWN");
        }

        TextView textView = (TextView) view.findViewById(android.R.id.text1);
        textView.setText(getTitle(position));

        if(position == mSelectedPosition) {
            textView.setCompoundDrawablesWithIntrinsicBounds(null, null, mSelector, null);
        } else {
            textView.setCompoundDrawablesWithIntrinsicBounds(null, null, null, null);
        }

        return view;
    }

    @Override
    public View getView(final int position, View view, ViewGroup parent) {

        if (view == null || !view.getTag().toString().equals("NON_DROPDOWN")) {
            view = mInflater.inflate(R.layout.toolbar_spinner_item, parent, false);
            view.setTag("NON_DROPDOWN");
        }

        TextView textView = (TextView)view.findViewById(android.R.id.text1);
        textView.setText(getTitle(position));

        return view;
    }

    private String getTitle(final int position) {
        return mItems.get(position);
    }
}

使用代碼:

protected void initToolbar(Toolbar toolbar) {
    final MainActivity activity = (MainActivity) getActivity();
    activity.setSupportActionBar(toolbar);
    mDrawerToggle = new ActionBarDrawerToggle(activity, activity.getDrawerLayout(), toolbar, R.string.app_name, R.string.app_name);
    activity.getDrawerLayout().addDrawerListener(mDrawerToggle);
    ActionBar actionBar = activity.getSupportActionBar();
    Context toolbarContext;

    if (actionBar != null) {
        actionBar.setDisplayHomeAsUpEnabled(true);
        actionBar.setHomeButtonEnabled(true);
        actionBar.setDisplayShowTitleEnabled(false);
        mDrawerToggle.syncState();
        toolbarContext = activity.getSupportActionBar().getThemedContext();
    } else {
        toolbarContext = getContext();
    }

    mWeekSpinner = new Spinner(toolbarContext);
    ToolbarSpinnerAdapter adapter = new ToolbarSpinnerAdapter(toolbarContext);
    mWeekSpinner.setAdapter(adapter);
    toolbar.addView(mWeekSpinner);
    final String[] weekNames = WeekUtils.getWeekNames(getContext(), mTimetable.getWeekCount());
    adapter.addAll(weekNames);
    final int currentWeek = WeekUtils.getCurrentWeek(mTimetable);
    adapter.setSelection(currentWeek - 1);
    mWeekSpinner.setSelection(currentWeek - 1);
}

片段布局xml:

<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".activity.MainActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            app:layout_scrollFlags="scroll|enterAlways"/>

        <android.support.design.widget.TabLayout
            android:id="@+id/tabs"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:layout_gravity="bottom"
            android:background="@drawable/bg_tabs"
            app:tabGravity="fill"
            app:tabIndicatorColor="@color/primary"
            app:tabIndicatorHeight="6dp"
            app:tabMode="scrollable"
            app:tabSelectedTextColor="@color/primary"
            app:tabTextColor="@color/black_54"/>

    </android.support.design.widget.AppBarLayout>

    <!-- Body views -->

</android.support.design.widget.CoordinatorLayout>

Spinner 項目視圖 xml:

<TextView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/text1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/primary"
    android:gravity="center_vertical"
    android:minHeight="?attr/listPreferredItemHeightSmall"
    android:paddingLeft="12dp"
    android:paddingRight="12dp"
    android:textAppearance="?attr/textAppearanceListItemSmall"/>

活動主題:

<style name="Theme.Paper" parent="Theme.AppCompat.Light.NoActionBar">
    <item name="colorPrimary">@color/primary</item>
    <item name="colorPrimaryDark">@color/primary_dark</item>
    <item name="colorAccent">@color/accent</item>
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
    <item name="windowActionModeOverlay">true</item>
</style>

結果:
截屏 截圖 2 如何? 我什么都不懂...如何解決?

現在讓我們一勞永逸地解決這個問題:

嘗試這個:

首先 - 在 strings.xml 中

<string-array name="months">
    <item>January</item>
    <item>February</item>
    <item>March</item>
    <item>April</item>
    <item>May</item>
    <item>June</item>
    <item>July</item>
    <item>August</item>
</string-array>

您可以簡單地替換為您的真實值;

第二 - 在您的主要布局中

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  tools:context=".MainActivity">

  <android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="?attr/colorPrimary"
    android:minHeight="?attr/actionBarSize" />

關鍵是將您的工具欄放在布局中,就像您在上面所做的那樣。

三自定義微調器布局

為您的微調器創建自定義視圖!

<?xml version="1.0" encoding="utf-8"?>
<TextView
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@android:id/text1"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:background="@color/colorPrimary"
  android:gravity="center_vertical"
  android:minHeight="?android:attr/listPreferredItemHeightSmall"
  android:paddingLeft="12dp"
  android:paddingRight="12dp"
  android:textAppearance="?android:attr/textAppearanceListItemSmall"  />

四——MainActivity.java這里,我們來完成代碼。

public class MainActivity extends AppCompatActivity {

   private Toolbar toolbar = null;
   private String[] month = null;

   @Override
   protected void onCreate(Bundle savedInstanceState) {
     super.onCreate(savedInstanceState);
     setContentView(R.layout.activity_main);

     month = getResources().getStringArray(R.array.months);

     toolbar = (Toolbar) findViewById(R.id.toolbar);
     setSupportActionBar(toolbar);

     SpinnerAdapter spinnerAdapter = ArrayAdapter.createFromResource(getApplicationContext(), R.array.months, R.layout
            .spinner_drop_down_item);
     Spinner navigationSpinner = new Spinner(getSupportActionBar().getThemedContext());
     navigationSpinner.setAdapter(spinnerAdapter);
     toolbar.addView(navigationSpinner, 0);

      navigationSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
        @Override
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
            Toast.makeText(MainActivity.this,
                    "you selected: " + month[position],
                    Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onNothingSelected(AdapterView<?> parent) {

        }
     });

   }
}

最后,對於主題,您的styles.xml 中應該包含以下內容

<resources>

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="windowActionModeOverlay">true</item>
    <item name="windowActionBar">false</item>
    <item name="android:windowNoTitle">true</item>
</style>

這是我為上面的代碼創建的存儲庫

我希望這可以幫助你; 我試過了,效果很好;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM