2016-07-10 96 views
2

修订
我尝试添加SpinnerToolbar编程。所以,我写了下面的代码: 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> 

SPINN呃项目视图的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> 

结果:
ScreenshotScreenshot 2 如何?我什么都不懂了......如何解决它?

+0

为什么不使用xml添加它呢?工具栏就像其他任何布局;只需将它添加到工具栏中,然后重力开始或中心 – Eenvincible

+0

当我将它添加到xml中时,它不起作用。它只显示直角三角形(没有文字) –

+0

@Eenvincible,请看。我更新了我的主题。 –

回答

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) { 

     } 
    }); 

    } 
} 

最后,主题化,你应该在你的风格以下。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> 

这里是一个repository我为上面的代码创建的。

我希望这可以帮助你;我已经尝试过了,它工作得很好;

+0

谢谢!我会稍后再尝试。 –

+0

它不显示全部相同!不幸的是,我无法排除'AppBarLayout'。 –

+0

我喜欢这个'Spinner'。即使在'onCreate'方法中,只有当我已经设置了内容适配器或者调用'notifyDataSetChanged()'时, –