总结
本文讲解了我对Android开发现状的一些看法,也许有些人会觉得我的观点不对,但我认为没有绝对的对与错,一切交给时间去证明吧!愿与各位坚守的同胞们互相学习,共同进步!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
在Activity中要获取FragmentManager需要调用Activity的getFragmentManager()方法。
向FragmentManager中添加Fragment:
可以使用FragmentTransaction来实现,FragmentTransaction可以通过FragmentManager.beginTransaction()来获取,使用add(int containerViewId, Fragment fragment, String tag)方法来添加一个Fragment,remove(Fragment fragment)方法来移除掉一个Fragment。
通过show(Fragment fragment,String tag)和hide(Fragment fragment,String tag)制FragmentManager所管理的Fragment的显示状态,当hide时Fragment不显示,处于暂停状态;show时处于运行状态,允许用户交互。示例代码:
private void selectTab(int i) {
//获取FragmentManager对象
FragmentManager manager = getSupportFragmentManager();
//获取FragmentTransaction对象
FragmentTransaction transaction = manager.beginTransaction();
//先隐藏所有的Fragment
hideFragments(transaction);
switch (i) {
//当选中点击的是第一页的Tab时
case 0:
//设置第一页的ImageButton为绿色
mImg1.setImageResource(R.mipmap.icon1);
//如果第一页对应的Fragment没有实例化,则进行实例化,并显示出来
if (mFrag1 == null) {
mFrag1 = new Fragment();
transaction.add(R.id.id_content, mFrag1);
} else {
//如果第一页对应的Fragment已经实例化,则直接显示出来
transaction.show(mFrag1);
}
break;
case 1:
mImg2.setImageResource(R.mipmap.icon1);
if (mFrag2 == null) {
mFrag2 = new pageFragment2();
transaction.add(R.id.id_content, mFrag2);
} else {
transaction.show(mFrag2);
}
break;
case 2:
mImg3.setImageResource(R.mipmap.icon1);
if (mFrag3 == null) {
mFrag3 = new pageFragment3();
transaction.add(R.id.id_content, mFrag3);
} else {
transaction.show(mFrag3);
}
break;
case 3:
mImg4.setImageResource(R.mipmap.icon1);
if (mFrag4 == null) {
mFrag4 = new Fragment();
transaction.add(R.id.id_content, mFrag4);
} else {
transaction.show(mFrag4);
}
break;
}
//不要忘记提交事务
transaction.commit();
}
//将四个的Fragment隐藏
private void hideFragments(FragmentTransaction transaction) {
if (mFrag1 != null) {
transaction.hide(mFrag1);
}
if (mFrag2 != null) {
transaction.hide(mFrag2);
}
if (mFrag3 != null) {
transaction.hide(mFrag3);
}
if (mFrag4 != null) {
transaction.hide(mFrag4);
}
}
在本例子中,就是使用FragmentManager来管理多个Fragment,通过show()方法显示当前所在的Fragment页面,hide方法将其他页面隐藏。
MainActivity.class :核心Activity
ass MainActivity extends FragmentActivity implements OnClickListener {
//声明四个Tab的布局文件
private LinearLayout mTab1;
private LinearLayout mTab2;
private LinearLayout mTab3;
private LinearLayout mTab4;
//声明四个Tab的ImageButton
private ImageButton mImg1;
private ImageButton mImg2;
private ImageButton mImg3;
private ImageButton mImg4;
//声明四个Tab分别对应的Fragment
private Fragment mFrag1;
private Fragment mFrag2;
private Fragment mFrag3;
private Fragment mFrag4;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main);
initViews();//初始化控件
initEvents();//初始化事件
selectTab(0);//默认选中第一个Tab
}
private void initEvents() {
//初始化四个Tab的点击事件
mTab1.setOnClickListener(this);
mTab2.setOnClickListener(this);
mTab3.setOnClickListener(this);
mTab4.setOnClickListener(this);
}
private void initViews() {
//初始化四个Tab的布局文件
mTab1 = (LinearLayout) findViewById(R.id.id_tab1);
mTab2 = (LinearLayout) findViewById(R.id.id_tab2);
mTab3 = (LinearLayout) findViewById(R.id.id_tab3);
mTab4 = (LinearLayout) findViewById(R.id.id_tab4);
//初始化四个ImageButton
mImg1 = (ImageButton) findViewById(R.id.id_tab_img1);
mImg2 = (ImageButton) findViewById(R.id.id_tab_img2);
mImg3 = (ImageButton) findViewById(R.id.id_tab_img3);
mImg4 = (ImageButton) findViewById(R.id.id_tab_img4);
}
//处理Tab的点击事件
@Override
public void onClick(View v) {
resetImgs(); //先将四个ImageButton置为灰色
switch (v.getId()) {
case R.id.id_tab1:
selectTab(0);
break;
case R.id.id_tab2:
selectTab(1);
break;
case R.id.id_tab3:
selectTab(2);
break;
case R.id.id_tab4:
selectTab(3);
break;
}
}
//进行选中Tab的处理
private void selectTab(int i) {
//获取FragmentManager对象
FragmentManager manager = getSupportFragmentManager();
//获取FragmentTransaction对象
FragmentTransaction transaction = manager.beginTransaction();
//先隐藏所有的Fragment
hideFragments(transaction);
switch (i) {
//当选中点击的是第一页的Tab时
case 0:
//设置第一页的ImageButton为绿色
mImg1.setImageResource(R.mipmap.icon1);
//如果第一页对应的Fragment没有实例化,则进行实例化,并显示出来
if (mFrag1 == null) {
mFrag1 = new Fragment();
transaction.add(R.id.id_content, mFrag1);
} else {
//如果第一页对应的Fragment已经实例化,则直接显示出来
transaction.show(mFrag1);
}
break;
case 1:
mImg2.setImageResource(R.mipmap.icon1);
if (mFrag2 == null) {
mFrag2 = new pageFragment2();
transaction.add(R.id.id_content, mFrag2);
} else {
transaction.show(mFrag2);
}
break;
case 2:
mImg3.setImageResource(R.mipmap.icon1);
if (mFrag3 == null) {
mFrag3 = new pageFragment3();
transaction.add(R.id.id_content, mFrag3);
} else {
transaction.show(mFrag3);
}
break;
case 3:
mImg4.setImageResource(R.mipmap.icon1);
if (mFrag4 == null) {
mFrag4 = new Fragment();
transaction.add(R.id.id_content, mFrag4);
} else {
transaction.show(mFrag4);
}
break;
}
//不要忘记提交事务
transaction.commit();
}
//将四个的Fragment隐藏
private void hideFragments(FragmentTransaction transaction) {
if (mFrag1 != null) {
transaction.hide(mFrag1);
}
if (mFrag2 != null) {
transaction.hide(mFrag2);
}
if (mFrag3 != null) {
transaction.hide(mFrag3);
}
if (mFrag4 != null) {
transaction.hide(mFrag4);
}
}
//将四个ImageButton置为灰色
private void resetImgs() {
mImg1.setImageResource(R.mipmap.icon2);
mImg2.setImageResource(R.mipmap.icon2);
mImg3.setImageResource(R.mipmap.icon2);
mImg4.setImageResource(R.mipmap.icon2);
}
}
底部按钮颜色变化是使用两形状一样张颜色不一样图片来回切换实现的。将当前显示的页面对应按钮设置成绿色图片。其他设置成灰色。
四个页面对应的Fragment
pageFragment1,pageFragment2,pageFragment3.class ,pageFragment4.class
lic class pageFragment1 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.tab1, container, false);
return view;
}
}
class pageFragment2 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.tab2, container, false);
TextView txt = (TextView) view.findViewById(R.id.txt2);
txt.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Log.d(“dd”,“dddd”);
Toast.makeText(getActivity(), “当前页面:2”, Toast.LENGTH_SHORT).show();
}
});
return view;
}
}
public class pageFragment3 extends Fragment {
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.tab3, container, false);
return view;
}
}
public class pageFragment4 extends Fragment {
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.tab4, container, false);
return view;
}
}
布局文件:
activity_main.xml
<LinearLayout
xmlns:android=“http://schemas.android.com/apk/res/android”
android:orientation=“vertical”
android:layout_width=“match_parent”
android:layout_height=“match_parent”>
<FrameLayout
android:id=“@+id/id_content”
android:layout_width=“match_parent”
android:layout_height=“0dp”
android:layout_weight=“1”>
底部导航栏布局:
<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”
android:layout_width=“match_parent”
android:layout_height=“55dp”
android:gravity=“center”
android:orientation=“horizontal”>
<LinearLayout
android:layout_width=“0dp”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:id=“@+id/id_tab1”
android:gravity=“center”
android:orientation=“vertical”>
<ImageButton
android:id=“@+id/id_tab_img1”
android:clickable=“false”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:src=“@mipmap/icon1”
android:background=“#00000000”/>
<TextView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:textColor=“#A6A6A6”
android:text=“页面1”/>
<LinearLayout
android:id=“@+id/id_tab2”
android:layout_width=“0dp”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:gravity=“center”
android:orientation=“vertical”>
<ImageButton
android:id=“@+id/id_tab_img2”
android:clickable=“false”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:src=“@mipmap/icon2”
android:background=“#00000000”/>
<TextView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:textColor=“#A6A6A6”
android:text=“页面2”/>
<LinearLayout
android:id=“@+id/id_tab3”
android:layout_width=“0dp”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:gravity=“center”
android:orientation=“vertical”>
<ImageButton
android:id=“@+id/id_tab_img3”
android:clickable=“false”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:src=“@mipmap/icon2”
android:background=“#00000000”/>
<TextView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:textColor=“#A6A6A6”
android:text=“页面3”/>
<LinearLayout
android:id=“@+id/id_tab4”
android:layout_width=“0dp”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:gravity=“center”
android:orientation=“vertical”>
<ImageButton
android:id=“@+id/id_tab_img4”
android:clickable=“false”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:src=“@mipmap/icon2”
android:background=“#00000000”/>
<TextView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:textColor=“#A6A6A6”
android:text=“页面4”/>
Fragment对应布局
四个都一样:
<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”
android:orientation=“vertical”
android:layout_width=“match_parent”
android:layout_height=“match_parent”>
<TextView android:id=“@+id/txt1”
android:layout_width=“match_parent”
android:layout_height=“match_parent”
android:gravity=“center”
android:textSize=“30sp”
android:background=“@drawable/xiaomai1”
/>
style文件:
=============================================================================
使用Fragment有个局限,切换页面的方式只能通过点击底部的导航栏按钮切换,在平时的手机应用使用中也经常可以见到直接左右滑动页面就可以切换页面,而且看起来更加方便,所以下一种方式就是使用ViewPager来实现可以对页面滑动切换。
ViewPager简介
ViewPager是android扩展包androidX包中的类,旧版的是在v4包中,ViewPager就是一个简单的页面切换组件,可以往里面填充多个View,然后可以左右滑动,从而切换不同的View。ViewPager类直接继承了ViewGroup类,所以它是一个容器类,可以在其中添加其他的view类。和ListView,GridView一样,也需要一个Adapter(适配器)将View和ViewPager进行绑定,而ViewPager则有一个特定的Adapter——PagerAdapter。
PagerAdapter简介
PagerAdapter需要重写下面的四个方法:
这只是官方建议,实际上只需重写getCount()和isViewFromObject()就可以了
getCount():获得viewpager中有多少个view
destroyItem():移除一个给定位置的页面。适配器有责任从容器中删除这个视图。这是为了确保finishUpdate(viewGroup)返回时视图能够被移除。
①将给定位置的view添加到ViewGroup(容器)中,创建并显示出来。
②返回一个代表新增页面的Object(key),通常都是直接返回view本身就可以了。
判断instantiateItem(ViewGroup, int)函数所返回来的Key与一个页面视图是否是代表的同一个视图(即它俩是否是对应的,对应的表示同一个View),通常直接写return view == object!
以实现代码中的PagerAdapter为示例:
//初始化ViewPager的适配器
mAdpater = new PagerAdapter() {
//放回页面数量
@Override
public int getCount() {
return mTabs.size();
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
View view = mTabs.get(position);
container.addView(view);
return view;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
// super.destroyItem(container, position, object);
container.removeView(mTabs.get(position));
}
};
//设置ViewPager的适配器
mViewpager.setAdapter(mAdpater);
核心:MainActivity.class
public class MainActivity extends Activity implements OnClickListener {
//声明ViewPager
private ViewPager mViewpager;
//声明四个Tab
private Intent mTab1;
private Intent mTab2;
private Intent mTab3;
private Intent mTab4;
//声明四个ImageButton
private ImageButton mImg1;
private ImageButton mImg2;
private ImageButton mImg3;
private ImageButton mImg4;
//声明ViewPager的适配器
private PagerAdapter mAdpater;
//用于装载四个Tab的List
private List mTabs = new ArrayList();
private LocalActivityManager manager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//去掉TitleBar
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main);
//初始化控件
mViewpager = (ViewPager) findViewById(R.id.id_viewpager);
manager = new LocalActivityManager(this, true);
manager.dispatchCreate(savedInstanceState);
mTab1 = new Intent(MainActivity.this, pageActivity1.class);
View tab01 = manager.startActivity(“view1”, mTab1).getDecorView();
mTab2 = new Intent(MainActivity.this, pageActivity2.class);
View tab02 = manager.startActivity(“view2”, mTab2).getDecorView();
mTab3 = new Intent(MainActivity.this, pageActivity3.class);
View tab03 = manager.startActivity(“view3”, mTab3).getDecorView();
mTab4 = new Intent(MainActivity.this, pageActivity4.class);
View tab04 = manager.startActivity(“view4”, mTab4).getDecorView();
mImg1 = (ImageButton) findViewById(R.id.id_tab_img1);
mImg2 = (ImageButton) findViewById(R.id.id_tab_img2);
mImg3 = (ImageButton) findViewById(R.id.id_tab_img3);
mImg4 = (ImageButton) findViewById(R.id.id_tab_img4);
//获取到四个Tab
LayoutInflater inflater = LayoutInflater.from(this);
View tab1 = inflater.inflate(R.layout.tab1, null);
View tab2 = inflater.inflate(R.layout.tab2, null);
View tab3 = inflater.inflate(R.layout.tab3, null);
View tab4 = inflater.inflate(R.layout.tab4, null);
//将四个Tab添加到集合中
mTabs.add(tab01);
mTabs.add(tab02);
mTabs.add(tab03);
mTabs.add(tab04);
initDatas();//初始化数据
initEvents();//初始化事件
}
private void initEvents() {
//设置四个Tab的点击事件
mImg1.setOnClickListener(this);
mImg2.setOnClickListener(this);
mImg3.setOnClickListener(this);
mImg4.setOnClickListener(this);
//添加ViewPager的切换Tab的监听事件
mViewpager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
//获取ViewPager的当前Tab
int currentItem = mViewpager.getCurrentItem();
//将所以的ImageButton设置成灰色
resetImgs();
//将当前Tab对应的ImageButton设置成绿色
switch (currentItem) {
case 0:
mImg1.setImageResource(R.mipmap.icon1);
break;
case 1:
mImg2.setImageResource(R.mipmap.icon1);
break;
case 2:
mImg3.setImageResource(R.mipmap.icon1);
break;
case 3:
mImg4.setImageResource(R.mipmap.icon1);
break;
}
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
}
private void initDatas() {
//初始化ViewPager的适配器
最后
我见过很多技术leader在面试的时候,遇到处于迷茫期的大龄程序员,比面试官年龄都大。这些人有一些共同特征:可能工作了5、6年,还是每天重复给业务部门写代码,工作内容的重复性比较高,没有什么技术含量的工作。问到这些人的职业规划时,他们也没有太多想法。
其实30岁到40岁是一个人职业发展的黄金阶段,一定要在业务范围内的扩张,技术广度和深度提升上有自己的计划,才有助于在职业发展上有持续的发展路径,而不至于停滞不前。
不断奔跑,你就知道学习的意义所在!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
ion, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
//获取ViewPager的当前Tab
int currentItem = mViewpager.getCurrentItem();
//将所以的ImageButton设置成灰色
resetImgs();
//将当前Tab对应的ImageButton设置成绿色
switch (currentItem) {
case 0:
mImg1.setImageResource(R.mipmap.icon1);
break;
case 1:
mImg2.setImageResource(R.mipmap.icon1);
break;
case 2:
mImg3.setImageResource(R.mipmap.icon1);
break;
case 3:
mImg4.setImageResource(R.mipmap.icon1);
break;
}
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
}
private void initDatas() {
//初始化ViewPager的适配器
最后
我见过很多技术leader在面试的时候,遇到处于迷茫期的大龄程序员,比面试官年龄都大。这些人有一些共同特征:可能工作了5、6年,还是每天重复给业务部门写代码,工作内容的重复性比较高,没有什么技术含量的工作。问到这些人的职业规划时,他们也没有太多想法。
其实30岁到40岁是一个人职业发展的黄金阶段,一定要在业务范围内的扩张,技术广度和深度提升上有自己的计划,才有助于在职业发展上有持续的发展路径,而不至于停滞不前。
不断奔跑,你就知道学习的意义所在!
[外链图片转存中…(img-RaPTkJa1-1715658160115)]
[外链图片转存中…(img-NOPcRwkw-1715658160116)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!