Version 4.10.0: Updated target framework versions. Cleanup of TypeConverters, ImageLoader, MBTileSource.

This commit is contained in:
ClemensF 2018-08-09 18:21:16 +02:00
parent 6a1653056f
commit acf43d70ea
8 changed files with 109 additions and 81 deletions

View file

@ -35,23 +35,39 @@ namespace MapControl
return imageSource;
}
public static async Task<bool> LoadHttpTileImageAsync(Uri uri, Func<IBuffer, TimeSpan?, Task> tileCallback)
public static async Task<Tuple<IBuffer, TimeSpan?>> LoadHttpBufferAsync(Uri uri)
{
using (var response = await HttpClient.GetAsync(uri))
Tuple<IBuffer, TimeSpan?> result = null;
try
{
if (!response.IsSuccessStatusCode)
using (var response = await HttpClient.GetAsync(uri))
{
Debug.WriteLine("ImageLoader: {0}: {1} {2}", uri, (int)response.StatusCode, response.ReasonPhrase);
}
else if (IsTileAvailable(response.Headers))
{
var buffer = await response.Content.ReadAsBufferAsync();
if (!response.IsSuccessStatusCode)
{
Debug.WriteLine("ImageLoader: {0}: {1} {2}", uri, (int)response.StatusCode, response.ReasonPhrase);
}
else
{
IBuffer buffer = null;
TimeSpan? maxAge = null;
await tileCallback(buffer, response.Headers.CacheControl?.MaxAge);
}
if (IsTileAvailable(response.Headers))
{
buffer = await response.Content.ReadAsBufferAsync();
maxAge = response.Headers.CacheControl?.MaxAge;
}
return response.IsSuccessStatusCode;
result = new Tuple<IBuffer, TimeSpan?>(buffer, maxAge);
}
}
}
catch (Exception ex)
{
Debug.WriteLine("ImageLoader: {0}: {1}", uri, ex.Message);
}
return result;
}
public static async Task<ImageSource> CreateImageSourceAsync(IRandomAccessStream stream)
@ -61,12 +77,14 @@ namespace MapControl
return bitmapImage;
}
private static async Task<InMemoryRandomAccessStream> GetResponseStreamAsync(IHttpContent content)
private static async Task<ImageSource> CreateImageSourceAsync(IHttpContent content)
{
var stream = new InMemoryRandomAccessStream();
await content.WriteToStreamAsync(stream);
stream.Seek(0);
return stream;
using (var stream = new InMemoryRandomAccessStream())
{
await content.WriteToStreamAsync(stream);
stream.Seek(0);
return await CreateImageSourceAsync(stream);
}
}
private static bool IsTileAvailable(HttpResponseHeaderCollection responseHeaders)

View file

@ -21,7 +21,7 @@ namespace MapControl
{
var bitmapImage = imageSource as BitmapImage;
if (bitmapImage != null && bitmapImage.UriSource != null)
if (bitmapImage?.UriSource != null)
{
bitmapImage.ImageOpened += BitmapImageOpened;
bitmapImage.ImageFailed += BitmapImageFailed;

View file

@ -3,7 +3,6 @@
// Licensed under the Microsoft Public License (Ms-PL)
using System;
using System.Diagnostics;
using System.Threading.Tasks;
using Windows.Storage;
using Windows.Storage.Streams;
@ -36,26 +35,24 @@ namespace MapControl
{
var cacheItem = await Cache.GetAsync(cacheKey);
var cacheBuffer = cacheItem?.Buffer;
var loaded = false;
if (cacheBuffer == null || cacheItem.Expiration < DateTime.UtcNow)
{
try
var result = await ImageLoader.LoadHttpBufferAsync(uri);
if (result != null) // download succeeded
{
loaded = await ImageLoader.LoadHttpTileImageAsync(uri,
async (buffer, maxAge) =>
{
await SetTileImageAsync(tile, buffer); // create BitmapImage before caching
await Cache.SetAsync(cacheKey, buffer, GetExpiration(maxAge));
});
}
catch (Exception ex)
{
Debug.WriteLine("TileImageLoader: {0}: {1}", uri, ex.Message);
cacheBuffer = null; // discard cached image
if (result.Item1 != null) // tile image available
{
await SetTileImageAsync(tile, result.Item1); // show before caching
await Cache.SetAsync(cacheKey, result.Item1, GetExpiration(result.Item2));
}
}
}
if (!loaded && cacheBuffer != null) // keep expired image if download failed
if (cacheBuffer != null)
{
await SetTileImageAsync(tile, cacheBuffer);
}