4 скользящие вкладки вместо 2

Я делаю приложение, которое должно иметь 4 скользящие вкладки. Я нашел это руководство: http://www.android4devs.com/2015/01/how-to-make-material-design-sliding-tabs.html?m=1, которому я следовал, и он отлично работал, но он только показывает, как сделать это с 2 вкладками... Кто-то еще спрашивал об этом в комментариях, и мне ответили, что он сказал что-то, что дало мне много ошибок. Как мне заставить это работать с 4 вкладками вместо двух?


person Spickle    schedule 25.10.2015    source источник
comment
Можете ли вы привести пример того, что вы пробовали, но это не работает?   -  person andorov    schedule 26.10.2015
comment
Ответ ниже, кажется, работает, но я получаю одну ошибку на шаге 3 (изменить класс ViewPagerAdapter). В конце я получаю сообщение об ошибке «Отсутствует оператор возврата». У кого-нибудь есть решение?   -  person Spickle    schedule 26.10.2015


Ответы (1)


1) В основной активности:

В строке 20 настройте

int Numboftabs =2;

До нужного количества вкладок.

2) Повторите шаги 5 и 6 из руководства, но вместо Tab1 и Tab2 сделайте Tab3/4, ...

В основном вам нужно добавить файл класса java + файл макета для каждой вкладки. Итак, приступим:

Создайте tab_X.xml (X — номер/имя) со следующим содержимым

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textAppearance="?android:attr/textAppearanceMedium"
    android:text="You Are In Tab X"
    android:id="@+id/textView"
    android:layout_centerVertical="true"
    android:layout_centerHorizontal="true" />
 </RelativeLayout>

Создайте класс Java TabX (замените X номером вкладки или просто замените имя)

package com.android4devs.slidingtab;

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 TabX extends Fragment {

    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View v =inflater.inflate(R.layout.tab_X,container,false);
        return v;
     }
}

3) Отредактируйте класс ViewPagerAdapter

Например или 3 вкладки вместо 2, изменить следующее

//This method return the fragment for the every position in the View Pager
@Override
public Fragment getItem(int position) {

    if(position == 0) // if the position is 0 we are returning the First tab
    {
        Tab1 tab1 = new Tab1();
        return tab1;
    }
    else             // As we are having 2 tabs if the position is now 0 it must be 1 so we are returning second tab
    {
        Tab2 tab2 = new Tab2();
        return tab2;
    }
}

To

//This method return the fragment for the every position in the View Pager
@Override
public Fragment getItem(int position) {

    if(position == 0) // if the position is 0 we are returning the First tab
    {
        Tab1 tab1 = new Tab1();
        return tab1;
    }
    else if(position == 1)
    {
        Tab2 tab2 = new Tab2();
        return tab2;
    }
    else if(position == 2)
    {
        Tab3 tab3 = new Tab3();
        return tab3;
    }
    else if { .... } // add more as desired.
    // but make sure that you use "else" instead of "else if" for the last tab.
}

Все должно работать после внесения этих изменений. Я хочу отметить, что предоставленный/отредактированный код взят из учебника в вопросе ОП.

person Kevin Van Ryckegem    schedule 25.10.2015
comment
Большое спасибо! Я получаю только одну ошибку на последнем шаге: отсутствует оператор возврата. что делать сейчас? - person Spickle; 26.10.2015
comment
Я разобрался: на последней вкладке надо ставить не else if, а просто else - person Spickle; 27.10.2015
comment
@Spickle Верно :-). Добавлю это в мой ответ. Если этот ответ решил ваш вопрос, не могли бы вы отметить его как ответ? (нажмите галочку рядом с ответом). - person Kevin Van Ryckegem; 27.10.2015