Comment créer une Horizontale CardView à l'aide de RecyclerView avec une seule carte sur l'écran à la fois
Je suis nouveau dans le Développement Android. J'essaie d'afficher une liste de cartes dans l'écran avec une seule carte à la fois sur l'écran à l'aide RecyclerView. Mais, malheureusement, les cartes que j'ai conçu ne sommes pas remplir toute la largeur de l'écran comme prévu, comme vous pouvez le voir dans la image donné ci-dessous.
Comment je peux étirer ces cartes de remplir la totalité de l'écran (largeur sage, la hauteur est de les envelopper de contenu).
Est-il possible solution à ce problème?
Mon Code:
activity_sub.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<include
android:id="@+id/appBar"
layout="@layout/app_bar"/>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Horizontal Card List"
android:textSize="16sp"
android:padding="3dp"
android:background="#CCCCCC" />
<android.support.v7.widget.RecyclerView
android:id="@+id/hrlist_recycler_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:scrollbars="horizontal" />
</LinearLayout>
custom_card.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="wrap_content"
android:orientation="vertical"
android:padding="8dp"
android:tag="contains Cards main Container">
<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/card_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:elevation="10dp"
app:cardBackgroundColor="#B6B6B6">
<TextView
android:id="@+id/card_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:padding="20dp"
android:text="Card 1"
android:textSize="30sp" />
</android.support.v7.widget.CardView>
</LinearLayout>
SubActivity.java
package ab9.mamv.com.playground;
import android.os.Bundle;
import android.support.v4.app.NavUtils;
import android.support.v7.app.ActionBarActivity;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;
import java.util.ArrayList;
import java.util.List;
public class SubActivity extends ActionBarActivity {
Toolbar toolbar;
private RecyclerView mRecyclerView;
private SubActivityAdapter mAdapter;
private RecyclerView.LayoutManager mLayoutManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sub);
toolbar = (Toolbar) findViewById(R.id.appBar);
setSupportActionBar(toolbar);
getSupportActionBar().setHomeButtonEnabled(true);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
//RecyclerView
mRecyclerView = (RecyclerView) findViewById(R.id.hrlist_recycler_view);
mRecyclerView.setHasFixedSize(true);
mAdapter = new SubActivityAdapter(this, getData());
mRecyclerView.setAdapter(mAdapter);
//Layout manager for the Recycler View
mLayoutManager = new LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL, false);
mRecyclerView.setLayoutManager(mLayoutManager);
}
public static List<SubActivityData> getData() {
List<SubActivityData> subActivityData = new ArrayList<>();
String[] cardTitle = {
"Card 1",
"Card 2",
"Card 3",
"Card 4",
"Card 5",
"Card 6",
};
for (int i = 0; i < cardTitle.length; i++) {
SubActivityData current = new SubActivityData();
current.cardTitle = cardTitle[i];
subActivityData.add(current);
}
return subActivityData;
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
//Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_sub, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
//Handle action bar item clicks here. The action bar will
//automatically handle clicks on the Home/Up button, so long
//as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
if (id == android.R.id.home) {
NavUtils.navigateUpFromSameTask(this);
}
return super.onOptionsItemSelected(item);
}
}
SubActivityAdapter.java
package ab9.mamv.com.playground;
import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import java.util.Collections;
import java.util.List;
/**
* Created by Abhishek on 20-03-2015.
*/
public class SubActivityAdapter extends RecyclerView.Adapter<SubActivityAdapter.SubActivityViewHolder> {
private final LayoutInflater inflater;
List<SubActivityData> subActivityData = Collections.EMPTY_LIST;
public SubActivityAdapter(Context context, List<SubActivityData> subActivityData) {
inflater = LayoutInflater.from(context);
this.subActivityData = subActivityData;
}
@Override
public SubActivityViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = inflater.inflate(R.layout.custom_card, parent, false);
SubActivityViewHolder subActivityViewHolder = new SubActivityViewHolder(view);
return subActivityViewHolder;
}
@Override
public void onBindViewHolder(SubActivityViewHolder holder, int position) {
SubActivityData currentCard = subActivityData.get(position);
holder.title.setText(currentCard.cardTitle);
}
@Override
public int getItemCount() {
return subActivityData.size();
}
class SubActivityViewHolder extends RecyclerView.ViewHolder {
TextView title;
public SubActivityViewHolder(View itemView) {
super(itemView);
title = (TextView) itemView.findViewById(R.id.card_text);
}
}
}
Pourquoi ne pas utiliser une vue pager ici?
pratiquement, je vais créer 10-15 cartes ici, ça va être pratique ?
C'est l'ensemble de point de vue pager. il charge uniquement ce dont vous avez besoin, quand vous en avez besoin.
pratiquement, je vais créer 10-15 cartes ici, ça va être pratique ?
C'est l'ensemble de point de vue pager. il charge uniquement ce dont vous avez besoin, quand vous en avez besoin.
OriginalL'auteur aB9 | 2015-03-20
Vous devez vous connecter pour publier un commentaire.
Il suffit de changer votre onCreateViewHolder :
Vous pourriez avoir à travailler sur custom_card.xml après cette. Mais il devrait faire l'affaire.
OriginalL'auteur Rushikesh Gomekar
Si cette question et à bien d'autres questions similaires ont été posté depuis longtemps de retour, je n'ai pas trouvé de travail unique solution pour elle.
Voici une solution simple pour elle
Vous pouvez ajouter dx seuil pour plus attrayante swaps.
OriginalL'auteur Muthu Vignesh
Suivez le tutoriel ci-dessous, à l'exception de changer votre CardView largeur et la hauteur de "match_parent" et vous obtenez seulement une carte sur l'écran à un temps
https://knowledgecollisions.wordpress.com/2016/03/29/using-recyclerview-and-cardview-in-your-android-app/
OriginalL'auteur Neel Krishna