Due to the need to change the width of the TabLayout underline, the method set on the Internet has no effect, finally check the source code found API28 version after the mTabStrip has been changed to slidingTabIndicator, mTextView has been changed to textView. By substituting these two, you can achieve the same underline width as the length of the text. The code is as follows:
Public static void reflex(Final TabLayout TabLayout){tablayout.post (() -> {try {// Get the TabLayout slidingTabIndicator Field tabIndicator = tabLayout.getClass().getDeclaredField("slidingTabIndicator"); // Field tabIndicator = TabLayout.getClass ().getDeclaredField("mTabStrip"); tabIndicator.setAccessible(true); LinearLayout mTabStrip = (LinearLayout) tabIndicator.get(tabLayout); int dp10 = dip2px(tabLayout.getContext(), 10); for (int i = 0; i < mTabStrip.getChildCount(); i++) { View tabView = mTabStrip.getChildAt(i); MTextViewField = tabView.getClass().getDeclaredField("textView"); // Field mTextViewField = tabView.getClass().getDeclaredField("mTextView"); mTextViewField.setAccessible(true); TextView mTextView = (TextView) mTextViewField.get(tabView); tabView.setPadding(0, 0, 0, 0); Int width = 0; int width = 0; width = mTextView.getWidth(); if (width == 0) { mTextView.measure(0, 0); width = mTextView.getMeasuredWidth(); } / / Settings TAB spacing of 10 dp the spacing can change according to your demand LinearLayout. LayoutParams params = (LinearLayout. LayoutParams) tabView.getLayoutParams(); params.width = width ; params.leftMargin = dp10; params.rightMargin = dp10; tabView.setLayoutParams(params); tabView.invalidate(); } } catch (NoSuchFieldException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); }}); }Copy the code