Слайдер изображений с использованием View Pager с адаптером пейджера в Xamarin Android C # - PullRequest
0 голосов
/ 30 мая 2018

Я пытаюсь создать imageslider, используя viewpager с pageradapter.Все выглядит нормально, но когда я запускаю его, я получаю сообщение об ошибке и появляется сообщение «System.NullReferenceException: ссылка на объект не установлена ​​для экземпляра объекта».Я не знаю что делатьЯ пытаюсь добавить переопределение в моем объекте в моем адаптере, но все еще получаю ошибку.

Вот мои коды:

SlidingImage_Adapter.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Android.App;
using Android.Content;
using Android.OS;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.Util;
using Java.Lang;
using Android.Support.V4.View;
using Square.Picasso;

    namespace EFCAndroid
    {
        public class SlidingImage_Adapter : PagerAdapter
        {
            private int[] gridViewImage = { Resource.Drawable.cheese_1, Resource.Drawable.cheese_2, Resource.Drawable.cheese_3 };
            private LayoutInflater layoutInflater;
            private Context context;



            public SlidingImage_Adapter(Context context)
            {
                this.context = context;
                //this.gridViewImage = gridViewImage;
                //inflater = LayoutInflater.From(context);
            }


            public override int Count
            {
                get
                {
                    return gridViewImage.Length;
                }
            }

            public override bool IsViewFromObject(View view, Java.Lang.Object objects)
            {
                return view == objects;
            }

            public override Java.Lang.Object InstantiateItem(ViewGroup container, int position)
            {
                layoutInflater = (LayoutInflater)context.GetSystemService(Context.LayoutInflaterService);
                View view = layoutInflater.Inflate(Resource.Layout.slidingimages_layout, null);

                    ImageView imageview = view.FindViewById<ImageView>(Resource.Id.imageView);
                    Picasso.With(context)
                           .Load((gridViewImage[position]))
                           .Into(imageview);

                    ViewPager vp = (ViewPager)container;
                    vp.AddView(view, 0);


                return view;
            }

            public void destroyItem(ViewGroup container, int position, Java.Lang.Object objects)
            {
                ViewPager vp = (ViewPager)container;
                View view = (View)objects;
                vp.RemoveView(view);
            }


        }
    }

Activity_EFC_CHICKEN_TERIYAKI.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Android.App;
using Android.Content;
using Android.OS;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using SupportToolbar = Android.Support.V7.Widget.Toolbar;
using Android.Support.V7.App;
using Android.Support.Design.Widget;
using Android.Support.V4.Widget;
using Android.Support.V4.View;

namespace EFCAndroid
{
    [Activity(Label = "Activity_EFC_CHICKEN_TERIYAKI", Theme = "@style/Theme.DesignDemo")]
    public class Activity_EFC_CHICKEN_TERIYAKI : AppCompatActivity
    {
        private SupportToolbar mToolbar;
        ViewPager viewPager;
        protected override void OnCreate(Bundle savedInstanceState)
        {
            base.OnCreate(savedInstanceState);
            SetContentView(Resource.Layout.activity_efc_chicken_teriyaki);
            // Create your application here

            mToolbar = FindViewById<SupportToolbar>(Resource.Id.toolbar);

            SetSupportActionBar(mToolbar);
            SupportActionBar.Title = "EFC Chicken Teriyaki";
            SupportActionBar.SetDisplayHomeAsUpEnabled(true);
            SupportActionBar.SetDisplayShowHomeEnabled(true);

            viewPager = FindViewById<ViewPager>(Resource.Id.viewpager);
            SlidingImage_Adapter slideimageadapter = new SlidingImage_Adapter(this);
            viewPager.Adapter = slideimageadapter;

        }

        public override bool OnOptionsItemSelected(IMenuItem item)
        {
            switch(item.ItemId)
            {
                case Android.Resource.Id.Home:
                    Finish();
                    return true;
                default:
                    return base.OnOptionsItemSelected(item);
            }
        }
    }
}

А вот мои макеты:

slideimages_layout.axml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
  <ImageView
    android:id="@+id/imageView"
    android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:adjustViewBounds="true"
        android:layout_gravity="center"
        android:scaleType="centerCrop"/>

</LinearLayout>

activity_efc_chicken_terriyaki.axml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:fitsSystemWindows="true">
  <android.support.v7.widget.Toolbar
      android:id="@+id/toolbar"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:minHeight="?android:attr/actionBarSize"
      android:background="?android:attr/colorPrimary"
      app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
      app:popupTheme="@style/ThemeOverlay.AppCompat.Dark"
      android:theme="@style/ThemeOverlay.AppCompat.Dark" />
  <android.support.v4.widget.DrawerLayout
      android:id="@+id/drawer_layout"
      android:layout_width="match_parent"
      android:layout_height="match_parent">
    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
      <android.support.v4.view.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

      </android.support.v4.view.ViewPager>

    </RelativeLayout>
  </android.support.v4.widget.DrawerLayout>
</LinearLayout>

1 Ответ

0 голосов
/ 31 мая 2018

Я решил это самостоятельно.Ошибка была неправильной, установите contentview внизу savedInstanceState.

...