android - ট্যাবলোআউট ট্যাব নির্বাচন




android-viewpager android-tablayout (15)

আপনার দর্শকের জন্য যুক্ত করুন:

private void setViewPagerByIndex(final int index){
    Application.getInstance().getHandler().post(new Runnable() {
        @Override
        public void run() {
            viewPager.setCurrentItem(index);
        }
    });
}

// ক্র্যাশ বহির্মুখী রোধ করতে হ্যান্ডলার অন

void updateSelectedTabTo(int position) {
    if (tabLayout != null){
        int selected = tabLayout.getSelectedTabPosition();
        if (selected != -1){
            TabLayout.Tab oldTab = tabLayout.getTabAt(0);
            if (oldTab != null){
                View view = oldTab.getCustomView();
                if (view != null){
                    view.setSelected(false);
                }
                else {
                    Timber.e("oldTab customView is null");
                }
            }
            else {
                Timber.e("oldTab is null");
            }
        }
        else {
            Timber.e("selected is -1");
        }
        TabLayout.Tab newTab = tabLayout.getTabAt(position);
        if (newTab != null){
            View view = newTab.getCustomView();
            if (view != null){
                view.setSelected(false);
            }
            else {
                Timber.e("newTab customView is null");
            }
        }
        else {
            Timber.e("newTab is null");
        }
    }
    else {
        Timber.e("tablayout is null");
    }
}

আমি কীভাবে ট্যাবলআউট প্রোগ্রামে একটি ট্যাব নির্বাচন করব?

 TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
 tabLayout.setupWithViewPager(viewPager);

আপনার যদি বুঝতে সমস্যা হয় তবে এই কোডটি আপনাকে সহায়তা করতে পারে

myTabLayout.setTabTextColors(getColor(R.color.colorNormalTab),getColor(R.color.colorSelectedTab));

আপনি এটিকে আপনার কোডে যুক্ত করতে পারেন:

tabLayout.setTabTextColors(getResources().getColor(R.color.colorHintTextLight),
                           getResources().getColor(R.color.colorPrimaryTextLight));

আপনি নিম্নলিখিত ফাংশনগুলি ব্যবহার করে ট্যাবলআউট পজিশনটি সেট করতে পারেন

private void MyTabLayout(){
    TabLayout.Tab myTab = myTabLayout.newTab(); // create a new tab
    myTabLayout.addTab(myTab); // add my new tab to myTabLayout
    myTab.setText("new tab"); 
    myTab.select(); // select the new tab
}

আপনি যদি ট্যাব ব্যবহার না করতে পারেন (নির্বাচন করুন) এবং আপনি ভিউপ্যাজারটি ব্যবহার করতে না চান তবে আপনি প্রোগ্রামের পরে কোনও ট্যাব নির্বাচন করতে পারেন। আপনি যদি TabLayout.Tab setCustomView(android.view.View view) মাধ্যমে একটি কাস্টম ভিউ ব্যবহার করছেন তবে এটি সহজ। এটি উভয় উপায়ে কীভাবে করা যায় তা এখানে।

// if you've set a custom view
void updateTabSelection(int position) {
    // get the position of the currently selected tab and set selected to false
    mTabLayout.getTabAt(mTabLayout.getSelectedTabPosition()).getCustomView().setSelected(false);
    // set selected to true on the desired tab
    mTabLayout.getTabAt(position).getCustomView().setSelected(true);
    // move the selection indicator
    mTabLayout.setScrollPosition(position, 0, true);

    // ... your logic to swap out your fragments
}

আপনি যদি কাস্টম ভিউ ব্যবহার না করে থাকেন তবে আপনি এটি এর মতো করতে পারেন

// if you are not using a custom view
void updateTabSelection(int position) {
    // get a reference to the tabs container view
    LinearLayout ll = (LinearLayout) mTabLayout.getChildAt(0);
    // get the child view at the position of the currently selected tab and set selected to false
    ll.getChildAt(mTabLayout.getSelectedTabPosition()).setSelected(false);
    // get the child view at the new selected position and set selected to true
    ll.getChildAt(position).setSelected(true);
    // move the selection indicator
    mTabLayout.setScrollPosition(position, 0, true);

    // ... your logic to swap out your fragments
}

নির্বাচিত এবং নির্বাচিত বাছাইযোগ্য ড্রয়াবল বা রঙ এবং / অথবা অঙ্কনযোগ্যগুলির সাথে আপনি যা করতে চান তেমন কিছু করার জন্য টগল করতে একটি স্টেটলিস্টড্রেবল ব্যবহার করুন।


আপনি যে ট্যাবটি নির্বাচন করতে চান তার সূচিটি যদি জানেন তবে আপনি এটির মতো এটি করতে পারেন:

TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
TabLayout.Tab tab = tabLayout.getTabAt(someIndex);
tab.select();

এই কৌশলটি যদি আপনি ভিউপ্যাজার ছাড়া নিজেই ট্যাবলআউট ব্যবহার করেন তবে এটি কার্যকর হয় (যা অ্যাটিক্যাল, এবং সম্ভবত খারাপ অভ্যাস, তবে আমি এটিটি দেখেছি)।


আমি টুকরাগুলি স্যুইচ করতে ট্যাবলআউট ব্যবহার করছি using এটি বেশিরভাগ অংশের জন্যই কাজ করে, যখনই আমি আমার TabLayout.OnTabSelectedListener tab.select() ব্যবহার করে প্রোগ্রামটিমেটিকভাবে ট্যাবটি নির্বাচন করার চেষ্টা করি TabLayout.OnTabSelectedListener onTabSelected(TabLayout.Tab tab) , যা আমার অনেক শোকের কারণ হতে পারে। আমি শ্রোতাদের ট্রিগার না করে প্রোগ্রাম্যাটিক নির্বাচন করার একটি উপায় খুঁজছিলাম for

সুতরাং আমি আমার ব্যবহারের জন্য @ টেনডোগির উত্তরটি মানিয়েছি। আমি আরও এমন সমস্যার মুখোমুখি হয়েছি যেখানে কিছু অভ্যন্তরীণ বস্তু onActivityResult() ফিরে আসবে (কারণ তারা এখনও তৈরি হয়নি, কারণ আমি আমার খণ্ড থেকে onActivityResult() উত্তর onActivityResult() যা ক্রিয়াকলাপটি singleTask বা singleTask ক্ষেত্রে singleTask আগে ঘটে onCreate() ) তাই আমি একটি বিস্তারিত লিখেছি যদি / অন্য ক্রমটি ত্রুটিটি রিপোর্ট করে এবং NullPointerException ব্যতীত পড়ে যা অন্যথায় ট্রিগার করে। লগিংয়ের জন্য আমি কাঠ ব্যবহার করি, যদি আপনি Log.e() ব্যবহার না করেন।

 viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

            @Override
            public void onPageSelected(int position) {
                array.clear();
                switch (position) {
                    case 1:
                        //like a example
                        setViewPagerByIndex(0);
                        break;
                }
            }

            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
            }

            @Override
            public void onPageScrollStateChanged(int state) {
            }
        });

এখানে, ট্যাবলাউটটি আমার এক্সএমএলে TabLayout অবজেক্টের সাথে আবদ্ধ আমার মেমরি ভেরিয়েবল। এবং আমি স্ক্রোলিং ট্যাব বৈশিষ্ট্যটি ব্যবহার করি না তাই আমি এটিও সরিয়েছি।


এইভাবে চেষ্টা করুন।

 mTitles = getResources().getStringArray(R.array.tabItems);
    mIcons = getResources().obtainTypedArray(R.array.tabIcons);
    for (int i = 0; i < mTitles.length; i++) {

        tabs.addTab(tabs.newTab().setText(mTitles[i]).setIcon(mIcons.getDrawable(i)));
        if (i == 0) {
            /*For setting selected position 0 at start*/
            Objects.requireNonNull(Objects.requireNonNull(tabs.getTabAt(i)).getIcon()).setColorFilter(ContextCompat.getColor(getApplicationContext(), R.color.colorPrimary), PorterDuff.Mode.SRC_IN);
        }
    }

    tabs.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
        @Override
        public void onTabSelected(TabLayout.Tab tab) {
            Objects.requireNonNull(tab.getIcon()).setColorFilter(ContextCompat.getColor(getApplicationContext(), R.color.colorPrimary), PorterDuff.Mode.SRC_IN);
        }

        @Override
        public void onTabUnselected(TabLayout.Tab tab) {
            Objects.requireNonNull(tab.getIcon()).setColorFilter(ContextCompat.getColor(getApplicationContext(), R.color.white), PorterDuff.Mode.SRC_IN);
        }

        @Override
        public void onTabReselected(TabLayout.Tab tab) {

        }
    });

এটা চেষ্টা কর

    new Handler().postDelayed(
            new Runnable(){
                @Override
                public void run() {
                    if (i == 1){
                        tabLayout.getTabAt(0).select();
                    } else if (i == 2){
                        tabLayout.getTabAt(1).select();
                    }
                }
            }, 100);

এটা ব্যবহার কর:

<android.support.design.widget.TabLayout
    android:id="@+id/patienthomescreen_tabs"
    android:layout_width="match_parent"
    android:layout_height="72sp"
    app:tabGravity="fill"
    app:tabMode="fixed"
    app:tabIndicatorColor="@android:color/white"
    app:tabSelectedTextColor="@color/green"/>

অনক্লিকলিস্টনার পরে:

TabLayout tabLayout = (TabLayout) findViewById(R.id.patienthomescreen_tabs);
TabLayout.Tab tab = tabLayout.getTabAt(someIndex);
tab.select();

এটি সম্ভবত চূড়ান্ত সমাধান নয় , এবং এটির জন্য আপনি TabLayout একসাথে TabLayout ব্যবহার করতে হবে তবে TabLayout আমি এটি সমাধান করেছি:

void selectPage(int pageIndex)
{
    viewPager.setCurrentItem(pageIndex);
    tabLayout.setupWithViewPager(viewPager);
}

এই কোডটি ব্যবহারের পারফরম্যান্সের প্রভাবটি কতটা বড় তা আমি পরীক্ষা করেছিলাম প্রথমে পদ্ধতিটি চালনার সময় অ্যান্ড্রয়েড স্টুডিওতে মেমরি মনিটরগুলি দেখে এবং তারপরে যখন আমি পৃষ্ঠাগুলির মধ্যে নেভিগেট করতাম তখন সিপিইউ এবং মেমরিতে থাকা লোডের সাথে তুলনা করেছিলাম আমি (সোয়াইপ অঙ্গভঙ্গি ব্যবহার করে), এবং পার্থক্যটি উল্লেখযোগ্যভাবে বড় নয়, তাই কমপক্ষে এটি কোনও ভয়াবহ সমাধান নয় ...

আশা করি এটি কাউকে সাহায্য করবে!


কিছুটা দেরি হলেও এটি একটি কার্যকর সমাধান হতে পারে। আমি আমার টেবিলআউটটি সরাসরি আমার টুকরোটিতে ব্যবহার করছি এবং ফ্রেগমেন্টের লাইফসাইকেলের প্রথম দিকে কোনও ট্যাব নির্বাচন করার চেষ্টা করছি। আমার জন্য কাজটি হ'ল অ্যান্ড্রয়েড.ভিউ.ভিউ android.view.View#post পদ্ধতিটি ব্যবহার করে ট্যাবলআউটটি তার সন্তানের দৃষ্টিভঙ্গিগুলি শেষ না হওয়া পর্যন্ত অপেক্ষা করা ছিল। অর্থাৎ,

int myPosition = 0;
myFilterTabLayout.post(() -> { filterTabLayout.getTabAt(myPosition).select(); });

ডিফল্টরূপে আপনি কোনও ট্যাব নির্বাচন করলে এটি হাইলাইট করা হবে। আপনি যদি স্পষ্টভাবে নির্বাচন করতে চান তবে আপনার নির্দিষ্ট ট্যাব সূচক অবস্থানের সাথে onTabSelected (TabLayout.Tab ট্যাব) এর অধীন প্রদত্ত মন্তব্যকৃত কোডটি ব্যবহার করুন। এই কোডটি ভিউপ্যাজারটি ব্যবহার করে ট্যাব নির্বাচিত অবস্থানে পরিবর্তন খণ্ড সম্পর্কে ব্যাখ্যা করবে।

public class GalleryFragment extends Fragment implements TabLayout.OnTabSelectedListener 
{
private ViewPager viewPager;public ViewPagerAdapter adapter;private TabLayout tabLayout;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_gallery, container, false);
viewPager = (ViewPager) rootView.findViewById(R.id.viewpager);
adapter = new ViewPagerAdapter(getChildFragmentManager());
adapter.addFragment(new PaymentCardFragment(), "PAYMENT CARDS");
adapter.addFragment(new LoyaltyCardFragment(), "LOYALTY CARDS");
viewPager.setAdapter(adapter);
tabLayout = (TabLayout) rootView.findViewById(R.id.tabs);
    tabLayout.setupWithViewPager(viewPager);
    tabLayout.setOnTabSelectedListener(this);
}

@Override
public void onTabSelected(TabLayout.Tab tab) {
    //This will be called 2nd when you select a tab or swipe using viewpager
    final int position = tab.getPosition();
    Log.i("card", "Tablayout pos: " + position);
    //TabLayout.Tab tabdata=tabLayout.getTabAt(position);
    //tabdata.select();
    tabLayout.post(new Runnable() {
        @Override
        public void run() {
            if (position == 0) {
                PaymentCardFragment paymentCardFragment = getPaymentCardFragment();
                if (paymentCardFragment != null) {
                   VerticalViewpager vp = paymentCardFragment.mypager;
                    if(vp!=null)
                    {
                      //vp.setCurrentItem(position,true);
                      vp.setCurrentItem(vp.getAdapter().getCount()-1,true);
                    }
                  }
            }
            if (position == 1) {
               LoyaltyCardFragment loyaltyCardFragment = getLoyaltyCardFragment();
                if (loyaltyCardFragment != null) {
                   VerticalViewpager vp = loyaltyCardFragment.mypager;
                    if(vp!=null)
                    {
                        vp.setCurrentItem(position);
                    }
                  }
            }
        }
    });
}

@Override
public void onTabUnselected(TabLayout.Tab tab) {
 //This will be called 1st when you select a tab or swipe using viewpager
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
  //This will be called only when you select the already selected tab(Ex: selecting 3rd tab again and again)
}
 private PaymentCardFragment getLoyaltyCardFragment() {
    Fragment f = adapter.mFragmentList.get(viewPager.getCurrentItem());

   if(f instanceof PaymentCardFragment)
   {
    return (PaymentCardFragment) f;
   }
   return null;
 }
private LoyaltyCardFragment getPaymentCardFragment() {
    Fragment f = adapter.mFragmentList.get(viewPager.getCurrentItem());
    if(f instanceof LoyaltyCardFragment)
   {
    return (LoyaltyCardFragment) f;
   }
   return null;
 }
  class ViewPagerAdapter extends FragmentPagerAdapter {
   public List<Fragment> mFragmentList = new ArrayList<>();
    private final List<String> mFragmentTitleList = new ArrayList<>();
   public void addFragment(Fragment fragment, String title) {
   mFragmentList.add(fragment);
   mFragmentTitleList.add(title);
  }
 }
}

ভিউপেজ.সিটারকেনারটাইম () ব্যবহার করার জন্য আপনার ভিউপেজার ব্যবহার করা উচিত

 viewPager.setCurrentItem(n);
 tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
            @Override
            public void onTabSelected(TabLayout.Tab tab) {
                viewPager.setCurrentItem(tab.getPosition());
            }

            @Override
            public void onTabUnselected(TabLayout.Tab tab) {
            }

            @Override
            public void onTabReselected(TabLayout.Tab tab) {

            }
        });

যদি এটি ঘটে থাকে যে আপনার ডিফল্ট ট্যাবটি প্রথমটি (0) এবং আপনি কোনও খণ্ডে স্যুইচ করতে যাচ্ছেন তবে আপনাকে অবশ্যই প্রথম বারের জন্য খণ্ডটি ম্যানুয়ালি প্রতিস্থাপন করতে হবে। শ্রোতার রেজিস্ট্রেশন হওয়ার আগে ট্যাবটি নির্বাচিত হওয়ার কারণ এটি।

private TabLayout mTabLayout;

...

@Override
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fragment_tablayout, container, false);
    mTabLayout = view.findViewById(R.id.sliding_tabs);
    mTabLayout.addOnTabSelectedListener(mOnTabSelectedListener);

    getActivity().getSupportFragmentManager().beginTransaction()
        .replace(R.id.tabContent, MyFirstFragment.newInstance()).commit();
    return view;
}

বিকল্পভাবে, আপনি getTabAt(0).select()onTabReselected ওভাররাইডিং এর মতো বিবেচনা করতে পারেন:

@Override
public void onTabReselected(TabLayout.Tab tab) {
    // Replace the corresponding tab fragment.
}

এটি কাজ করবে কারণ আপনি প্রতিটি ট্যাব পুনঃনির্ধারণে মূলত খণ্ডটি প্রতিস্থাপন করছেন।


ম্যাটেরিয়াল কম্পোনেন্টস লাইব্রেরি দ্বারা সরবরাহিত TabLayout দিয়ে কেবল selectTab পদ্ধতিটি ব্যবহার করুন:

viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
    @Override
    public void onPageScrolled(int i, float v, int i1) {
    }

    @Override
    public void onPageSelected(int i) {
        tablayout.getTabAt(i).select();
    }

    @Override
    public void onPageScrollStateChanged(int i) {
    }
});

এটির সংস্করণ 1.1.0 প্রয়োজন।





android-design-library