Icona di caricamento per schermo di layout Xamarin Android
-
21-12-2019 - |
Domanda
Voglio scoprire se ci sono buone idee / tutorial su come aggiungere il caricamento GIF a un layout Android quando si verifica e quando un layout di pagina naviga su un'altra layout di pagina.
Ho provato a usare questo - andhud
Ma sembra che non funzioni bene con le biblioteche di classe portale (PCL) e servizi all'interno del PCL.Non sono riuscito a trovare un sacco di esempi con questo componente.
Vedo Android utilizza una finestra di dialogo di avanzamento per questo, ma speravo in una versione Xamarin in C # o qualsiasi altro modo intelligente di fare questo.
Soluzione
Aggiungi Andhud al progetto Android e BtprogressHud al tuo progetto iOS.
Quindi devi solo creare un'interfaccia in PCL come questa:
public enum MaskType
{
None = 1,
Clear,
Black,
Gradient
}
public interface IHudService
{
void Show(string message, MaskType maskType, int progress = -1);
void Dismiss();
void ShowToast(string message, bool showToastCentered = true, double timeoutMs = 1000);
void ShowToast(string message, MaskType maskType, bool showToastCentered = true, double timeoutMs = 1000);
}
.
e implementazioni concrete in ciascuno dei progetti (esempio IOS):
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using BigTed;
using Foundation;
using MyExample.Services;
using UIKit;
[assembly: Xamarin.Forms.Dependency(typeof(MyExample.iOS.Services.HudService))]
namespace MyExample.iOS.Services
{
public class HudService : IHudService
{
public HudService()
{
}
#region IHudService Members
public void Show(string message, MaskType maskType, int progress)
{
float p = (float)progress / 100f;
BTProgressHUD.Show(message, p, (ProgressHUD.MaskType)maskType);
}
public void Dismiss()
{
BTProgressHUD.Dismiss();
}
public void ShowToast(string message, bool showToastCentered = true, double timeoutMs = 1000)
{
BTProgressHUD.ShowToast(message, showToastCentered, timeoutMs);
}
public void ShowToast(string message, MaskType maskType, bool showToastCentered = true, double timeoutMs = 1000)
{
BTProgressHUD.ShowToast(message, (ProgressHUD.MaskType)maskType, showToastCentered, timeoutMs);
}
#endregion
}
}
.
E, su Android:
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 AndroidHUD;
using MyExample.Services;
using Xamarin.Forms;
using XHUD;
[assembly: Xamarin.Forms.Dependency(typeof(MyExample.Android.Services.HudService))]
namespace MyExample.Android.Services
{
public class HudService : IHudService
{
//Although, not well documented, for Xamarin.Forms, "Forms.Context" is the current activity
public HudService()
{
}
#region IHudService Members
public void Show(string message, MyExample.Services.MaskType maskType, int progress)
{
AndHUD.Shared.Show(Forms.Context, message, progress, (AndroidHUD.MaskType)maskType);
}
public void Dismiss()
{
AndHUD.Shared.Dismiss(Forms.Context);
}
public void ShowToast(string message, bool showToastCentered = true, double timeoutMs = 1000)
{
AndHUD.Shared.ShowToast(Forms.Context, message, (AndroidHUD.MaskType)MyExample.Services.MaskType.Black, TimeSpan.FromSeconds(timeoutMs / 1000), showToastCentered);
}
public void ShowToast(string message, MyExample.Services.MaskType maskType, bool showToastCentered = true, double timeoutMs = 1000)
{
AndHUD.Shared.ShowToast(Forms.Context, message, (AndroidHUD.MaskType)maskType, TimeSpan.FromSeconds(timeoutMs / 1000), showToastCentered);
}
#endregion
}
}
.
Questa è fondamentalmente solo una copia della facciata XHUD.HUD che è stata aggiunta a entrambe le biblioteche di lisciare le differenze API.
Quindi, registra il tuo servizio nel punto di ingresso per i progetti specifici della piattaforma (in questo caso, AppDelegate.cs) e chiamalo dal PCL.Nel mio caso, sto usando Xamarin.Forms.Labs quindi il tuo metodo di registrazione può variare.
public override bool FinishedLaunching(UIApplication app, NSDictionary options)
{
SetupIocContainer();
Forms.Init();
FormsMaps.Init();
window = new UIWindow(UIScreen.MainScreen.Bounds);
window.RootViewController = App.GetMainPage().CreateViewController();
window.MakeKeyAndVisible();
return true;
}
private void SetupIocContainer()
{
var resolverContainer = new SimpleContainer();
var app = new XFormsAppiOS();
app.Init(this);
resolverContainer.Register<IDevice>(t => AppleDevice.CurrentDevice)
.Register<IDisplay>(t => t.Resolve<IDevice>().Display)
//EDIT: this does not seem necessary after all and actually
//causes it to crash on Android (but works on iOS)
//not sure why
//.Register<IHudService>(t => t.Resolve<IHudService>())
.Register<IXFormsApp>(app)
.Register<IDependencyContainer>(t => resolverContainer);
Resolver.SetResolver(resolverContainer.GetResolver());
}
.
In PCL, puoi istanziarlo e fare qualcosa del genere:
private IHudService hudService;
public IHudService HudService
{
get
{
if(hudService == null)
{
hudService = DependencyService.Get<IHudService>();
}
return this.hudService;
}
}
private async Task Setup()
{
this.HudService.Show("Long operation occurring", MaskType.Black);
await Operation();
this.HudService.Dismiss();
}
.