Navigation -- TabHost

Navigation -- TabHost

Source: Internet
Author: User

Open the call button on the Android mobile phone, which shows the navigation control. You can click one to display different or identical pages below. Two implementation methods

1. inherited from TabActivitty

The inherited navigation bar can only contain text and has a single style.

Specific implementation:

◆ Main Activity

@ Override protected void onCreate (Bundle savedInstanceState) {super. onCreate (savedInstanceState); // define the navigation TabHost th = getTabHost ();/*** add navigation items to the navigation * Add a label * newTabSpec every addTab time: specify the tag ID to differentiate different tags * setIndicator: Set the tag display information * setContent: the response event when the tag is clicked. This is the page Jump */th. addTab (th. newTabSpec ("tab1 "). setIndicator ("Navigation 1 "). setContent (new Intent (this, Act1.class); th. addTab (th. newTabSpec ("tab2 "). setIndicator ("navigation 2 "). setContent (new Intent (this, Act2.class); th. addTab (th. newTabSpec ("tab3 "). setIndicator ("navigation 3 "). setContent (new Intent (this, Act3.class )));}

◆ When you click navigation, you only need to specify three xml files for the three activities to jump to. These three xml files only add a button.

◆ Result

650) this. width = 650; "src =" http://www.bkjia.com/uploads/allimg/131228/10554G203-0.png "title =" .png "/>

Ii. Custom navigation

1: Create

1) Create an xml file, create a TabHost node, and set its ID.

2) create a TabWidget subnode to set the tag. The ID must be "@ android: id/tabs ". Each tag is determined by the style defined in an xml file. For example, this navigation label may be regarded as an image above and a text below. Such a style can be defined in an xml file.

3) create a FrameLayout subnode to display the content. The Id must be "@ android: id/tabcontent ". There are several labels, and FrameLayout has several layout views. For example, if there is a single navigation label, there will be three RelativeLayout. Here is just an example. You can also set your own style for other la S.

2: specific implementation

1) selftabhost. xml file of TabHost

<? Xml version = "1.0" encoding = "UTF-8"?> <! -- Note that there is no layout, and there is a TabHost --> <TabHost xmlns: android =" http://schemas.android.com/apk/res/android "Android: id =" @ + id/tabhost "android: layout_width =" fill_parent "android: layout_height =" fill_parent "> <LinearLayout android: layout_width =" fill_parent "android: layout_height = "fill_parent" android: orientation = "vertical" android: gravity = "center"> <! -- Navigation tag --> <TabWidget android: id = "@ android: id/tabs" android: layout_width = "fill_parent" android: layout_height = "wrap_content"> </TabWidget> <! -- Used to display the content --> <FrameLayout android: id = "@ android: id/tabcontent" android: layout_width = "fill_parent" android: layout_height = "fill_parent" android: gravity = "center"> <! -- There are several RelativeLayout interfaces to display --> <RelativeLayout android: id = "@ + id/daohang1" android: layout_width = "match_parent" android: layout_height = "match_parent" android: gravity = "center"> <! -- Defines the style in the interface. Here is a Button --> <Button android: id = "@ + id/button1" android: layout_width = "wrap_content" android: layout_height = "wrap_content" android: text = "Navigation 1 corresponding to button 1"/> </RelativeLayout> <RelativeLayout android: id = "@ + id/daohang2" android: layout_width = "match_parent" android: layout_height = "match_parent" android: gravity = "center"> <Button android: id = "@ + id/button1" android: layout_width = "wrap_content" android: layout_height = "wrap_content" android: text = "navigation 2 corresponds to button 2"/> </RelativeLayout> <RelativeLayout android: id = "@ + id/daohang3" android: layout_width = "match_parent" android: layout_height = "match_parent" android: gravity = "center"> <Button android: id = "@ + id/button1" android: layout_width = "wrap_content" android: layout_height = "wrap_content" android: text = "navigation 3 button 3 on the corresponding interface"/> </RelativeLayout> </FrameLayout> </LinearLayout> </TabHost>

2) style xml file of the navigation tag

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:orientation="vertical"    android:gravity="center"    >    <ImageView        android:id="@+id/imageView1"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:src="@drawable/ic_launcher" />    <TextView        android:id="@+id/textView1"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="TextView" />                                                                            </LinearLayout>

3) Main Activity: SelfTabHost

Public class SelfTabHost extends Activity {@ Override protected void onCreate (Bundle savedInstanceState) {super. onCreate (savedInstanceState); // load the custom navigation view setContentView (R. layout. selftabhost); // defines the navigation TabHost th = (TabHost) findViewById (R. id. tabhost); // initialize navigation th. setup (); // define the binding of each navigation label to its corresponding display content, and define the event triggered upon clicking to jump to the page.) TabSpec ts1 = th. newTabSpec ("tab1"); // defines the first tag. The Id is tab1 ts1.setIndicator (createTabView (th, "Navigation 1", R. drawable. ic_launcher); // you can specify the binding ts1.setContent (R. id. daohang1); // defines the event th triggered when a click is made. addTab (ts1); // Add the label to the navigation bar. TabSpec ts2 = th. newTabSpec ("tab2"); // defines the first tag. The Id is tab2 ts2.setIndicator (createTabView (th, "navigation 2", R. drawable. ic_launcher); // you can specify the binding ts2.setContent (R. id. daohang2); // defines the event th triggered when a click is made. addTab (ts2); // Add the tab to the navigation bar. TabSpec ts3 = th. newTabSpec ("tab3"); // defines the first tag. The Id is tab3 ts3.setIndicator (createTabView (th, "navigation 3", R. drawable. ic_launcher); // you can specify the binding ts3.setContent (R. id. daohang3); // defines the event th triggered when a click is made. addTab (ts3); // Add the tag to the navigation} // compile a method to return the binding public View createTabView (TabHost th, String title, int image) {// View view corresponding to the loaded tag = LayoutInflater. from (this ). inflate (R. layout. cell, null, false); // get the control and set the property TextView txtView = (TextView) view. findViewById (R. id. textView1); txtView. setText (title); // get the control and set the property ImageView imageView = (ImageView) view. findViewById (R. id. imageView1); imageView. setBackgroundResource (image); // return view ;}}

4) Results

650) this. width = 650; "src =" http://www.bkjia.com/uploads/allimg/131228/10554J256-1.png "title =" .png "/>

Navigation to guide you forward... Come On 650) this. width = 650; "src =" http://www.bkjia.com/uploads/allimg/131228/10554KO7-2.gif "/>

This article is from the "Schindler" blog, please be sure to keep this source http://cinderella7.blog.51cto.com/7607653/1282212

Large-Scale Price Reduction
  • 59% Max. and 23% Avg.
  • Price Reduction for Core Products
  • Price Reduction in Multiple Regions
undefined. /
Connect with us on Discord
  • Secure, anonymous group chat without disturbance
  • Stay updated on campaigns, new products, and more
  • Support for all your questions
undefined. /
Free Tier
  • Start free from ECS to Big Data
  • Get Started in 3 Simple Steps
  • Try ECS t5 1C1G
undefined. /

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.