I am using Xamarin and this is my second attempt at getting a ViewPager working. I have created an application from scratch with reference to this web link: http://looksok.wordpress.com/2013/10/26/android-support-v4-viewpager-tutorial-including-source-code/
The application compiles, deploys, but only a blank, black screen is displayed.
Here is my full code:
MainActivity.cs
using System;
using Android.App;
using Android.Content;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;
using Android.Support.V4.App;
using Android.Support.V4.View;
namespace AndroidViewPagerTutorial
{
[Activity (Label = "AndroidViewPagerTutorial", MainLauncher = true)]
public class MainActivity : FragmentActivity
{
protected override void OnCreate (Bundle bundle)
{
base.OnCreate (bundle);
SetContentView (Resource.Layout.activity_main);
MyPagerAdapter pageAdapter = new MyPagerAdapter(SupportFragmentManager);
var pager = FindViewById<ViewPager>(Resource.Id.myViewPager);
pager.Adapter = pageAdapter;
pager.SetCurrentItem (0, true);
}
}
}
MyPagerAdapter.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.Support.V4.App;
namespace AndroidViewPagerTutorial
{
public class MyPagerAdapter : FragmentPagerAdapter {
private List<Android.Support.V4.App.Fragment> fragments;
int fragmentCount;
public MyPagerAdapter(Android.Support.V4.App.FragmentManager fm) : base(fm)
{
this.fragments = new List<Android.Support.V4.App.Fragment>();
fragments.Add(new FragmentOrange());
fragments.Add(new FragmentGreen());
fragments.Add(new FragmentRed());
fragmentCount = fragments.Count;
}
#region implemented abstract members of PagerAdapter
public override int Count
{
get
{
return fragmentCount;
}
}
#endregion
#region implemented abstract members of FragmentPagerAdapter
public override Android.Support.V4.App.Fragment GetItem (int position)
{
return fragments[position];
}
#endregion
}
}
FragmentOrange.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.Util;
using Android.Views;
using Android.Widget;
namespace AndroidViewPagerTutorial
{
public class FragmentOrange : Android.Support.V4.App.Fragment
{
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.Inflate(Resource.Layout.fragment_orange, container, false);
return view;
}
}
}
fragment_green.axml
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.Util;
using Android.Views;
using Android.Widget;
namespace AndroidViewPagerTutorial
{
public class FragmentGreen : Android.Support.V4.App.Fragment
{
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.Inflate(Resource.Layout.fragment_green, container, false);
return view;
}
}
}
fragment_red.axml
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.Util;
using Android.Views;
using Android.Widget;
namespace AndroidViewPagerTutorial
{
public class FragmentRed : Android.Support.V4.App.Fragment
{
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.Inflate(Resource.Layout.fragment_red, container, false);
return view;
}
}
}
activity_main.axml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<android.support.v4.view.ViewPager
android:id="@+id/myViewPager"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</RelativeLayout>
fragment_orange.axml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent" />
fragment_green.axml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/holo_green_dark" />
fragment_red.axml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/holo_red_light" />
May I please have some help to get this working?
Thanks in advance
I have got the code working.
This is what needed to be changed for each fragment:
public override View OnCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With