-
Notifications
You must be signed in to change notification settings - Fork 377
Advanced Usage
You can override global defaults by calling ImageService.Instance.Initialize
method in platform specific project. You can globally enable transparency channel, disable fade animation, specify own logger, timeouts and a lot more. *To use this method, you need to add a System.Net.Http
nuget package (PCL projects) or add a reference to System.Net.Http
(Android, iOS - Xamarin Studio: Edit references menu)
public static void Initialize(Configuration config)
Available configuration properties and their default values are here: Configuration.cs
By default FFImageLoading errors are logged to console. If you want to change that you can create a custom logger. Example:
public class CustomMiniLogger: IMiniLogger
{
public void Debug(string message)
{
}
public void Error(string errorMessage)
{
Insights.Report(ex);
}
public void Error(string errorMessage, Exception ex)
{
Insights.Report(ex, new Dictionary <string, string> { {"message", errorMessage} });
}
}
and instruct FFImageloading to use it in a platform specific project with:
ImageService.Instance.Initialize(logger: new CustomMiniLogger());
If you don't want to use the Retry() functionality but have your custom error handling/retry logic (for example: because you use Polly). Then you can use IntoAsync() instead of Into()
try {
// IntoAsync does not swallow exceptions so you should surround it with a try/catch
await ImageService.Instance.LoadUrl(urlToImage).IntoAsync(_imageView);
} catch (Exception ex) {
// do whatever you want...
}
If you want to stop pending loading requests. For example when your activity gets paused/resumed:
protected override void OnPause()
{
base.OnPause();
ImageService.Instance.SetExitTasksEarly(true);
}
protected override void OnResume()
{
base.OnResume();
ImageService.Instance.SetExitTasksEarly(false);
}
If you want to load many images in a scrollable list view or horizontal list view and you have performance issues while you fling. In our app with more than 1000 items in an horizontal list view it was the case. To solve it we used:
_myListView.ScrollStateChanged += (object sender, ScrollStateChangedEventArgs scrollArgs) => {
switch (scrollArgs.ScrollState)
{
case ScrollState.Fling:
ImageService.Instance.SetPauseWork(true); // all image loading requests will be silently canceled
break;
case ScrollState.Idle:
ImageService.Instance.SetPauseWork(false); // loading requests are allowed again
// Here you should have your custom method that forces redrawing visible list items
_myListView.ForcePdfThumbnailsRedraw();
break;
}
};
Customizing the loading logic is very easy: inherit from ImageLoaderTask, put your own logic, and then pass the instance to ImageService: ImageService.Instance.LoadImage(customImageTask)
.