设备旋转时UIProgressView消失或不缩放

时间:2017-05-26 06:54:50

标签: ios xamarin.ios rotation scale uiprogressview

我正在使用Xamarin.IOS,我在UIScrollView中也有两个按钮的UIprogressView。

我在ViewWillLayoutSubviews方法中按代码设置UIprogressView框架:

        CGRect newFrame;
        newFrame.Width = MyScrollView.Frame.Width / 2;
        newFrame.Location = new CGPoint(0, NextButton.Frame.Y);
        MyProgressView.Frame = newFrame;
        MyProgressView.Transform = CGAffineTransform.MakeScale(1, 20f);
        MyProgressView.TrackTintColor = CustomColors.CustomColors.GetColor(CustomColors.CustomColors.ColorGray);
        MyProgressView.ProgressTintColor = CustomColors.CustomColors.GetColor(CustomColors.CustomColors.ColorBlue);

问题是当我将设备从纵向旋转到横向时,只有进度视图会消失。同时下一个按钮就在那里,进度视图和下一个按钮都有相同的Y!。

如果我停止使用MyProgressView.ProgressTintColor,我可以在轮换后看到进度视图,但不会缩放。

知道怎么解决吗?

这是我所说的UIProgressView:

enter image description here

2 个答案:

答案 0 :(得分:1)

在Helper文件夹中创建此UIProgressView文件

<强> LoadingOverlay.cs

public class LoadingOverlay : UIView
    {
        // control declarations
        UIActivityIndicatorView activitySpinner;
        UILabel loadingLabel;

    public LoadingOverlay(CGRect frame) : base(frame)
    {
        // configurable bits
        BackgroundColor = UIColor.Black;
        Alpha = 0.75f;
        AutoresizingMask = UIViewAutoresizing.All;

        nfloat labelHeight = 22;
        nfloat labelWidth = Frame.Width - 20;

        // derive the center x and y
        nfloat centerX = Frame.Width / 2;
        nfloat centerY = Frame.Height / 2;

        // create the activity spinner, center it horizontall and put it 5 points above center x
        activitySpinner = new UIActivityIndicatorView(UIActivityIndicatorViewStyle.WhiteLarge);
        activitySpinner.Frame = new CGRect(
            centerX - (activitySpinner.Frame.Width / 2),
            centerY - activitySpinner.Frame.Height - 20,
            activitySpinner.Frame.Width,
            activitySpinner.Frame.Height);
        activitySpinner.AutoresizingMask = UIViewAutoresizing.All;
        AddSubview(activitySpinner);
        activitySpinner.StartAnimating();

        // create and configure the "Loading Data" label
        loadingLabel = new UILabel(new CGRect(
            centerX - (labelWidth / 2),
            centerY + 20,
            labelWidth,
            labelHeight
            ));
        loadingLabel.BackgroundColor = UIColor.Clear;
        loadingLabel.TextColor = UIColor.White;
        loadingLabel.Text = "Loading Data...";
        loadingLabel.TextAlignment = UITextAlignment.Center;
        loadingLabel.AutoresizingMask = UIViewAutoresizing.All;
        AddSubview(loadingLabel);

    }

    /// <summary>
    /// Fades out the control and then removes it from the super view
    /// </summary>
    public void Hide()
    {
        UIView.Animate(
            0.5, // duration
            () => { Alpha = 0; },
            () => { RemoveFromSuperview(); }
        );
    }
}

并以这种方式使用

显示加载

var loadingOverlay = new LoadingOverlay(UIScreen.MainScreen.Bounds);
View.Add(loadingOverlay);

并隐藏它

loadingOverlay.Hide();

答案 1 :(得分:0)

我通过在每次旋转时重新缩放来修复它:

public override void WillAnimateRotation(UIInterfaceOrientation toInterfaceOrientation, double duration)
{
     progressView.Transform = CGAffineTransform.Scale(progressView.Transform,1, 20f);   
}