日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

android 顶部标签切换,Android实现底部切换标签

發布時間:2024/7/19 Android 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 android 顶部标签切换,Android实现底部切换标签 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文實例為大家分享了Android實現底部切換標簽的具體代碼,供大家參考,具體內容如下

實現底部通用切換標簽 ,嵌套Fragment,方便自定義布局

自定義控件:

widget_tab_view.xml

android:layout_width="match_parent"

android:layout_height="match_parent">

android:id="@+id/tab_image"

android:layout_width="20dp"

android:layout_height="20dp" />

android:id="@+id/tab_label"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:textColor="#666666"

android:textSize="12sp" />

定義單個標簽

public class TabView extends LinearLayout {

private ImageView mTabImage;

private TextView mTabLable;

public TabView(Context context) {

super(context);

initView(context);

}

public TabView(Context context, @Nullable AttributeSet attrs) {

super(context, attrs);

initView(context);

}

public TabView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

initView(context);

}

private void initView(Context context) {

setOrientation(VERTICAL);

setGravity(Gravity.CENTER);

LayoutInflater.from(context).inflate(R.layout.widget_tab_view, this, true);

mTabImage = (ImageView) findViewById(R.id.tab_image);

mTabLable = (TextView) findViewById(R.id.tab_label);

}

public void initData(TabItem tabItem) {

mTabImage.setImageResource(tabItem.imageResId);

mTabLable.setText(tabItem.lableResId);

}

}

定義單個標簽的entity

public class TabItem {

public int imageResId;

public int lableResId;

public Class extends Fragment> tagFragmentClz;

public TabItem(int imageResId, int lableResId) {

this.imageResId = imageResId;

this.lableResId = lableResId;

}

public TabItem(int imageResId, int lableResId, Class extends Fragment> tagFragmentClz) {

this.imageResId = imageResId;

this.lableResId = lableResId;

this.tagFragmentClz = tagFragmentClz;

}

}

定義底部切換標簽控件

public class BottomTabLayout extends LinearLayout implements View.OnClickListener {

private ArrayList tabs;

private OnTabClickListener listener;

private int tabCount;

private View selectedView;

public BottomTabLayout(Context context) {

super(context);

initView();

}

public BottomTabLayout(Context context, @Nullable AttributeSet attrs) {

super(context, attrs);

initView();

}

public BottomTabLayout(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

initView();

}

private void initView() {

setOrientation(HORIZONTAL);

}

public void setCurrentTab(int i) {

if (i < tabCount && i >= 0) {

View view = getChildAt(i);

onClick(view);

}

}

public void initData(ArrayList tabs, OnTabClickListener listener) {

this.tabs = tabs;

this.listener = listener;

LayoutParams params = new LayoutParams(0, ViewGroup.LayoutParams.MATCH_PARENT);

params.weight = 1;

params.gravity = Gravity.CENTER;

if (tabs != null && tabs.size() > 0) {

tabCount = tabs.size();

TabView mTabView = null;

for (int i = 0, len = tabs.size(); i < len; i++) {

mTabView = new TabView(getContext());

mTabView.setTag(tabs.get(i));

mTabView.initData(tabs.get(i));

mTabView.setOnClickListener(this);

addView(mTabView, params);

}

} else {

throw new IllegalArgumentException("tabs can not be empty");

}

}

@Override

public void onClick(View view) {

if (selectedView != view) {

listener.onTabClick((TabItem) view.getTag());

view.setSelected(true);

if (selectedView != null) {

selectedView.setSelected(false);

}

selectedView = view;

}

}

public interface OnTabClickListener {

void onTabClick(TabItem tabItem);

}

}

Activity

public class MainActivity extends AppCompatActivity implements BottomTabLayout.OnTabClickListener {

private BottomTabLayout tab_layout;

private ArrayList tabs;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

setTitle("底部切換標簽");

tab_layout = (BottomTabLayout) findViewById(R.id.tab_layout);

initBottomTab();

tab_layout.setCurrentTab(0);

}

private void initBottomTab() {

tabs = new ArrayList<>();

tabs.add(new TabItem(R.drawable.selector_tab_msg, R.string.wechat, OneFragment.class));

tabs.add(new TabItem(R.drawable.selector_tab_contact, R.string.contacts, TwoFragment.class));

tabs.add(new TabItem(R.drawable.selector_tab_moments, R.string.discover, ThreeFragment.class));

tabs.add(new TabItem(R.drawable.selector_tab_profile, R.string.me, FourFragment.class));

tab_layout.initData(tabs, this);

}

private Fragment lastFragment;

@Override

public void onTabClick(TabItem tabItem) {

try {

Fragment tmpFragment = getSupportFragmentManager().findFragmentByTag(tabItem.tagFragmentClz.getSimpleName());

FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();

if (tmpFragment == null) {

tmpFragment = tabItem.tagFragmentClz.newInstance();

transaction.add(R.id.fl_container, tmpFragment, tabItem.tagFragmentClz.getSimpleName());

if (lastFragment != null) {

transaction.hide(lastFragment);

}

transaction.commitAllowingStateLoss();

} else {

transaction.show(tmpFragment);

if (lastFragment != null) {

transaction.hide(lastFragment);

}

transaction.commitAllowingStateLoss();

}

lastFragment = tmpFragment;

} catch (Exception e) {

e.printStackTrace();

}

}

}

布局文件

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"

android:orientation="vertical"

tools:context="com.sample.bottomtab.MainActivity">

android:id="@+id/fl_container"

android:layout_width="match_parent"

android:layout_height="0dp"

android:layout_weight="1"

android:background="#ffffff" />

android:layout_width="match_parent"

android:layout_height="1dp"

android:background="#dcdcdc" />

android:id="@+id/tab_layout"

android:layout_width="match_parent"

android:layout_height="48dp"

android:background="#ffffff" />

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

總結

以上是生活随笔為你收集整理的android 顶部标签切换,Android实现底部切换标签的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。