首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >UISlider扭曲圆角

UISlider扭曲圆角
EN

Stack Overflow用户
提问于 2014-11-04 15:02:23
回答 2查看 2.7K关注 0票数 2

我创建了一个UISlider,然后像这样设置min track的色调颜色:

代码语言:javascript
复制
    [slider setMinimumTrackTintColor:[UIColor whiteColor]];

然而,我最终在左边得到了扭曲的圆角,就像这样。我该怎么做?

编辑:以下是重现该问题的代码:

代码语言:javascript
复制
UISlider *slider = [[UISlider alloc] initWithFrame:CGRectMake(40, 40, 180, 50)];

[slider setMinimumTrackTintColor:[UIColor whiteColor]];
EN

回答 2

Stack Overflow用户

发布于 2019-01-21 11:31:13

我在增加滑块高度时遇到了同样的错误。

随着滑块高度的增加,滑块的边缘失去了圆角。为了解决这个问题,我创建了带有圆角的图像,并将其分配给滑块最小轨迹图像。

Swift

代码语言:javascript
复制
 override func viewDidLoad() {
        super.viewDidLoad()

        slider.maximumTrackTintColor = UIColor.gray;

        let img:UIImage = GetImage(rectToDraw: CGRect(x: 0, y: 0, width: 400, height: 400));

        slider.setMinimumTrackImage(img.resizableImage(withCapInsets: UIEdgeInsets(top: 13,left: 15,bottom: 15,right: 14)), for: UIControlState.normal)
        slider.setMinimumTrackImage(img.resizableImage(withCapInsets: UIEdgeInsets(top: 13,left: 15,bottom: 15,right: 14)), for: UIControlState.selected)
    }

    func GetImage(rectToDraw:CGRect) -> UIImage {

        let layer:CALayer =  CALayer()
        layer.frame = rectToDraw;
        layer.cornerRadius = 20;
        layer.backgroundColor = UIColor.red.cgColor;
        UIGraphicsBeginImageContext(layer.frame.size)
        layer.render(in: UIGraphicsGetCurrentContext()!)
        let  image :UIImage = UIGraphicsGetImageFromCurrentImageContext()!
        UIGraphicsEndImageContext()
        return image;
    }

Xamarin.iOS

在自定义渲染器中

代码语言:javascript
复制
 protected override void OnElementChanged(ElementChangedEventArgs<Slider> e)
            {
                MySlideriOS sliderIos = new MySlideriOS();
                SetNativeControl(sliderIos);
                base.OnElementChanged(e);
            }

在自定义滑块中

代码语言:javascript
复制
 public class MySlideriOS : UISlider
    {
        public UILabel label = null;

        public MySlideriOS()
        {

             this.MaximumTrackTintColor = UIColor.Gray;

            UIImage img = GetImage(new CGRect(0,0,400,400));

            this.SetMinTrackImage(img.CreateResizableImage(new UIEdgeInsets(13, 15, 15,14)), UIControlState.Normal);
            this.SetMinTrackImage(img.CreateResizableImage(new UIEdgeInsets(13, 15, 15, 14)), UIControlState.Selected);


            this.MaxValue = 15;
        }
 public UIImage GetImage(CGRect recttoDraw)
        {
            CGRect rect = recttoDraw;

            CALayer layer = new CALayer();
            layer.Frame = recttoDraw;
            layer.CornerRadius = 20;
            layer.BackgroundColor = UIColor.Red.CGColor;
            UIGraphics.BeginImageContext(layer.Frame.Size);
            layer.RenderInContext(UIGraphics.GetCurrentContext());
            UIImage image = UIGraphics.GetImageFromCurrentImageContext();
            UIGraphics.EndImageContext();
            return image;

        }
票数 2
EN

Stack Overflow用户

发布于 2015-02-04 00:57:40

我也遇到过同样的问题,并找到了一个解决方案,即根据颜色为滑块添加一个minimumTrackImage。

代码语言:javascript
复制
UIImage *black = [UIImage imageWithColor:[UIColor blackColor]];
[self.slider setMinimumTrackImage:black forState:UIControlStateNormal];

使用以下方法添加一个UIImage类别- imageWithColor

代码语言:javascript
复制
+ (UIImage *)imageWithColor:(UIColor *)color {
    CGRect rect = CGRectMake(0.0f, 0.0f, 1.0, 1.0);
    UIGraphicsBeginImageContext(rect.size);
    CGContextRef context = UIGraphicsGetCurrentContext();

    CGContextSetFillColorWithColor(context, [color CGColor]);
    CGContextFillRect(context, rect);

    UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();

    return image;
}
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26729402

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档