A Xamarin.Forms demo that uses the Instagram API as a data source. Login with any Instagram account! 16 hours of development is all it took to get the app to its initial state of seven functional screens.
- Xamarin.iOS (I'm using 8.10.0.267)
- Xamarin.Android (I'm using 5.1.0.115)
- Xamarin.Forms 1.4 (I'm using 1.4.2.6359)
- Xamarin Studio or Visual Studio w/ Xamarin extensions (I used Xamarin Studio for this)
You'll need an Instagram account. Login via the web and go to https://instagram.com/developer/clients/manage/. There you can create a new set of client credentials for your app.
In the App.cs in the XamaGram project, you'll see a section where you can enter the Instagram Client ID and Redirect URL you just created.
XamarinAuthSettings =
new OAuthSettings(
clientId: "[your client id]",
scope: "basic",
authorizeUrl: "https://api.instagram.com/oauth/authorize/",
redirectUrl: "[your redirect url]");
That's it! You should now be able to build your app for either iOS or Android. The first time you login, Instagram will prompt you to authorize the app. This only happens once and occurs for any app that uses the Instagram API.
This project uses a portion of the InstaSharp project, a C# wrapper for the Instagram API. I found that their client implementation wasn't working for me, so I just borrowed their model classes and wrote my own simple lightweight HttpClient implementation for the Instagram API. InstaSharp source can be found here: https://github.com/InstaSharp/InstaSharp
- At this time, the app does not take advantage of pagination in the Instagram API, so it only loads a max of 30 images in each list (which is the maximum page size that Instagram prefers API consumers to adhere to).
- The image widths don't go the screen edges on some devices, and may be cut off on smaller devices. This will be remedied when I add some of the great Xamarin.Forms extensions from: https://github.com/XLabs/Xamarin-Forms-Labs
- The app currently does not store the Instagram API token in the device keychain, so you have to login each time the app starts.
- The app does not provide a logout function, so there is no way to logout besides "killing" the app.
- Add proper exception handling.
- Add network connectivity checking.
- Add Xamarin Insights integration point (optionally enabled).
- Add pagination to relevant InstagramClient methods to support more than 30 images in each list.
- (Possibly) add image pre-caching to eliminate "jumping" of images during scrolling, especially on slower networks.
- Add pull-to-refresh to relevant screens.
- Correct excessively large ActivityIndicator on Android
- Update login to store Instagram token in device keychain, thus avoiding the login prompt on each run of the app.
- Add logout functionality.
- Add an image detail page for displaying descriptions, likes, comments, time elapsed since post, etc.
- Add dropshadow to overlaid image labels (using Xamarin-Forms-Labs extension).
- Add the Xamarin-Forms-Labs extension that allows device-specific screen width detection at runtime.
- Add optional grid layouts for display of followers/following and image lists.
- Add navigation of followers/following user graph by extending the ProfilePage to be shown for users other than just the authenticated user. May involve a custom BindableProperty on ProfilePage, to facilitate use within a DataTemplate.