Intents や Views (TabHost のように) なしで Android のシンプルなタブに実装する方法は?
タブヘッダーだけが必要で、タブインデックスがどのように変化するかを聞きたいです。
または、マルチポジション スイッチの実装方法を教えてください。
UPD:別の目的で既に使用されている api v14 と ActionBar タブを使用しています。
最も単純な解決策 (もちろん私の意見では) は、単純に 3 つの異なる ImageView または Button を使用して "タブ" を模倣することです。必要に応じて、「選択されていないタブ」の画像を「選択されたタブ」の画像と入れ替えることができます。
私の知る限り、TabHosts や、さまざまなタブのアクティビティ、フラグメント、またはビューを必要とするその他のソリューション以外に簡単な方法はありません。
これが例です
se01、se02、および se03 が、水平方向の LinearLayout または ScrollView の 3 つのボタンであるとします (より多くのタブをサポートする場合)。したがって、各ボタンに onClickListeners を設定し、クリック時に特定の背景 (タブが選択されていることを示す) に切り替えるようにプログラムできます。それが最も簡単な方法です。これは非常に理解しやすいコード スニペットです。お役に立てれば :-)
//initialize the first button to be 'selected' when the activity is started by a background which is similar to the other buttons but shows the selected button/tab as highlighted.
se01.setBackgroundResource(R.drawable.popup_full_dark2);
lastClicked = (Button) findViewById(R.id.ph_s01);//this keeps a track of the last tab/button pressed
toSe01();// a function which performs the changes to the view with respect to the tab selected
//Listeners
se01.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
if (v.getId() != lastClicked.getId()) {
lastClicked
.setBackgroundResource(R.drawable.popup_bottom_dark);//changes the background to show the tab is selected
v.setBackgroundResource(R.drawable.popup_full_dark2);
lastClicked = se01;
s.startAnimation(new Animation9());
toSe01();
s.scrollTo(0, 0);
}
}
});
se02.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
if (v.getId() != lastClicked.getId()) {
lastClicked
.setBackgroundResource(R.drawable.popup_bottom_dark);
v.setBackgroundResource(R.drawable.popup_full_dark2);
lastClicked = se02;
s.startAnimation(new Animation9());
toSe02();
s.scrollTo(0, 0);
}
}
});
se03.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
if (v.getId() != lastClicked.getId()) {
lastClicked
.setBackgroundResource(R.drawable.popup_bottom_dark);
v.setBackgroundResource(R.drawable.popup_full_dark2);
lastClicked = se03;
s.startAnimation(new Animation9());
toSe03();
s.scrollTo(0, 0);
}
}
});
しばらく前に、タブの変更をリッスンする必要がある同様のプロジェクトがありました。Google の素晴らしい例を次に示します。
public class MyPagerAdapter extends FragmentPagerAdapter
implements TabHost.OnTabChangeListener, ViewPager.OnPageChangeListener {
private final Context mContext;
private final TabHost mTabHost;
private final ViewPager mViewPager;
private final ArrayList<TabInfo> mTabs = new ArrayList<TabInfo>();
private class TabInfo {
@SuppressWarnings("unused")
private final String tag;
private final Class<?> clss;
private final Bundle args;
public TabInfo(String _tag, Class<?> _clss, Bundle _args) {
tag = _tag;
clss = _clss;
args = _args;
}
}
private class DummyFactory implements TabHost.TabContentFactory {
private final Context mContext;
public DummyFactory(Context context) {
mContext = context;
}
public View createTabContent(String tag) {
View v = new View(mContext);
v.setMinimumHeight(0);
v.setMinimumWidth(0);
return v;
}
}
public MyPagerAdapter(FragmentActivity activity, TabHost tabHost, ViewPager viewPager) {
super(activity.getSupportFragmentManager());
mContext = activity;
mTabHost = tabHost;
mViewPager = viewPager;
mTabHost.setOnTabChangedListener(this);
mViewPager.setAdapter(this);
mViewPager.setOnPageChangeListener(this);
}
public void addTab(TabHost.TabSpec tabSpec, Class<?> clss, Bundle args) {
tabSpec.setContent(new DummyFactory(mContext));
String tag = tabSpec.getTag();
TabInfo tab = new TabInfo(tag, clss, args);
mTabs.add(tab);
mTabHost.addTab(tabSpec);
this.notifyDataSetChanged();
}
@Override
public Fragment getItem(int i) {
TabInfo tab = mTabs.get(i);
Fragment fragment = Fragment.instantiate(mContext, tab.clss.getName(), tab.args);
Log.d("DEBUG", "getItem from view pager called returning hash: " + fragment.hashCode());
return fragment;
}
@Override
public int getCount() {
return mTabs.size();
}
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
public void onPageSelected(int position) {
// Unfortunately when TabHost changes the current tab, it kindly
// also takes care of putting focus on it when not in touch mode.
// The jerk.
// This hack tries to prevent this from pulling focus out of our
// ViewPager.
TabWidget widget = mTabHost.getTabWidget();
int oldFocusability = widget.getDescendantFocusability();
widget.setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);
mTabHost.setCurrentTab(position);
widget.setDescendantFocusability(oldFocusability);
}
public void onTabChanged(String tabId) {
int position = mTabHost.getCurrentTab();
mViewPager.setCurrentItem(position);
}
}
ここで関連する部分は、アダプターが実装TabHost.OnTabChangeListener
し、コンストラクターの本体で、それに応じて onTabChangedListener が設定されていることです ( mTabHost.setOnTabChangedListener(this)
)
内部クラスにも気付くでしょうDummyFactory
private class DummyFactory implements TabHost.TabContentFactory {
private final Context mContext;
public DummyFactory(Context context) {
mContext = context;
}
public View createTabContent(String tag) {
View v = new View(mContext);
v.setMinimumHeight(0);
v.setMinimumWidth(0);
return v;
}
}
これは、および0addTab
のコンテンツ ビューを作成するために使用されます。これにより、レイアウトの TabHost の下に実際のコンテンツを追加できます。height
width