CardView 不在披萨片段中显示图片

Posted

技术标签:

【中文标题】CardView 不在披萨片段中显示图片【英文标题】:CardView doesn't show a picture in fragment of pizza 【发布时间】:2021-09-20 21:51:07 【问题描述】:

我正在从书中学习 android studio。我想要 CardView 和 RecyclerView。 我有我的代码,但 cardView 没有显示图片。它仅显示带有文本的 empy CardView。 喜欢这里 -> enter image description here 谁能告诉我怎么了?

我的适配器

public class CaptionedImagesAdapter extends
        RecyclerView.Adapter<CaptionedImagesAdapter.ViewHolder> 

    private String[] captions;
    private int[] imageIds;




        public CaptionedImagesAdapter(String [] captions, int [] imageIds)
        this.captions = captions;
        this.imageIds = imageIds;
    

    public int getItemCount()
        return captions.length;
    

    public CaptionedImagesAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType)
        CardView cv =  (CardView)LayoutInflater.from(parent.getContext())
                .inflate(R.layout.card_captioned_image, parent, false);
        return new ViewHolder(cv);
    

    public void onBindViewHolder(CaptionedImagesAdapter.ViewHolder holder, int position)
        final CardView cardView = holder.cardView;
        ImageView imageView = (ImageView)cardView.findViewById(R.id.info_image);
        Drawable drawable =
                ContextCompat.getDrawable(cardView.getContext(), imageIds[position]);
        imageView.setImageDrawable(drawable);
        imageView.setContentDescription(captions[position]);
        TextView textView = (TextView)cardView.findViewById(R.id.info_text);
        textView.setText(captions[position]);
    

    public static class ViewHolder extends RecyclerView.ViewHolder
        private CardView cardView;

        public ViewHolder(CardView v)
            super(v);
            cardView = v;
        
    



mainActivity 中包含的片段

public class PizzaFragment extends Fragment 





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

        RecyclerView pizzaRecycler = (RecyclerView)inflater.inflate(
                R.layout.fragment_pizza, container, false);

        String[] pizzaNames = new String[Pizza.pizzas.length];
        for(int i =0; i < pizzaNames.length; i++)
            pizzaNames[i] = Pizza.pizzas[i].getName();
        

        int[] pizzaImages = new int[Pizza.pizzas.length];
        for(int i=0; i< pizzaImages.length; i++)
            pizzaImages[i] = Pizza.pizzas[i].getImageResourceId();
        

        CaptionedImagesAdapter adapter =
                new CaptionedImagesAdapter(pizzaNames, pizzaImages);

        GridLayoutManager layoutManager = new GridLayoutManager(getActivity(), 2);
        pizzaRecycler.setLayoutManager(layoutManager);
        pizzaRecycler.setAdapter(adapter);



                return pizzaRecycler;
    

片段的xml

<?xml version="1.0" encoding="utf-8"?>
    <androidx.recyclerview.widget.RecyclerView
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/pizza_recycler"
        android:layout_
        android:layout_
        android:scrollbars="vertical"/>

我的主要活动

public class MainActivity extends AppCompatActivity 



    private ViewPager2 viewPager;
    private FragmentStateAdapter pagerAdapter;
    private ShareActionProvider shareActionProvider;
    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar)findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        viewPager = findViewById(R.id.pager);
        pagerAdapter = new ScreenSlidePagerAdapter(this);
        viewPager.setAdapter(pagerAdapter);

        CharSequence homeTab0 = getResources().getText(R.string.home_tab);
        CharSequence homeTab1 = getResources().getText(R.string.pizza_tab);
        CharSequence homeTab2 = getResources().getText(R.string.psata_tab);
        CharSequence homeTab3 = getResources().getText(R.string.store_tab);

        String [] titles = new String[]
                String.valueOf(homeTab0),
                String.valueOf(homeTab1),
                String.valueOf(homeTab2),
                String.valueOf(homeTab3)
        ;

        TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
        new TabLayoutMediator(tabLayout, viewPager,(tab, position) ->
            tab.setText(titles[position])).attach();


    



    public boolean onCreateOptionsMenu(Menu menu)

        getMenuInflater().inflate(R.menu.menu_main, menu);
        MenuItem menuItem = menu.findItem(R.id.action_share);
        shareActionProvider = (ShareActionProvider) MenuItemCompat.getActionProvider(menuItem);
        setShareActionIntent("Umowimy sie na pizze?");
        return super.onCreateOptionsMenu(menu);
    

    private void setShareActionIntent(String text)
        Intent intent = new Intent(Intent.ACTION_SEND);
        intent.setType("text/plain");
        intent.putExtra(Intent.EXTRA_TEXT, text);
        shareActionProvider.setShareIntent(intent);
    

    public boolean onOptionsItemSelected(MenuItem item)
        switch(item.getItemId())
            case R.id.action_create_order:
                Intent intent = new Intent(this, OrderActivity.class);
                startActivity(intent);
                return true;
            default:
                return super.onOptionsItemSelected(item);
        
    

    private class ScreenSlidePagerAdapter extends FragmentStateAdapter 
        public ScreenSlidePagerAdapter(FragmentActivity fm) 
            super(fm);
        



        public int getItemCount()
            return 4;
        

        public Fragment createFragment(int position)
            switch (position)
                case 0:
                    return new TopFragment();
                case 1:
                    return  new PizzaFragment();
                case 2:
                    return new StoresFragment();

                case 3:
                    return new PastaFragment();

            
            return null;
        


    

    public void onBackPressed() 
        if (viewPager.getCurrentItem() == 0) 
// If the user is currently looking at the first step, allow the system to handle the
            // Back button. This calls finish() on this activity and pops the back stack.d
            super.onBackPressed();
         else 
// Otherwise, select the previous step.
            viewPager.setCurrentItem(viewPager.getCurrentItem() - 1);
        
    

MainActivity的xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout 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_
    android:layout_


    tools:context=".MainActivity">



    <com.google.android.material.appbar.AppBarLayout
        android:layout_
        android:layout_
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <androidx.appcompat.widget.Toolbar
            android:id="@+id/toolbar"
            app:layout_scrollFlags="scroll|enterAlways"
            android:layout_
            android:layout_

            />
        <com.google.android.material.tabs.TabLayout
            android:id="@+id/tabs"
            android:layout_
            android:layout_/>

    </com.google.android.material.appbar.AppBarLayout>



    <androidx.viewpager2.widget.ViewPager2
        android:id="@+id/pager"
        android:layout_
        android:layout_
        app:layout_behavior="@string/appbar_scrolling_view_behavior"

        />

</androidx.coordinatorlayout.widget.CoordinatorLayout>

我的数据类

public class Pizza 
    private String name;
    private int imageResourceId;

    public static final Pizza[] pizzas =
            new Pizza("Diavolo9999", R.drawable.diavolo),
            new Pizza("Fungi", R.drawable.funghi)
    ;

    public  Pizza(String name, int imageResourceId)
        this.name = name;
        this.imageResourceId = imageResourceId;
    

    public String getName()
        return name;
    

    public int getImageResourceId()
        return imageResourceId;
    


卡片xml

<?xml version="1.0" encoding="utf-8"?>
    <androidx.cardview.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_
    android:layout_
    android:layout_margin="4dp"
    card_view:cardElevation="2dp"
    card_view:cardCornerRadius="4dp">

    <LinearLayout
        android:layout_
        android:layout_
        android:orientation="vertical">

        <ImageView
            android:id="@+id/info_image"
            android:layout_
            android:layout_
            android:layout_weight="1.0"
            android:scaleType="centerCrop"/>

        <TextView
            android:id="@+id/info_text"
            android:layout_marginLeft="4dp"
            android:layout_marginBottom="4dp"
            android:layout_
            android:layout_/>

    </LinearLayout>

</androidx.cardview.widget.CardView>

【问题讨论】:

【参考方案1】:

您的ImageView 高度为零!如果你想使用LinearLayout,那么你可以将你的卡片xml更改为:

<?xml version="1.0" encoding="utf-8"?>
<androidx.cardview.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_
android:layout_
android:layout_margin="4dp"
card_view:cardCornerRadius="4dp"
card_view:cardElevation="2dp">

<LinearLayout
    android:layout_
    android:layout_
    android:orientation="vertical">

    <ImageView
        android:id="@+id/info_image"
        android:layout_
        android:layout_
        android:layout_weight="1.0"
        android:scaleType="centerCrop" />

    <TextView
        android:id="@+id/info_text"
        android:layout_
        android:layout_
        android:layout_marginLeft="4dp"
        android:layout_marginBottom="4dp"
        android:layout_weight="1.0" />
</LinearLayout>
</androidx.cardview.widget.CardView>

【讨论】:

以上是关于CardView 不在披萨片段中显示图片的主要内容,如果未能解决你的问题,请参考以下文章

VB.NET:PictureBox 视图范围?

如何在Android中加载带有动画的cardview GridView?

如何用CSS使图片自适应显示宽度

android如何在imageview控件上绘制点

android开发中imageview能显示gif动画吗

CardView 在我的片段上不能完全滚动