Take Slidemenu to achieve the effect sidebar:
Room
Setcontentview is the layout that sets the main background
Setbehindcontentview is to set the layout of the left menu
Setsecondarymenu is to set the layout on the right
Setshadowwidth is to set the width of the shadow
Setbehindwidth is set valid pull-out width
SetMode is set to open the menu on both left and right
Use Viewpagerindictor to implement sliding navigation bar and page layout
The use of tabpageindicator to do sliding navigation bar
Viewpager do a sliding layout
The first thing to do is to set the navigation bar style
<style name= "Homeuptheme" parent= "Android:Theme.Holo.Light.DarkActionBar" > <item name= "vpitabpagei Ndicatorstyle "> @style/customtabpageindicator</item> </style> <style name=" Customtabpageindic Ator "parent=" Widget.tabpageindicator "> <item name=" android:dividerpadding ">10dp</item> <i TEM name= "Android:paddingleft" >20dp</item> <item name= "Android:paddingright" >20dp</item> <item name= "Android:paddingtop" >10dp</item> <item name= "Android:paddingbottom" >10dp</item> ; <item name= "Android:textsize" >10pt</item> <item name= "android:textappearance" > @style/ customtabpageindicator.text</item> <item name= "Android:textcolor" > #000000 </item> <item Name= "Android:fadingedge" >horizontal</item> <item name= "Android:fadingedgelength" >8dp</item > <item name= "AndroiD:background "> @drawable/selectitle</item> <item name=" android:gravity ">center</item> </s Tyle>
In the Code
Viewpager inside can be set to load
Layout adapter Pageradapter overriding Instantiateitem method
Fragment adapter Fragmentstatepageradapter overriding method of Fragment GetItem ()
And finally connect the two.
Indicatorview.setviewpager (pager);
Full code:
public class Mainact extends slidingactivity {slidingmenu slidingmenu; Tabpageindicator Indicatorview; Viewpager Pager; @Overridepublic void OnCreate (Bundle savedinstancestate) {//TODO auto-generated method Stubsuper.oncreate (savedinstancestate); Setbehindcontentview (R.layout.slide_behind); SetContentView ( R.layout.slide_main); slidingmenu = Getslidingmenu (); Slidingmenu.setbehindoffset (); Slidingmenu.setbehindwidth ( Slidingmenu.setsecondarymenu (R.layout.slide_second);//Slidingmenu.settouchmodeabove (SlidingMenu.LEFT_ right); Slidingmenu.setshadowwidth (+); Slidingmenu.setmode (slidingmenu.left_right); Indicatorview = ( Tabpageindicator) Findviewbyid (r.id.indicator);p ager = (Viewpager) Findviewbyid (R.id.pager);p Ager.setadapter (new Myadapter ());p Ager.setoffscreenpagelimit (8); Indicatorview.setontabreselectedlistener (new Ontabreselectedlistener () {@Overridepublic void ontabreselected (int position) {Toast.maketext (getapplicationcontext (), Position + "",. Show ();//TODO auto-generated method Stubpager.setcurrentitem (position);}}); Pager.setcurrentitem (0); Indicatorview.setviewpager (pager); indicatorview.setclickable (true);} Class Myadapter extends Pageradapter {@Overridepublic int getcount () {//TODO auto-generated method Stubreturn 8;} @Overridepublic charsequence getpagetitle (int position) {//TODO auto-generated method Stubreturn "--" + position + "--";} @Overridepublic void Destroyitem (ViewGroup container, int position, object object) {//TODO auto-generated method Stub (Vi Ewpager) container). Removeviewat (position); Super.destroyitem (container, Position, object);} @Overridepublic boolean isviewfromobject (View arg0, Object arg1) {//TODO auto-generated method Stubreturn arg0 = arg1;} @Overridepublic Object Instantiateitem (viewgroup container, int position) {//TODO auto-generated method Stubimageview im Ageview = new ImageView (Getapplicationcontext ()); Imageview.setimagebitmap (Bitmapfactory.decoderesource ( Getresources (), r.drawable.flower)); Container.addview (imageView); return IMageview;//return Super.instantiateitem (container, position);}}
Copyright notice: This article Bo Master original article. Blog, not reproduced without consent.
"Andord true" slidemenu+viewpagerindictor double sliding sidebar + sliding navigation bar