CGFloat

Core Graphics 및 연관 프레임워크에서 사용되는 기본 부동소수점 스칼라 타입

원문 출처 https://developer.apple.com/documentation/coregraphics/cgfloat

Declaration

@frozen struct CGFloat

Summary

SDKs

  • iOS 7.0+

  • macOS 10.9+

  • Mac Catalyst 13.0+

  • tvOS 9.0+

  • watchOS 2.0+

  • Xcode 6.0.1+

Framework

  • Core Graphics

Overview

이 타입의 크기와 정밀도는 CPU 아키텍처에 따라서 다릅니다. 64-bit CPU 용도로 빌드하면 CGFloat은 Double에 해당하는 IEEE 배정밀도 부동소수점 타입의 64비트가 됩니다. 만약 32-bit CPU 용으로 빌드한다면 CGFloat은 32비트로써 IEEE 단정밀도 부동소수점 타입으로써 Float에 해당하는 타입이 됩니다.

주제

Type Aliases

  • typealias CGFloat.FloatLiteralType

  • typealias CGFloat.IntegerLiteralType

  • typealias CGFloat.Magnitude

  • typealias CGFloat.RawExponent

  • typealias CGFloat.Stride

  • typealias CGFloat.Exponent 쓰여진 지수를 표현할 수 있는 정수 타입

  • typealias CGFloat.NativeType CGFloat을 저장하는데 사용되는 네이티브 타입으로써 32비트 아키텍쳐에서는 Float, 64비트 아키텍처에서는 Double입니다.

  • typealias CGFloat.RawSignificand 부호없는 정수형으로써 어떤 값이든지 그 가수를 표현하는데 사용될 수 있습니다.

Initializers

  • init() 0으로 초기화된 인스턴스를 생성합니다.

  • init(Float) Float을 표현 가능한 범위 내에서 가장 가까운 값으로 반올림합니다.

  • init(Double) Double을 표현 가능한 범위 내에서 가장 가까운 값으로 반올림합니다.

  • init(CGFloat) 주어진 값으로 초기화된 인스턴스를 생성합니다.

  • init(Float80) Float80을 표현가능한 범위 내에서 가장 가까운 값으로 반올림합니다.

  • init<Source>(Source) 주어진 값으로 새로운 인스턴스를 생성하되, 가능한 표현범위 내에서 가장 가까운 값으로 반올림합니다.

  • init<Source>(Source) 주어진 값으로 새 값을 생성하되, 가능한 표현범위 내에서 가장 가까운 값으로 반올림합니다.

  • init(NSNumber) Deprecated

  • init(bitPattern: UInt)

  • init?<T>(exactly: T)

  • init?<Source>(exactly: Source) 정확히 표현될 수 있다면, 주어진 값으로부터 새 인스턴스를 생성합니다.

  • init?<Source>(exactly: Source) 주어진 정수가 정확히 표현될 수 있다면, 새 값을 생성합니다.

  • init?(exactly: NSNumber)

  • init(floatLiteral: CGFloat.NativeType) 주어진 값으로 초기화된 인스턴스를 생성합니다.

  • init(floatLiteral: CGFloat.NativeType) 주어진 값으로 초기화된 인스턴스를 생성합니다.

  • init(from: Decoder)

  • init(integerLiteral: Int) 주어진 값으로 초기화된 인스턴스를 생성합니다.

  • init(nan: CGFloat.RawSignificand, signaling: Bool)

    NaN with specified payload.

  • init(sign: FloatingPointSign, exponent: Int, significand: CGFloat) 부호, 지수와 가수로 초기화합니다.

  • init(sign: FloatingPointSign, exponentBitPattern: UInt, significandBitPattern: UInt) 부호, 지수와 가수 비트 패턴을 조합하여 부동 소수점 값을 만들어냅니다.

  • init(signOf: CGFloat, magnitudeOf: CGFloat) 하나의 값에서 부호를 취하고, 다른 값에 적용시켜서 새로운 부동소수점 값을 생성합니다.

  • init(truncating: NSNumber)

인스턴스 속성

  • var binade: CGFloat

    The least-magnitude member of the binade of self.

  • var bitPattern: UInt

  • var customMirror: Mirror

    CGFloat 인스턴스를 반영하는 Mirror.

  • var description: String

    self의 텍스트 표현

  • var exponent: Int self를 기수(밑수)가 r인 로그로 표현했을 때의 지수를 가리킵니다. (r은 이진법 타입인 경우에는 2, 십진법 타입인 경우에는 10입니다.) IEEE 754 logB 연산의 구현입니다.

  • var exponentBitPattern: UInt raw encoding으로 나타낸 부동 소수점 값의 지수부

  • var floatingPointClass: FloatingPointClassification

  • var hashValue: Int

    해시 값

  • var isCanonical: Bool

    self가 표준 형식이면 true를 반환합니다.

  • var isFinite: Bool self가 0이거나, 준정규 값이거나, 정규값이라면 (infinity나 NaN이 아님) true를 반환합니다. (역자 주: 준정규 값, 정규값에 관한 설명)

  • var isInfinite: Bool self가 infinity라면 true를 반환합니다.

  • var isNaN: Bool self가 NaN(Not A Number)라면 true를 반환합니다.

  • var isNormal: Bool self가 정규값이라면 (0, 준정규 값, infinity, NaN이 아님) true를 반환합니다.

  • var isSignalingNaN: Bool self가 signaling NaN인 경우에만 true를 반환합니다.

  • var isSubnormal: Bool self가 준 정규값이라면 true를 반환합니다.

  • var isZero: Bool self가 +0.0이나 -0.0이라면 true를 반환합니다.

  • var magnitude: CGFloat

  • var magnitudeSquared: Double

  • var native: CGFloat.NativeType

    The native value.

  • var native: CGFloat.NativeType

    The native value.

  • var nextDown: CGFloat 이 값보다 작은 범위 내에서 표현 가능한 가장 큰 값

  • var nextUp: CGFloat 이 값보다 큰 범위 내에서 표현 가능한 가장 작은 값

  • var sign: FloatingPointSign self의 sign bit가 (1로) 설정되어 있으면 음수, 그렇지 않으면 양수입니다. IEEE 754 signbit 동작의 구현입니다.

  • var significand: CGFloat 부동 소수점 숫자의 가수

  • var significandBitPattern: UInt raw encoding으로 표현된 부동 소수점 값의 가수부

  • var significandWidth: Int 가수를 표현하는데 요구되는 비트 갯수

  • var ulp: CGFloat self의 마지막 자리의 단위

타입 속성

  • static var exponentBitCount: Int 지수를 표현하는데 사용되는 비트 갯수

  • static var greatestFiniteMagnitude: CGFloat 가장 큰 유한수

  • static var infinity: CGFloat

    양의 무한수

  • static var leastNonzeroMagnitude: CGFloat 가장 작은 양수

  • static var leastNormalMagnitude: CGFloat 가장 작은 양의 정규값

  • static var nan: CGFloat

    A quiet NaN.

  • static var pi: CGFloat

    상수 π (3.14159...)

  • static var radix: Int 이 부동소수점 타입의 기수, 또는 지수의 밑수입니다.

  • static var signalingNaN: CGFloat

    A signaling NaN (not-a-number).

  • static var significandBitCount: Int 고정 길이 부동소수점 타입에서 이 속성은 가수부 비트의 갯수를 나타냅니다.

  • static var ulpOfOne: CGFloat

    The unit in the last place of 1.0.

  • static var zero: CGFloat

    0의 값

인스턴스 메소드

  • func addProduct(CGFloat, CGFloat)

  • func addingProduct(CGFloat, CGFloat) -> CGFloat 중간 반올림없이 주어진 두 값을 곱하고, self에 더한 값을 반환합니다.

  • func advanced(by: CGFloat) -> CGFloat

    Returns a Self x such that self.distance(to: x) approximates n.

  • func distance(to: CGFloat) -> CGFloat

    Returns a stride x such that self.advanced(by: x) approximates other.

  • func encode(to: Encoder)

  • func formRemainder(dividingBy: CGFloat)

  • func formSquareRoot()

  • func formTruncatingRemainder(dividingBy: CGFloat) 나머지 연산의 결과값으로 self를 대체합니다. C 표준 라이브러리 함수 fmod와 유사합니다.

  • func hash(into: inout Hasher)

  • func isEqual(to: CGFloat) -> Bool

    IEEE 754 equality predicate.

  • func isLess(than: CGFloat) -> Bool

    IEEE 754 less-than predicate.

  • func isLessThanOrEqualTo(CGFloat) -> Bool

    IEEE 754 less-than-or-equal predicate.

  • func isTotallyOrdered(belowOrEqualTo: CGFloat) -> Bool 오름차순 정렬 시 주어진 값이 인스턴스와 비교하여 앞서거나 동일한 위치에 존재하게 될지를 알려주는 Boolean 값을 반환합니다.

  • func negate()

    인스턴스가 음수면 양수로, 양수면 음수로 값을 바꿉니다.

  • func remainder(dividingBy: CGFloat) -> CGFloat 주어진 값으로 나눈 나머지를 반환합니다.

  • func round() "schoolbook rounding"을 사용하여 이 값을 정수값으로 반올림합니다.

  • func round(FloatingPointRoundingRule)

  • func rounded() -> CGFloat

    "schoolbook rounding"을 사용하여 self를 정수값으로 반올림해서 반환합니다.

  • func rounded(FloatingPointRoundingRule) -> CGFloat 지정된 반올림 규칙을 사용하여 정수로 반올림된 self값을 반환합니다.

  • func scale(by: Double) func squareRoot() -> CGFloat 이 값의 제곱근을 표현 가능한 값으로 반올림하여 반환합니다.

  • func truncatingRemainder(dividingBy: CGFloat) -> CGFloat 주어진 값으로 나머지 연산하여 나오는 나머지 값을 반환합니다.

타입 메소드

  • static func maximum(CGFloat, CGFloat) -> CGFloat

    주어진 두 개의 값 중 더 큰 값을 반환합니다.

  • static func maximumMagnitude(CGFloat, CGFloat) -> CGFloat (절대값 기준으로) 크기가 더 큰 값을 반환합니다.

  • static func minimum(CGFloat, CGFloat) -> CGFloat 주어진 두 개의 값 중 더 작은 값을 반환합니다.

  • static func minimumMagnitude(CGFloat, CGFloat) -> CGFloat (절대값 기준으로) 크기가 더 작은 값을 반환합니다.

  • static func random(in: ClosedRange) -> CGFloat 지정된 범위 내에서 랜덤한 값을 반환합니다.

  • static func random(in: Range) -> CGFloat 지정된 범위 내에서 랜덤한 값을 반환합니다.

  • static func random(in: ClosedRange, using: inout T) -> CGFloat in 범위 내에서 using 을 랜덤 제너레이터로 사용하여 무작위 값을 반환합니다.

  • static func random(in: Range, using: inout T) -> CGFloat in 범위 내에서 using 을 랜덤 제너레이터로 사용하요 무작위 값을 반환합니다.

연산자 함수

  • static func != (CGFloat, CGFloat) -> Bool 두 값이 다른지를 비교해서 다르면 true를 반환합니다.

  • static func * (CGFloat, CGFloat) -> CGFloat

  • static func *= (inout CGFloat, CGFloat)

  • static func + (CGFloat) -> CGFloat

    Returns the given number unchanged.

  • static func + (CGFloat, CGFloat) -> CGFloat

  • static func += (inout CGFloat, CGFloat)

  • static func - (CGFloat) -> CGFloat 지정된 값의 역수를 더합니다.

  • static func - (CGFloat, CGFloat) -> CGFloat

  • static func -= (inout CGFloat, CGFloat)

  • static func ... (CGFloat) -> PartialRangeFrom 하한선을 기준으로 위로 확장되는 부분 구간을 반환합니다.

  • static func ... (CGFloat) -> PartialRangeThrough 상한선까지 포함되는 부분 구간을 반환합니다.

  • static func ... (CGFloat, CGFloat) -> ClosedRange 경계를 포함하는 닫힌 구간을 반환합니다.

  • static func ..< (CGFloat) -> PartialRangeUpTo 상한을 포함하지 않는 부분 구간을 반환합니다.

  • static func ..< (CGFloat, CGFloat) -> Range 하한선을 포함하고 상한선을 포함하지 않는 반 열린 구간을 반환합니다.

  • static func / (CGFloat, CGFloat) -> CGFloat

  • static func /= (inout CGFloat, CGFloat)

  • static func < (CGFloat, CGFloat) -> Bool 첫번째 인자가 두번째 인자보다 작은지를 나타내는 Boolean 값을 반환합니다.

  • static func < (CGFloat, CGFloat) -> Bool

    첫번째 인자가 두번째 인자보다 작은지를 나타내는 Boolean 값을 반환합니다.

  • static func <= (CGFloat, CGFloat) -> Bool 첫번째 인자가 두번째 인자보다 작거나 같은지를 나타내는 Boolean 값을 반환합니다.

  • static func <= (CGFloat, CGFloat) -> Bool 첫번째 인자가 두번째 인자보다 작거나 같은지를 나타내는 Boolean 값을 반환합니다.

  • static func == (CGFloat, CGFloat) -> Bool 두 값이 같은지를 나타내는 Boolean 값을 반환합니다.

  • static func == (CGFloat, CGFloat) -> Bool 두 값이 같은지를 나타내는 Boolean 값을 반환합니다.

  • static func > (CGFloat, CGFloat) -> Bool 첫번째 인자가 두번째 인자보다 더 큰지를 나타내는 Boolean 값을 반환합니다.

  • static func > (CGFloat, CGFloat) -> Bool 첫번째 인자가 두번째 인자보다 더 큰지를 나타내는 Boolean 값을 반환합니다.

  • static func >= (CGFloat, CGFloat) -> Bool 첫번째 인자가 두번째 인자보다 더 크거나 같은지를 나타내는 Boolean 값을 반환합니다.

  • static func >= (CGFloat, CGFloat) -> Bool 첫번째 인자가 두번째 인자보다 더 크거나 같은지를 나타내는 Boolean 값을 반환합니다.

관련 문서

준수하는 프로토콜

  • BinaryFloatingPoint

  • CustomReflectable

  • CustomStringConvertible

  • Decodable

  • Encodable

  • Hashable

  • SignedNumeric

  • Strideable

  • VectorArithmetic

같이 보기

기하 데이터 유형

  • struct CGPoint 2차원 좌표계상의 지점을 나타내는 구조체

  • struct CGSize 너비와 높이 값을 갖는 구조체

  • struct CGRect 사각형의 위치와 크기값을 갖는 구조체

  • struct CGVector 2차원 벡터값을 갖는 구조체

  • struct CGAffineTransform 2D 그래픽을 그릴때 사용되는 affine 변환 매트릭스

Last updated