In Xamarin, I have an Activity that has a GridView and a list of image web addresses. A list of Bitmap objects are retrieved and then displayed in the GridView from these web addresses.
Here is my MainActivity code:
public class MainActivity : Activity
{
GridView gridView;
List<String> bitmapUris;
List<Bitmap> gridViewItems;
protected override void OnCreate (Bundle bundle)
{
base.OnCreate (bundle);
SetContentView (Resource.Layout.Main);
gridView = FindViewById<GridView>(Resource.Id.gridView);
bitmapUris = new List<string> ();
bitmapUris.Add ("http://images4.fanpop.com/image/photos/15000000/My-Sample-Pictures-lexi-and-sophie-15061826-1024-768.jpg");
bitmapUris.Add ("http://www.cameraegg.org/wp-content/uploads/2013/08/AF-S-DX-NIKKOR-18-140mm-f-3.5-5.6G-ED-VR-sample-images-1.jpg");
bitmapUris.Add ("http://upload.wikimedia.org/wikipedia/en/5/5d/The_Samples-Outpost.jpg");
bitmapUris.Add ("http://www.1800postcards.com/images/samples/sample_kits2.jpg");
gridViewItems = GetBitmapImages (bitmapUris);
gridView.Adapter = new GridViewAdapter (this, gridViewItems);
}
List<Bitmap> GetBitmapImages(List<String> bitmapUris)
{
List<Bitmap> images = new List<Bitmap> ();
Bitmap image;
foreach (var uri in bitmapUris)
{
image = GetImageBitmapFromUri (uri);
images.Add (image);
}
return images;
}
private Bitmap GetImageBitmapFromUri(string uri)
{
Bitmap imageBitmap = null;
using (var webClient = new WebClient())
{
var imageBytes = webClient.DownloadData(uri);
if (imageBytes != null && imageBytes.Length > 0)
{
imageBitmap = BitmapFactory.DecodeByteArray(imageBytes, 0, imageBytes.Length);
}
}
return imageBitmap;
}
}
Here is my GridViewAdapter code:
public class GridViewAdapter : BaseAdapter
{
Activity context;
List<Bitmap> gridViewtems;
public GridViewAdapter (Activity context, List<Bitmap> gridViewtems)
{
this.context = context;
this.gridViewtems = gridViewtems;
}
public override int Count {
get { return gridViewtems.Count; }
}
public override Java.Lang.Object GetItem (int position)
{
return null;
}
public override long GetItemId (int position)
{
return 0;
}
public override View GetView (int position, View convertView, ViewGroup parent)
{
View view = convertView;
if (view == null)
view = context.LayoutInflater.Inflate(Resource.Layout.GridViewItemWithImageAndText, null);
view.FindViewById<ImageView> (Resource.Id.image).SetImageBitmap (gridViewtems[position]);
view.FindViewById<TextView> (Resource.Id.text).Text = position.ToString();
return view;
}
}
Currently, when the application loads up, the screen goes blank until the Bitmaps are retrieved from the web addresses.
My question is this: How can I display the Activity with place holders for the GridView items, and when each Bitmap is retrieved, the relevant GridView item image is populated?
Is this done in the MainActivity, or in the GridViewAdapter?
Thanks in advance