Acabo de comenzar con Android y tengo un problema. Tengo Recycler View con la lista de entrenamiento y en esta vista, quiero hacer un encabezado que estará en un lugar estático, independientemente del desplazamiento. Sin embargo, la vista de encabezado o texto no es visible en el diseño lineal que se encuentra sobre recycler view. No tengo idea de cómo resolver mi problema, ¿alguien tiene alguna solución o idea? A continuación presento los elementos individuales del código.

Mi vista del reciclador:

 <android.support.v7.widget.RecyclerView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/training_recycler"
    android:scrollbars="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

Mi ejemplo de diseño lineal

<LinearLayout 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="wrap_content"
    android:orientation="vertical"
    tools:context=".TrainingFragment">


    <TextView
        android:id="@+id/anything"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="40sp"
        android:text="@string/monia"/>

</LinearLayout>

Dentro de RecyclerView tengo una vista de tarjeta que se ve:

<android.support.v7.widget.CardView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:card_view="http://schemas.android.com/apk/res-auto"
    android:id="@+id/card_view"
    android:layout_width="match_parent"
    android:layout_height="50dp"
    android:layout_margin="15dp"
    card_view:cardCornerRadius="10dp">


    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical">

        <TextView
            android:id="@+id/info_text"
            android:layout_marginLeft="15dp"
            android:layout_marginBottom="15dp"
            android:layout_height="wrap_content"
            android:layout_width="match_parent"
            android:textSize="20sp"/>
    </LinearLayout>

</android.support.v7.widget.CardView>

Cuando miro a la ventana de diseño, veo mi textView con texto, pero cuando enciendo el emulador, TextView no se muestra.

Gracias por cualquier sugerencia.

Editar:

TrainingMaterialFragment.java

public class TrainingMaterialFragment extends Fragment {

    RecyclerView trainingRecycler;
    public TrainingMaterialFragment() {
        // Required empty public constructor
    }

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

        RecyclerView trainingRecycler = (RecyclerView)inflater.inflate(
                R.layout.fragment_training_material, container, false);
        int userNo = 1;

        String[] nameArray = new String[0];
        int[] idArray= new int[0];
        try {

            SQLiteOpenHelper myFitnessAppDatabaseHelper = new MyFitnessAppDatabaseHelper(inflater.getContext());
            View view = inflater.inflate(R.layout.fragment_training, container, false);

            SQLiteDatabase db = myFitnessAppDatabaseHelper.getReadableDatabase();

            Cursor cursor = db.query("TRAINING_DIARY",
                    new String[]{"TRAINING_NAME", "DATE",
                            "DISTANCE","_id"},
                    "USER = ?",
                    new String[]{Integer.toString(userNo)},
                    null, null, null);
            int count = cursor.getCount();
            nameArray = new String[count];
            idArray=new int[count];

            if (cursor.moveToFirst()) {

                String nameText = cursor.getString(0);
                TextView name = (TextView) view.findViewById(R.id.training_name);
                name.setText(nameText);
                nameArray[0] = nameText;
                idArray[0]=cursor.getInt(3);

                int i = 1;
                while(i < count) {
                    cursor.moveToNext();

                    nameText = cursor.getString(0);
                    nameArray[i] = nameText;
                    idArray[i]=cursor.getInt(3);
                    i++;

                }
            }
            cursor.close();
            db.close();
        } catch (SQLiteException e) {
            Toast toast = Toast.makeText(inflater.getContext(), "Baza danych jest niedostępna", Toast.LENGTH_SHORT);
            toast.show();
        }

        TrainingAdapter adapter =
                new TrainingAdapter(nameArray);
        trainingRecycler.setAdapter(adapter);
        LinearLayoutManager layoutManager = new LinearLayoutManager(getActivity());
        trainingRecycler.setLayoutManager(layoutManager);


        adapter.setListener(new TrainingAdapter.Listener() {
            public void onClick(int position) {

                Intent intent = new Intent(getActivity(), TrainingDetailActivity.class);
                intent.putExtra(TrainingDetailActivity.EXTRA_TRAINING, position);

                getActivity().startActivity(intent);
            }
        });
        return trainingRecycler;           
    }
}

Adaptador

public class TrainingAdapter extends RecyclerView.Adapter<TrainingAdapter.ViewHolder> {

    private String[] captions;
    private Listener listener;

    public TrainingAdapter(String[] captions){
        this.captions = captions;
    }

    public static class ViewHolder extends RecyclerView.ViewHolder {
        private CardView cardView;
        public ViewHolder(CardView v) {
            super(v);
            cardView = v;
        }
    }
    @Override
    public TrainingAdapter.ViewHolder onCreateViewHolder(
            ViewGroup parent, int viewType){    
        CardView cv = (CardView) LayoutInflater.from(parent.getContext())
                .inflate(R.layout.training_card_view, parent, false);
        return new ViewHolder(cv);
    }
    @Override
    public void onBindViewHolder(ViewHolder holder, final int position){
        CardView cardView = holder.cardView;

        TextView textView = (TextView)cardView.findViewById(R.id.info_text);
        textView.setText(captions[position]);


        cardView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (listener != null) {
                    listener.onClick(position);
                }
            }
        });     
    }

    @Override
    public int getItemCount(){
        return captions.length;
    }

    public static interface Listener {
        public void onClick(int position);
    }

    public void setListener(Listener listener) {
        this.listener = listener;
    }
}
0
Vix 7 sep. 2018 a las 22:08

3 respuestas

La mejor respuesta

Intenta de esta manera.

Como dijiste LinearLayout in fragment_training.xml, pon la vista de reciclador dentro de linearlayout.

Su código fragment_training.xml se convierte en el siguiente

<LinearLayout 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="wrap_content"
android:orientation="vertical"
tools:context=".TrainingFragment">


<TextView
android:id="@+id/anything"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="40sp"
android:text="@string/monia"/>

<android.support.v7.widget.RecyclerView
android:id="@+id/training_recycler"
android:scrollbars="vertical"
android:layout_width="match_parent"
android:layout_height="wrap_content" />

<LinearLayout/>

Entonces finalmente cambia en la clase de Java.

Cambiar esta línea

 RecyclerView trainingRecycler = (RecyclerView)inflater.inflate(
            R.layout.fragment_training_material, container, false);

Para

View rootview = inflater.inflate(
            R.layout.fragment_training, container, false);
.....
..... 

return rootview;

Entonces puede encontrar la vista de reciclador usando rootview.

trainingRecycler = rootview.findViewById(R.id.training_recycler);

Y asegúrese de volver rootview agregado ..

Su método OnCreateView se ve a continuación

 @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
View rootview = inflater.inflate(
            R.layout.fragment_training, container, false);
trainingRecycler = rootview.findViewById(R.id.findViewById);
.....
...
..
return rootview;
1
Mohamed Mohaideen AH 8 sep. 2018 a las 10:08

Corríjame si estoy equivocado pero no está colocando su Reciclador dentro del LinearLayout. Su LinearLayout debería verse así y luego podrá obtener lo que desea:

<LinearLayout 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="wrap_content"
android:orientation="vertical"
tools:context=".TrainingFragment">


<TextView
    android:id="@+id/anything"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textSize="40sp"
    android:text="@string/monia"/>
<android.support.v7.widget.RecyclerView

    android:id="@+id/training_recycler"
    android:scrollbars="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />
<LinearLayout/>
0
OmerCohen1994 7 sep. 2018 a las 19:19

Hice lo mismo en este proyecto. Este es el enlace al archivo XML https://github.com/ ShowYoungg / JournalApp / blob / master / app / src / main / res / layout / activity_main.xml. y el enlace al archivo java; https: //github.com/ShowYoungg/JournalApp/blob/master/app/src/main/java/com/example/android/journalapp/MainActivity.java. Puede descargar toda la aplicación y ejecutarla para ver que puse no solo TexView sino también el botón y otros en RecyclerView

0
Show Young Soyinka 7 sep. 2018 a las 22:02