개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.07.10 22:10

UIDrawBrushGradient::addStop 관련 질문

목록
  • 컴파일러수집가 5일 전 2025.07.10 22:10
  • 27
    1
안녕하세요 선생님. 저는 UIDrawBrushGradient::addStop 관련하여 질문을 드리겠습니다.

저는 iOS 개발을 공부중에 있으며, Gradient Brush를 사용하여 뷰의 배경을 gradient로 변경하고자 합니다.

Gradient Brush를 사용하여 배경을 gradient로 변경하는 코드는 다음과 같습니다.
swift

let gradient = UIDrawBrushGradient()

gradient.colors = [UIColor.red, UIColor.blue]

gradient.locations = [0, 1]

view.layer.backgroundColor = gradient.cgColor


위의 코드를 실행하였으나, Gradient의 색상이 정상적으로 나타나지 않습니다.

Gradient의 색상이 정상적으로 나타나지 않는 이유는 무엇이며, 이를 해결하는 방법은 무엇입니까?

또한, Gradient의 색상을 변경하고자 할 때, addStop() 메서드를 사용하는 방법을 알려주시면 감사하겠습니다.

다음은 addStop() 메서드를 사용하여 Gradient의 색상을 변경하는 코드입니다.
swift

gradient.addStop(at: 0, color: UIColor.red)

gradient.addStop(at: 0.5, color: UIColor.blue)

gradient.addStop(at: 1, color: UIColor.red)


위의 코드를 실행하였으나, Gradient의 색상이 정상적으로 나타나지 않습니다.

Gradient의 색상이 정상적으로 나타나지 않는 이유는 무엇이며, 이를 해결하는 방법은 무엇입니까?

또한, addStop() 메서드를 사용하여 Gradient의 색상을 변경하는 방법에 대한 설명을 알려주시면 감사하겠습니다.

감사합니다.

    댓글목록

    profile_image
    나우호스팅  5일 전



    먼저, Gradient Brush를 사용하여 배경을 gradient로 변경하는 코드에서 문제가 발생하는 이유는 UIDrawBrushGradient 클래스가 deprecated 되었기 때문입니다. 대신 CGGradient 클래스를 사용해야 합니다.

    다음은 CGGradient 클래스를 사용하여 배경을 gradient로 변경하는 코드입니다.

    #hostingforum.kr
    swift
    
    let gradient = CGGradient(colorsSpace: CGColorSpaceCreateDeviceRGB(), colors: [UIColor.red.cgColor, UIColor.blue.cgColor], locations: [0, 1])!
    
    view.layer.backgroundColor = UIColor.clear.cgColor
    
    view.layer.contents = UIGraphicsImageRenderer(size: view.bounds.size).image { _ in
    
        UIGraphicsGetCurrentContext()!.scaleBy(x: 1, y: -1)
    
        UIGraphicsGetCurrentContext()!.translateBy(x: 0, y: -view.bounds.height)
    
        UIGraphicsGetCurrentContext()!.drawLinearGradient(gradient, start: CGPoint(x: 0, y: 0), end: CGPoint(x: 1, y: 0), options: [])
    
    }
    
    


    위의 코드를 실행하여 Gradient의 색상이 정상적으로 나타나게 됩니다.

    addStop() 메서드를 사용하여 Gradient의 색상을 변경하는 방법은 다음과 같습니다.

    #hostingforum.kr
    swift
    
    let gradient = CGGradient(colorsSpace: CGColorSpaceCreateDeviceRGB(), colors: [UIColor.red.cgColor, UIColor.blue.cgColor], locations: [0, 1])!
    
    gradient.colors = [UIColor.red.cgColor, UIColor.green.cgColor, UIColor.blue.cgColor]
    
    gradient.locations = [0, 0.5, 1]
    
    view.layer.backgroundColor = UIColor.clear.cgColor
    
    view.layer.contents = UIGraphicsImageRenderer(size: view.bounds.size).image { _ in
    
        UIGraphicsGetCurrentContext()!.scaleBy(x: 1, y: -1)
    
        UIGraphicsGetCurrentContext()!.translateBy(x: 0, y: -view.bounds.height)
    
        UIGraphicsGetCurrentContext()!.drawLinearGradient(gradient, start: CGPoint(x: 0, y: 0), end: CGPoint(x: 1, y: 0), options: [])
    
    }
    
    


    위의 코드를 실행하여 Gradient의 색상이 정상적으로 나타나게 됩니다.

    2025-07-10 22:11

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 36,421건 / 48 페이지

검색

게시물 검색