एंड्रॉइड न्यू बॉटम नैविगेशन बार या बॉटमवेशन व्यू


133

देखा नई गाइडलाइन सामने आई है, और google photosनवीनतम ऐप में उपयोग की गई है । नए बॉटम नेविगेशन बार का उपयोग करने का कोई विचार नहीं है। नए समर्थन के माध्यम से देखें, कोई लीड नहीं मिली।

यहाँ छवि विवरण दर्ज करें

कोई आधिकारिक नमूना नहीं मिल सकता है।

नए बॉटम बार का उपयोग कैसे करें? कोई कस्टमाइज़ नहीं करना चाहते हैं।



आप मेरे उत्तर पर एक नज़र डाल सकते हैं: stackoverflow.com/a/44967021/2412582
प्रशांत

जवाबों:


175

मुझे लगता है कि आप इसके लिए देख रहे होंगे।

आरंभ करने के लिए यहां एक त्वरित स्निपेट है:

public class MainActivity extends AppCompatActivity {
    private BottomBar mBottomBar;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        // Notice how you don't use the setContentView method here! Just
        // pass your layout to bottom bar, it will be taken care of.
        // Everything will be just like you're used to.
        mBottomBar = BottomBar.bind(this, R.layout.activity_main,
                savedInstanceState);

        mBottomBar.setItems(
                new BottomBarTab(R.drawable.ic_recents, "Recents"),
                new BottomBarTab(R.drawable.ic_favorites, "Favorites"),
                new BottomBarTab(R.drawable.ic_nearby, "Nearby"),
                new BottomBarTab(R.drawable.ic_friends, "Friends")
        );

        mBottomBar.setOnItemSelectedListener(new OnTabSelectedListener() {
            @Override
            public void onItemSelected(final int position) {
                // the user selected a new tab
            }
        });
    }

    @Override
    protected void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        mBottomBar.onSaveInstanceState(outState);
    }
}

यहाँ संदर्भ लिंक है।

https://github.com/roughike/BottomBar

EDIT नई विज्ञप्ति।

नीचे का नेविगेशन दृश्य कुछ समय के लिए सामग्री डिजाइन दिशानिर्देशों में रहा है, लेकिन हमारे लिए इसे अपने ऐप्स में लागू करना आसान नहीं है। कुछ अनुप्रयोगों ने अपने स्वयं के समाधान का निर्माण किया है, जबकि अन्य लोगों ने काम पाने के लिए तीसरे पक्ष के ओपन-सोर्स पुस्तकालयों पर भरोसा किया है। अब डिज़ाइन सपोर्ट लाइब्रेरी इस नीचे नेविगेशन बार के जोड़ को देख रही है, आइए एक डुबकी लें कि हम इसका उपयोग कैसे कर सकते हैं!

कैसे इस्तेमाल करे ?

शुरू करने के लिए हमें अपनी निर्भरता को अपडेट करने की आवश्यकता है!

compile com.android.support:design:25.0.0

डिजाइन xml।

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <!-- Content Container -->

    <android.support.design.widget.BottomNavigationView
        android:id="@+id/bottom_navigation"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        app:itemBackground="@color/colorPrimary"
        app:itemIconTint="@color/white"
        app:itemTextColor="@color/white"
        app:menu="@menu/bottom_navigation_main" />

</RelativeLayout>

अपनी आवश्यकता के अनुसार मेनू बनाएं।

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
    <item
        android:id="@+id/action_favorites"
        android:enabled="true"
        android:icon="@drawable/ic_favorite_white_24dp"
        android:title="@string/text_favorites"
        app:showAsAction="ifRoom" />
    <item
        android:id="@+id/action_schedules"
        android:enabled="true"
        android:icon="@drawable/ic_access_time_white_24dp"
        android:title="@string/text_schedules"
        app:showAsAction="ifRoom" />
    <item
        android:id="@+id/action_music"
        android:enabled="true"
        android:icon="@drawable/ic_audiotrack_white_24dp"
        android:title="@string/text_music"
        app:showAsAction="ifRoom" />
</menu>

विकलांग / विकलांग राज्यों को संभालना। चयनकर्ता फ़ाइल बनाएँ।

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
  <item
      android:state_checked="true"
      android:color="@color/colorPrimary" />
  <item
      android:state_checked="false"
      android:color="@color/grey" />
 </selector>

क्लिक इवेंट्स को हैंडल करें।

BottomNavigationView bottomNavigationView = (BottomNavigationView)
                findViewById(R.id.bottom_navigation);

bottomNavigationView.setOnNavigationItemSelectedListener(
        new BottomNavigationView.OnNavigationItemSelectedListener() {
            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem item) {
                switch (item.getItemId()) {
                    case R.id.action_favorites:

                        break;
                    case R.id.action_schedules:

                        break;
                    case R.id.action_music:

                        break;
                }
                return false;
            }
});

संपादित करें: Androidx का उपयोग करके आपको बस नीचे निर्भरता जोड़ने की आवश्यकता है।

implementation 'com.google.android.material:material:1.2.0-alpha01'

ख़ाका

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
             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">
    <com.google.android.material.bottomnavigation.BottomNavigationView
            android:layout_gravity="bottom"
            app:menu="@menu/bottom_navigation_menu"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"/>
</FrameLayout>

यदि आप इसके तरीकों के बारे में अधिक पढ़ना चाहते हैं और यह कैसे काम करता है यह पढ़ें।

निश्चित रूप से यह आपकी मदद करेगा।


नमूना में नीचे पट्टी अभी भी अपने स्वयं के द्वारा अनुकूलित की जाती है, मूल एंड्रॉयड लिब का उपयोग करने का कोई तरीका। मुझे लगा कि यह सपोर्ट लिब में हो सकता है। या अभी तक सार्वजनिक नहीं किया गया है?
zjywill

@zjywill यह अनुकूलित नहीं है, लेकिन यह हमारे ऐप में आधिकारिक बॉटम नेविगेशन बार कार्यक्षमता का उपयोग करने का तरीका है। बस इस कोड की कोशिश करो।
जे राठौड़ आरजे

1
चूंकि एपीआई पूरी तरह से लागू नहीं हुआ है और मुझे रेंडरिंग समस्याओं का सामना करना पड़ा है, इसलिए मैं आपको रद्दी नीचे पट्टी का उपयोग करने का सुझाव नहीं दूंगा। आप चिह्न को रनटाइम पर नहीं बदल सकते हैं, और यह बटन पृष्ठभूमि के लिए मेरे द्वारा निर्धारित रंगों की अनदेखी करता रहा।
अलोन कोगन

कृपया जवाब दें कि मैं इतिहास को कैसे बचा सकता हूं
मितुल गोटी

1
MShiftingMode पर जावा प्रतिबिंब ने मेरी मदद की! मैं नहीं जानता कि वे इस क्षेत्र को उजागर नहीं करके क्या सोच रहे हैं
केले का डोर

48

आपको v25 एंड्रॉइड सपोर्ट लाइब्रेरी से BottomNavigationView का उपयोग करना चाहिए । यह आवेदन के लिए एक मानक नीचे नेविगेशन बार का प्रतिनिधित्व करता है।

यहाँ माध्यम पर एक पोस्ट है जिसमें स्टेप बाय स्टेप गाइड है: https://medium.com/@hitherejoe/exploring-the-android-design-support-library-bottom-navigation-drawer-548de6xe8e0#.9vmiekxze


2
stackoverflow.com/questions/40153888/… हैलो मैक्सिम .. मैंने इसे लागू किया है, लेकिन इसका प्रदर्शन नहीं हो रहा है ..
सागर चावड़ा

@SagarChavada आप इस में देखने के लिए चाहते हो सकता है के बाद
Maksim Turaev

5
@DroidDev वह है क्योंकि बॉटम नेशनव्यू व्यू उसी दिन जारी किया गया था जब यह उत्तर पोस्ट किया गया था। इससे पहले केवल तीसरे पक्ष के समाधान उपलब्ध थे।

क्या आप जानते हैं कि क्या आप एक एडेप्टर के साथ कस्टम दृश्य कर सकते हैं?
राडू

1
@Alan, ऐसा लगता है कि बॉटम नेशनगेशन व्यू सपोर्ट लाइब्रेरी का एक हिस्सा है, जिसमें मिनिमम एपीआई एपीआई 9 है, इसलिए मुझे लगता है कि यह काम करेगा। आप अभी भी इसे 100% सुनिश्चित करने के लिए एमुलेटर पर देख सकते हैं।
मक्सिम तुराएव

17

मेरा मूल उत्तर के साथ निपटा BottomNavigationView, लेकिन अब एक है BottomAppBar। मैंने कार्यान्वयन लिंक के साथ उसके लिए शीर्ष पर एक खंड जोड़ा।

निचला ऐप बार

BottomAppBarएक फ़्लोटिंग एक्शन बटन का समर्थन करता है।

यहाँ छवि विवरण दर्ज करें

से छवि यहाँप्रलेखन और मदद करने के लिए इस ट्यूटोरियल की स्थापना देखें BottomAppBar

नीचे का नेविगेशन दृश्य

निम्न पूर्ण उदाहरण दिखाता है कि प्रश्न में छवि के समान निचला नेविगेशन दृश्य कैसे बनाया जाए। प्रलेखन में निचला नेविगेशन भी देखें ।

यहाँ छवि विवरण दर्ज करें

डिज़ाइन समर्थन लाइब्रेरी जोड़ें

इस लाइन को अन्य सहायता लाइब्रेरी चीजों के बगल में अपने ऐप के बिल्ड.ग्रेड फ़ाइल में जोड़ें ।

implementation 'com.android.support:design:28.0.0'

जो भी वर्तमान है, उसके साथ संस्करण संख्या बदलें।

गतिविधि लेआउट बनाएँ

लेआउट में हमने जो एकमात्र विशेष चीज जोड़ी है, वह है BottomNavigationView। आइकन और पाठ का रंग बदलने के लिए जब इसे क्लिक किया जाता है, तो आप selectorसीधे रंग निर्दिष्ट करने के बजाय उपयोग कर सकते हैं । यह यहाँ सादगी के लिए छोड़ा गया है।

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.design.widget.BottomNavigationView
        android:id="@+id/bottom_navigation"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        app:menu="@menu/bottom_nav_menu"
        app:itemBackground="@color/colorPrimary"
        app:itemIconTint="@android:color/white"
        app:itemTextColor="@android:color/white" />

</RelativeLayout>

ध्यान दें कि हम layout_alignParentBottomवास्तव में इसे सबसे नीचे रखते थे।

मेनू आइटम को परिभाषित करें

नीचे के नेविगेशन दृश्य के लिए ऊपर दी गई xml bottom_nav_menu। यह वह है जो हमारे विचार में प्रत्येक आइटम को परिभाषित करता है। हम इसे अभी बनाएंगे। आपको बस एक एक्शन बार या टूलबार की तरह एक मेनू संसाधन जोड़ना होगा।

bottom_nav_menu.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
      xmlns:app="http://schemas.android.com/apk/res-auto">

    <item
        android:id="@+id/action_recents"
        android:enabled="true"
        android:icon="@drawable/ic_action_recents"
        android:title="Recents"
        app:showAsAction="ifRoom" />

    <item
        android:id="@+id/action_favorites"
        android:enabled="true"
        android:icon="@drawable/ic_action_favorites"
        android:title="Favorites"
        app:showAsAction="ifRoom" />

    <item
        android:id="@+id/action_nearby"
        android:enabled="true"
        android:icon="@drawable/ic_action_nearby"
        android:title="Nearby"
        app:showAsAction="ifRoom" />
</menu>

आपको अपनी परियोजना में उपयुक्त आइकन जोड़ने होंगे। यह बहुत मुश्किल नहीं है यदि आप फ़ाइल> नई> छवि संपत्ति पर जाते हैं और आइकन प्रकार के रूप में एक्शन बार और टैब आइकन चुनें।

एक आइटम चयनित श्रोता जोड़ें

यहां कुछ खास नहीं हो रहा है। हम अपनी गतिविधि के onCreateतरीके में केवल नीचे की ओर नेविगेशन बार में श्रोता जोड़ते हैं ।

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        BottomNavigationView bottomNavigationView = (BottomNavigationView) findViewById(R.id.bottom_navigation);
        bottomNavigationView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem item) {
                switch (item.getItemId()) {
                    case R.id.action_recents:
                        Toast.makeText(MainActivity.this, "Recents", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.action_favorites:
                        Toast.makeText(MainActivity.this, "Favorites", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.action_nearby:
                        Toast.makeText(MainActivity.this, "Nearby", Toast.LENGTH_SHORT).show();
                        break;

                }
                return true;
            }
        });
    }
}

क्या और मदद चाहिये?

मैंने निम्न YouTube वीडियो को देखने का तरीका सीखा। कंप्यूटर की आवाज़ थोड़ी अजीब है, लेकिन प्रदर्शन बहुत स्पष्ट है।


16

आप इसे प्राप्त करने के लिए कस्टम टैब दृश्य के साथ टैब लेआउट का भी उपयोग कर सकते हैं।

custom_tab.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="?attr/selectableItemBackground"
    android:gravity="center"
    android:orientation="vertical"
    android:paddingBottom="10dp"
    android:paddingTop="8dp">

    <ImageView
        android:id="@+id/icon"
        android:layout_width="24dp"
        android:layout_height="24dp"
        android:scaleType="centerInside"
        android:src="@drawable/ic_recents_selector" />

    <TextView
        android:id="@+id/title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:ellipsize="end"
        android:maxLines="1"
        android:textAllCaps="false"
        android:textColor="@color/tab_color"
        android:textSize="12sp"/>
</LinearLayout>

activity_main.xml

<?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.support.v4.view.ViewPager

        android:id="@+id/view_pager"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1" />

    <android.support.design.widget.TabLayout
        android:id="@+id/tab_layout"
        style="@style/AppTabLayout"
        android:layout_width="match_parent"
        android:layout_height="56dp"
        android:background="?attr/colorPrimary" />

</LinearLayout>

MainActivity.java

public class MainActivity extends AppCompatActivity {
    private TabLayout mTabLayout;

    private int[] mTabsIcons = {
            R.drawable.ic_recents_selector,
            R.drawable.ic_favorite_selector,
            R.drawable.ic_place_selector};


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // Setup the viewPager
        ViewPager viewPager = (ViewPager) findViewById(R.id.view_pager);
        MyPagerAdapter pagerAdapter = new MyPagerAdapter(getSupportFragmentManager());
        viewPager.setAdapter(pagerAdapter);

        mTabLayout = (TabLayout) findViewById(R.id.tab_layout);
        mTabLayout.setupWithViewPager(viewPager);

        for (int i = 0; i < mTabLayout.getTabCount(); i++) {
            TabLayout.Tab tab = mTabLayout.getTabAt(i);
            tab.setCustomView(pagerAdapter.getTabView(i));
        }

        mTabLayout.getTabAt(0).getCustomView().setSelected(true);
    }


    private class MyPagerAdapter extends FragmentPagerAdapter {

        public final int PAGE_COUNT = 3;

        private final String[] mTabsTitle = {"Recents", "Favorites", "Nearby"};

        public MyPagerAdapter(FragmentManager fm) {
            super(fm);
        }

        public View getTabView(int position) {
            // Given you have a custom layout in `res/layout/custom_tab.xml` with a TextView and ImageView
            View view = LayoutInflater.from(MainActivity.this).inflate(R.layout.custom_tab, null);
            TextView title = (TextView) view.findViewById(R.id.title);
            title.setText(mTabsTitle[position]);
            ImageView icon = (ImageView) view.findViewById(R.id.icon);
            icon.setImageResource(mTabsIcons[position]);
            return view;
        }

        @Override
        public Fragment getItem(int pos) {
            switch (pos) {

                case 0:
                    return PageFragment.newInstance(1);

                case 1:
                    return PageFragment.newInstance(2);
                case 2:
                    return PageFragment.newInstance(3);

            }
            return null;
        }

        @Override
        public int getCount() {
            return PAGE_COUNT;
        }

        @Override
        public CharSequence getPageTitle(int position) {
            return mTabsTitle[position];
        }
    }

}

पूरा नमूना परियोजना डाउनलोड करें


8
Google डिज़ाइन दिशानिर्देशों के अनुसार, किसी को टैब के बीच स्विच करने के लिए स्वाइपिंग गति का उपयोग नहीं करना चाहिए। google.com/design/spec/compenders/…
कार्ल बी

1
महान होगा यदि आप उस लेखक के लिए एक क्रेडिट डालते हैं जिसने व्यवहार लिखा है :)
निकोला डेस्पोटोस्की

13

डिज़ाइन समर्थन लाइब्रेरी के संस्करण 25.0.0 के बाद Google ने बॉटमवेशन व्यू लॉन्च किया है। लेकिन यह निम्नलिखित सीमाओं के साथ आया:

  1. आप शीर्षक और केंद्र आइकन नहीं निकाल सकते।
  2. आप शीर्षक पाठ का आकार नहीं बदल सकते हैं।
  3. Yo̶u̶ ̶c̶a̶n̶'̶t̶ ̶c̶h̶a̶n̶g̶e̶ ̶t̶h̶e̶ ̶b̶a̶c̶k̶g̶r̶o̶n̶d̶d̶ ̶c̶o̶l̶o̶r̶ ̶i̶i ̶̶̶̶̶̶̶̶̶̶̶̶̶ ̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶ ̶̶̶̶̶̶̶̶̶̶̶ ̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶ एक एक̶̶̶̶̶̶̶̶̶̶̶̶ ̶̶̶̶ ̶̶ ̶̶ ̶̶ ̶̶ ̶̶ ̶̶̶ ̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶̶) बनाने के लिए है के लिए उतना ज़्यादा है।
  4. इसमें एक बॉटनैविगेशन बिहेवियर नहीं है: इसलिए कॉर्डिनेटर लयआउट के माध्यम से एफएबी या स्नैकबेर के साथ कोई एकीकरण नहीं है।
  5. हर menuItem FrameLayout का एक शुद्ध विस्तार है, इसलिए इसका कोई अच्छा सर्कल प्रकट नहीं होता है

तो अधिकतम आप बॉटम नॉनविजिविज़्यू के इस मुट्ठी संस्करण के साथ कर सकते हैं: (किसी भी प्रतिबिंब के बिना या अपने आप से काम को लागू करने के बिना)।

यहाँ छवि विवरण दर्ज करें

तो, अगर आप इनमें से कोई भी चाहते हैं। आप किसी तीसरे भाग की लाइब्रेरी का उपयोग कर सकते हैं जैसे रफाइक / बॉटबर या अपने आप से काम को लागू करना।


4
बस रिकॉर्ड के लिए, आप पृष्ठभूमि का रंग बदल सकते हैं और आप शीर्षक पाठ का आकार बदल सकते हैं (थियो मुझे उस विधि के साथ अन्य समस्याएं मिली हैं जिसका मैं उपयोग कर रहा हूं)। एंड्रॉइड का उपयोग करना: पृष्ठभूमि = "xxx" इसकी पृष्ठभूमि का रंग बदल देगा, लेकिन यदि आप एक निर्दिष्ट app:itemBackground="xxx"सभी आइटम भी इस रंग को साझा करते हैं और आप पृष्ठभूमि को नहीं देख सकते हैं (जब तक आप पारदर्शिता नहीं जोड़ते हैं, लेकिन फिर भी, सभी आइकन एक ही रंग साझा करते हैं) । बहुत ही लचर है कि एंड्रॉइड टीम ने इस तरह के एक भद्दा घटक जारी किया ... हमेशा 75% पूर्ण, अतिरिक्त मील को याद कर रहा है जो इसे महान बना देगा।
मार्टिन मार्कोसिनी

हम पृष्ठभूमि का रंग बदल सकते हैं
स्टीव

नमस्ते, मैं एक ही काम का उपयोग कर रहा हूँ और इसके ठीक काम कर रहा हूँ, लेकिन यहाँ मैं नीचे पट्टी के केंद्र में खिताब के बिना केवल प्रतीक प्रदर्शित करना चाहते हैं। क्या यह संभव है? और मैंने पहले ही मेनू आइटम में खाली डालने की कोशिश की लेकिन अभी भी आइकन केवल शीर्ष में दिखाई दे रहे हैं। बॉटम बार के केंद्र में मैं बिना शीर्षक के केवल चिह्न कैसे दिखा सकता हूं?
14:

नमस्ते, कृपया इसके लिए मेरे उत्तर की जाँच करें यहाँ stackoverflow.com/questions/40183239/…
Sanf0rd

@MartinMarconcini नीचे के नेविगेशन दृश्य के लिए आपने पाठ का आकार कैसे बदला?
पुंसुयंबु वेल्लादुरई

10

जैसा कि Sanf0rd ने उल्लेख किया है, Google ने डिजाइन सपोर्ट लाइब्रेरी संस्करण 25.0.0 के भाग के रूप में बॉटनवेशन व्यू लॉन्च किया । उन्होंने जिन सीमाओं का उल्लेख किया है, वे ज्यादातर सच हैं, सिवाय इसके कि आप दृश्य की पृष्ठभूमि का रंग और यहां तक ​​कि पाठ का रंग और आइकन रंग भी बदल सकते हैं। जब आप 4 से अधिक आइटम जोड़ते हैं, तो इसका एक एनीमेशन भी होता है (दुख की बात यह है कि इसे सक्षम या मैन्युअल रूप से अक्षम नहीं किया जा सकता है)।

मैंने इसके बारे में एक विस्तृत ट्यूटोरियल उदाहरणों के साथ और एक रिपॉजिटरी के साथ लिखा, जिसे आप यहाँ पढ़ सकते हैं: https://blog.autsoft.hu/now-you-can-use-the-bottom-navigation-view-in-the- डिजाइन-support-पुस्तकालय /


इसका सार

आपको इन्हें अपने ऐप स्तर में जोड़ना होगा build.gradle:

compile 'com.android.support:appcompat-v7:25.0.0'  
compile 'com.android.support:design:25.0.0'

आप इसे अपने लेआउट में इस तरह शामिल कर सकते हैं:

<android.support.design.widget.BottomNavigationView  
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:id="@+id/bottom_navigation_view"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:itemBackground="@color/darkGrey"
        app:itemIconTint="@color/bottom_navigation_item_background_colors"
        app:itemTextColor="@color/bottom_navigation_item_background_colors"
        app:menu="@menu/menu_bottom_navigation" />

आप इस तरह से मेनू संसाधन के माध्यम से आइटम निर्दिष्ट कर सकते हैं:

<?xml version="1.0" encoding="utf-8"?>  
<menu  
    xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:id="@+id/action_one"
        android:icon="@android:drawable/ic_dialog_map"
        android:title="One"/>
    <item
        android:id="@+id/action_two"
        android:icon="@android:drawable/ic_dialog_info"
        android:title="Two"/>
    <item
        android:id="@+id/action_three"
        android:icon="@android:drawable/ic_dialog_email"
        android:title="Three"/>
    <item
        android:id="@+id/action_four"
        android:icon="@android:drawable/ic_popup_reminder"
        android:title="Four"/>
</menu>

और आप टिंट और टेक्स्ट रंग को एक रंग सूची के रूप में सेट कर सकते हैं, इसलिए वर्तमान में चयनित आइटम हाइलाइट किया गया है:

<?xml version="1.0" encoding="utf-8"?>  
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item
        android:color="@color/colorAccent"
        android:state_checked="false"/>
    <item
        android:color="@android:color/white"
        android:state_checked="true"/>

</selector>

अंत में, आप एक OnNavigationItemSelectedListener के साथ आइटम का चयन संभाल सकते हैं:

bottomNavigationView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {  
    @Override
    public boolean onNavigationItemSelected(@NonNull MenuItem item) {
        Fragment fragment = null;
        switch (item.getItemId()) {
            case R.id.action_one:
                // Switch to page one
                break;
            case R.id.action_two:
                // Switch to page two
                break;
            case R.id.action_three:
                // Switch to page three
                break;
        }
        return true;
    }
});

1
अति उत्कृष्ट! सुझाव - निकालें एप्लिकेशन: itemBackground = "@ रंग / डार्कग्रे" देशी परिपत्र लहर प्रभाव प्राप्त करने के लिए।
गर्क

8

अन्य वैकल्पिक पुस्तकालय जिन्हें आप आज़मा सकते हैं: - https://github.com/Ashok-Varma/BottomNavigation

<com.ashokvarma.bottomnavigation.BottomNavigationBar
    android:layout_gravity="bottom"
    android:id="@+id/bottom_navigation_bar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>

BottomNavigationBar bottomNavigationBar = (BottomNavigationBar) findViewById(R.id.bottom_navigation_bar);

bottomNavigationBar
                .addItem(new BottomNavigationItem(R.drawable.ic_home_white_24dp, "Home"))
                .addItem(new BottomNavigationItem(R.drawable.ic_book_white_24dp, "Books"))
                .addItem(new BottomNavigationItem(R.drawable.ic_music_note_white_24dp, "Music"))
                .addItem(new BottomNavigationItem(R.drawable.ic_tv_white_24dp, "Movies & TV"))
                .addItem(new BottomNavigationItem(R.drawable.ic_videogame_asset_white_24dp, "Games"))
                .initialise();

1
इसी तरह की एक अन्य लाइब्रेरी है AHBottomNavigation: github.com/aurelhubert/ahbottomnavigation
ninjahoahong

3

मुझे लगता है कि यह भी उपयोगी है।

टुकड़ा

public class MainActivity : AppCompatActivity, BottomNavigationBar.Listeners.IOnTabSelectedListener
{
    private BottomBar _bottomBar;

    protected override void OnCreate(Bundle bundle)
    {
        base.OnCreate(bundle);

        SetContentView(Resource.Layout.MainActivity);

        _bottomBar = BottomBar.Attach(this, bundle);
        _bottomBar.SetItems(
            new BottomBarTab(Resource.Drawable.ic_recents, "Recents"),
            new BottomBarTab(Resource.Drawable.ic_favorites, "Favorites"),
            new BottomBarTab(Resource.Drawable.ic_nearby, "Nearby")
        );
        _bottomBar.SetOnItemSelectedListener(this);
        _bottomBar.HideShadow();
        _bottomBar.UseDarkTheme(true);
        _bottomBar.SetTypeFace("Roboto-Regular.ttf");

        var badge = _bottomBar.MakeBadgeForTabAt(1, Color.ParseColor("#f02d4c"), 1);
        badge.AutoShowAfterUnSelection = true;
    }

    public void OnItemSelected(int position)
    {

    }

    protected override void OnSaveInstanceState(Bundle outState)
    {
        base.OnSaveInstanceState(outState);

        // Necessary to restore the BottomBar's state, otherwise we would
        // lose the current tab on orientation change.
        _bottomBar.OnSaveInstanceState(outState);
    }
}

लिंक

https://github.com/pocheshire/BottomNavigationBar

यह https://github.com/roughike/BottomBar Xamarin डेवलपर्स के लिए C # में पोर्ट किया गया है


3

मैंने एक निजी वर्ग बनाया है जो ग्रिडव्यू और मेनू संसाधन का उपयोग करता है:

private class BottomBar {

    private GridView mGridView;
    private Menu     mMenu;
    private BottomBarAdapter mBottomBarAdapter;
    private View.OnClickListener mOnClickListener;

    public BottomBar (@IdRes int gridviewId, @MenuRes int menuRes,View.OnClickListener onClickListener) {
        this.mGridView = (GridView) findViewById(gridviewId);
        this.mMenu = getMenu(menuRes);
        this.mOnClickListener = onClickListener;

        this.mBottomBarAdapter = new BottomBarAdapter();
        this.mGridView.setAdapter(mBottomBarAdapter);
    }

    private Menu getMenu(@MenuRes int menuId) {
        PopupMenu p = new PopupMenu(MainActivity.this,null);
        Menu menu = p.getMenu();
        getMenuInflater().inflate(menuId,menu);
        return menu;
    }

    public GridView getGridView(){
        return mGridView;
    }

    public void show() {
        mGridView.setVisibility(View.VISIBLE);
        mGridView.animate().translationY(0);
    }

    public void hide() {
        mGridView.animate().translationY(mGridView.getHeight());
    }



    private class BottomBarAdapter extends BaseAdapter {

        private LayoutInflater    mInflater;

        public BottomBarAdapter(){
            this.mInflater = LayoutInflater.from(MainActivity.this);
        }

        @Override
        public int getCount() {
            return mMenu.size();
        }

        @Override
        public Object getItem(int i) {
            return mMenu.getItem(i);
        }

        @Override
        public long getItemId(int i) {
            return 0;
        }

        @Override
        public View getView(int i, View view, ViewGroup viewGroup) {

            MenuItem item = (MenuItem) getItem(i);

            if (view==null){
                view = mInflater.inflate(R.layout.your_item_layout,null);
                view.setId(item.getItemId());
            }

            view.setOnClickListener(mOnClickListener);
            view.findViewById(R.id.bottomnav_icon).setBackground(item.getIcon());
            ((TextView) view.findViewById(R.id.bottomnav_label)).setText(item.getTitle());

            return view;
        }
    }

your_menu.xml:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:id="@+id/item1_id"
        android:icon="@drawable/ic_item1"
        android:title="@string/title_item1"/>
    <item android:id="@+id/item2_id"
        android:icon="@drawable/ic_item2"
        android:title="@string/title_item2"/>
    ...
</menu>

और एक कस्टम लेआउट आइटम your_item_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content" android:layout_height="wrap_content"
    android:orientation="vertical"
    android:layout_margin="16dp">
    <ImageButton android:id="@+id/bottomnav_icon"
        android:layout_width="24dp"
        android:layout_height="24dp"
        android:layout_gravity="top|center_horizontal"
        android:layout_marginTop="8dp"
        android:layout_marginBottom="4dp"/>
    <TextView android:id="@+id/bottomnav_label"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|center_horizontal"
        android:layout_marginBottom="8dp"
        android:layout_marginTop="4dp"
        style="@style/mystyle_label" />
</LinearLayout>

आपकी मुख्यता के अंदर उपयोग:

BottomBar bottomBar = new BottomBar(R.id.YourGridView,R.menu.your_menu, mOnClickListener);

तथा

private View.OnClickListener mOnClickListener = new View.OnClickListener() {
    @Override
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.item1_id:
                //todo item1
                break;
            case R.id.item2_id:
                //todo item2
                break;
            ...
        }
    }
}

और layout_activity.xml में

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    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:fitsSystemWindows="true">
    ...
    <FrameLayout android:id="@+id/fragment_container"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

    <GridView android:id="@+id/bottomNav"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/your_background_color"
        android:verticalSpacing="0dp"
        android:horizontalSpacing="0dp"
        android:numColumns="4"
        android:stretchMode="columnWidth"
        app:layout_anchor="@id/fragment_container"
        app:layout_anchorGravity="bottom"/>
</android.support.design.widget.CoordinatorLayout>

3

डिज़ाइन समर्थन लाइब्रेरी के संस्करण 25 में एक नया आधिकारिक बॉटम-न्यूगेशन व्यू है

https://developer.android.com/reference/android/support/design/widget/BottomNavigationView.html ग्रेड में compile 'com.android.support:design:25.0.0'

एक्सएमएल

<android.support.design.widget.BottomNavigationView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:design="http://schema.android.com/apk/res/android.support.design"
    android:id="@+id/navigation"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    design:menu="@menu/my_navigation_items" />

1

यह लाइब्रेरी, बॉटम नॅनवेशन व्यू , गूगल के बॉटम नॅनवेशन व्यू को बढ़ाती है। आप जिस तरह से आप चाहते हैं, उसके नीचे नेविगेशन पट्टी रखने के लिए आप आसानी से Google की लाइब्रेरी को कस्टमाइज़ कर सकते हैं। आप स्थानांतरण मोड को अक्षम कर सकते हैं, आइकन और ग्रंथों की दृश्यता बदल सकते हैं और बहुत कुछ। निश्चित रूप से इसे आज़माएं।


0

मैंने इस github पोस्ट को संदर्भित किया है और मैंने नीचे टैब बार में पृष्ठों के three layoutsलिए सेट किया है three fragment

FourButtonsActivity.java:

bottomBar.setFragmentItems(getSupportFragmentManager(), R.id.fragmentContainer,
            new BottomBarFragment(LibraryFragment.newInstance(R.layout.library_fragment_layout), R.drawable.ic_update_white_24dp, "Recents"),
            new BottomBarFragment(PhotoEffectFragment.newInstance(R.layout.photo_effect_fragment), R.drawable.ic_local_dining_white_24dp, "Food"),
            new BottomBarFragment(VideoFragment.newInstance(R.layout.video_layout), R.drawable.ic_favorite_white_24dp, "Favorites")

    );

बैज गिनती सेट करने के लिए:

  BottomBarBadge unreadMessages = bottomBar.makeBadgeForTabAt(1, "#E91E63", 4);
  unreadMessages.show();
  unreadMessages.setCount(4);
  unreadMessages.setAnimationDuration(200);
  unreadMessages.setAutoShowAfterUnSelection(true);

LibraryFragment.java:

import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class LibraryFragment extends Fragment {
    private static final String STARTING_TEXT = "Four Buttons Bottom Navigation";

    public LibraryFragment() {
    }

    public static LibraryFragment newInstance(int resource) {
        Bundle args = new Bundle();
        args.putInt(STARTING_TEXT, resource);

        LibraryFragment sampleFragment = new LibraryFragment();
        sampleFragment.setArguments(args);

        return sampleFragment;
    }

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {


        View view = LayoutInflater.from(getActivity()).inflate(
                getArguments().getInt(STARTING_TEXT), null);
        return view;


    }

0

आप उपर्युक्त उत्तरों के अनुसार लेआउट बना सकते हैं यदि कोई भी इसे कोटलिन में उपयोग करना चाहता है: -

 private val mOnNavigationItemSelectedListener = BottomNavigationView.OnNavigationItemSelectedListener { item ->
    when (item.itemId) {
        R.id.images -> {
          // do your work....
            return@OnNavigationItemSelectedListener true
        }
       R.id.videos ->
         {
          // do your work....
            return@OnNavigationItemSelectedListener true
        }
    }
    false
}

फिर oncreate में आप उपरोक्त श्रोता को अपने विचार पर सेट कर सकते हैं

   mDataBinding?.navigation?.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener)

-1
<android.support.design.widget.BottomNavigationView
    android:id="@+id/navigation"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom"
    android:background="?android:attr/windowBackground"
    app:menu="@menu/navigation" />

नेविगेशन। xml (मेनू के अंदर)

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <item
        android:id="@+id/navigation_home"
        android:icon="@drawable/ic_home_black_24dp"
        android:title="@string/title_home"
        app:showAsAction="always|withText"
        android:enabled="true"/>

अंदर onCreate()विधि,

BottomNavigationView navigation = (BottomNavigationView)findViewById(R.id.navigation);
//Dont forgot this line     
BottomNavigationViewHelper.disableShiftMode(navigation);

और नीचे क्लास बनाएं।

public class BottomNavigationViewHelper {
    public static void disableShiftMode(BottomNavigationView view) {
        BottomNavigationMenuView menuView = (BottomNavigationMenuView) view.getChildAt(0);
        try {
            Field shiftingMode = menuView.getClass().getDeclaredField("mShiftingMode");
            shiftingMode.setAccessible(true);
            shiftingMode.setBoolean(menuView, false);
            shiftingMode.setAccessible(false);
            for (int i = 0; i < menuView.getChildCount(); i++) {
                BottomNavigationItemView item = (BottomNavigationItemView) menuView.getChildAt(i);
                //noinspection RestrictedApi
                item.setShiftingMode(false);
                // set once again checked value, so view will be updated
                //noinspection RestrictedApi
                item.setChecked(item.getItemData().isChecked());
            }
        } catch (NoSuchFieldException e) {
            Log.e("BNVHelper", "Unable to get shift mode field", e);
        } catch (IllegalAccessException e) {
            Log.e("BNVHelper", "Unable to change value of shift mode", e);
        }
    }
}
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.