Лучший способ изменить цвет фона для NSView

Я ищу лучший способ изменить backgroundColor NSView. Я также хотел бы установить соответствующую маску alpha для NSView. Что-то вроде:

myView.backgroundColor = [NSColor colorWithCalibratedRed:0.227f 
                                                   green:0.251f 
                                                    blue:0.337 
                                                   alpha:0.8];

Я замечаю, что NSWindow имеет этот метод, и я не являюсь большим поклонником опций фона NSColorWheel или NSImage, но если они являются лучшими, желающими использовать.

Ответ 1

Да, твой собственный ответ был верным. Вы также можете использовать методы Cocoa:

- (void)drawRect:(NSRect)dirtyRect {
    // set any NSColor for filling, say white:
    [[NSColor whiteColor] setFill];
    NSRectFill(dirtyRect);
    [super drawRect:dirtyRect];
}

В Свифте:

class MyView: NSView {

    override func draw(_ dirtyRect: NSRect) {
        super.draw(dirtyRect)

        // #1d161d
        NSColor(red: 0x1d/255, green: 0x16/255, blue: 0x1d/255, alpha: 1).setFill()
        dirtyRect.fill()
    }

}

Ответ 2

Простым и эффективным решением является настройка представления для использования слоя Core Animation в качестве хранилища поддержки. Затем вы можете использовать -[CALayer setBackgroundColor:] для установки цвета фона слоя.

- (void)awakeFromNib {
   self.wantsLayer = YES;  // NSView will create a CALayer automatically
}

- (BOOL)wantsUpdateLayer {
   return YES;  // Tells NSView to call `updateLayer` instead of `drawRect:`
}

- (void)updateLayer {
   self.layer.backgroundColor = [NSColor colorWithCalibratedRed:0.227f 
                                                          green:0.251f 
                                                           blue:0.337 
                                                          alpha:0.8].CGColor;
}

Вот оно!

Ответ 3

Если вы любитель раскадровки, вот вам способ не нуждаться в какой-либо строке кода.

Добавьте NSBox в качестве поднабора в NSView и настройте рамку NSBox как то же самое с NSView.

В Storyboard или XIB измените положение заголовка на None, тип поля пользовательский, тип границы - "None", а цвет границы - на все, что вам нравится.

Вот скриншот:

введите описание изображения здесь

Это результат:

введите описание изображения здесь

Ответ 4

Если вы сначала установитеWantsLayer в YES, вы можете напрямую управлять фоном слоя.

[self.view setWantsLayer:YES];
[self.view.layer setBackgroundColor:[[NSColor whiteColor] CGColor]];

Ответ 5

Думаю, я понял, как это сделать:

- (void)drawRect:(NSRect)dirtyRect {
    // Fill in background Color
    CGContextRef context = (CGContextRef) [[NSGraphicsContext currentContext] graphicsPort];
    CGContextSetRGBFillColor(context, 0.227,0.251,0.337,0.8);
    CGContextFillRect(context, NSRectToCGRect(dirtyRect));
}

Ответ 6

Я прошел через все эти ответы, и, к сожалению, ни один из них не помог мне. Тем не менее, я нашел этот чрезвычайно простой способ, после часа поиска :)

myView.layer.backgroundColor = CGColorCreateGenericRGB(0, 0, 0, 0.9);

Ответ 7

изменить/обновить: Xcode 8.3.1 • Swift 3.1

extension NSView {
    var backgroundColor: NSColor? {
        get {
            guard let color = layer?.backgroundColor else { return nil }
            return NSColor(cgColor: color)
        }
        set {
            wantsLayer = true
            layer?.backgroundColor = newValue?.cgColor
        }
    }
}

использование:

let myView = NSView(frame: NSRect(x: 0, y: 0, width: 100, height: 100))
print(myView.backgroundColor ?? "none")     //  NSView background hasn't been set yet = nil
myView.backgroundColor = .red               // set NSView background color to red color
print(myView.backgroundColor ?? "none")
view.addSubview(myView)

Ответ 8

Лучшее решение:

- (id)initWithFrame:(NSRect)frame
{
    self = [super initWithFrame:frame];
    if (self)
    {
        self.wantsLayer = YES;
    }
    return self;
}

- (void)awakeFromNib
{
    float r = (rand() % 255) / 255.0f;
    float g = (rand() % 255) / 255.0f;
    float b = (rand() % 255) / 255.0f;

    if(self.layer)
    {
        CGColorRef color = CGColorCreateGenericRGB(r, g, b, 1.0f);
        self.layer.backgroundColor = color;
        CGColorRelease(color);
    }
}

Ответ 9

В Swift:

override func drawRect(dirtyRect: NSRect) {

    NSColor.greenColor().setFill()
    NSRectFill(dirtyRect)

    super.drawRect(dirtyRect)
}

Ответ 10

Используйте NSBox, который является подклассом NSView, что позволяет нам легко стилизовать

Swift 3

let box = NSBox()
box.boxType = .custom
box.fillColor = NSColor.red
box.cornerRadius = 5

Ответ 11

Я проверил следующее, и это сработало для меня (в Swift):

view.wantsLayer = true
view.layer?.backgroundColor = NSColor.blackColor().colorWithAlphaComponent(0.5).CGColor

Ответ 12

В Swift 3 вы можете создать расширение, чтобы сделать это:

extension NSView {
    func setBackgroundColor(_ color: NSColor) {
        wantsLayer = true
        layer?.backgroundColor = color.cgColor
    }
}

// how to use
btn.setBackgroundColor(NSColor.gray)

Ответ 13

Без сомнения, самый простой способ, также совместимый с Color Set Assets:

Свифт:

view.setValue(NSColor.white, forKey: "backgroundColor")

Цель-C:

[view setValue: NSColor.whiteColor forKey: "backgroundColor"];

Интерфейсный Разработчик:

Добавьте пользовательский атрибут backgroundColor в построителе интерфейса типа NSColor.

Ответ 14

Посмотрите RMSkinnedView. Вы можете установить цвет фона NSView из Interface Builder.

Ответ 15

В swift вы можете подклассифицировать NSView и сделать это

class MyView:NSView {
    required init?(coder: NSCoder) {
        super.init(coder: coder);

        self.wantsLayer = true;
        self.layer?.backgroundColor = NSColor.redColor().CGColor;
    }
}

Ответ 16

Просто маленький многоразовый класс (Swift 4.1)

class View: NSView {

   var backgroundColor: NSColor?

   convenience init() {
      self.init(frame: NSRect())
   }

   override func draw(_ dirtyRect: NSRect) {
      if let backgroundColor = backgroundColor {
         backgroundColor.setFill()
         dirtyRect.fill()
      } else {
         super.draw(dirtyRect)
      }
   }
}

// Usage
let view = View()
view.backgroundColor = .white