← 返回
数据分析 中文

ColorKit

Expert guidance on ColorKit, a Swift library for advanced color manipulation, conversion, and accessibility management. Use when developers mention: (1) CKColor, CKBlendMode, CKAPCA, (2) color space conversion (OKLAB, Display P3, sRGB), (3) WCAG or APCA contrast checks, (4) hex color initialization, (5) dynamic/adaptive colors for Dark Mode, (6) perceptual gamut mapping.
针对 ColorKit(一个用于高级颜色处理、转换及无障碍管理的 Swift 库)提供专家指导。适用于开发者提及以下内容时:(1) CKColor、CKBlendMode、CKAPCA,(2) 色彩空间转换(OKLAB、Display P3、sRGB),(3) WCAG 或 APCA 对比度检查,(4) 十六进制颜色初始化,(5) 深色模式的动态/自适应颜色,(6) 感知色域映射。
szpakkamil
数据分析 clawhub v0.1.0 1 版本 99867.8 Key: 无需
★ 0
Stars
📥 1,511
下载
💾 23
安装
1
版本
#latest

概述

ColorKit Skill

Overview

This skill provides expert guidance on ColorKit, a powerful, cross-platform Swift library for advanced color management. It covers advanced color creation (Hex, OKLAB, HSL), professional blending modes, precise color space transformations with perceptual gamut mapping, and comprehensive accessibility checks using WCAG and APCA standards. Use this skill to help developers implement sophisticated color logic and ensure UI accessibility across all Apple platforms.

Agent Behavior (Follow These Rules)

  1. Clarify Color Space Needs: Always identify if the user needs standard sRGB or wide-gamut (Display P3, Adobe RGB) support before recommending conversion methods.
  2. Prioritize CKColor: Encourage the use of CKColor as the unified entry point for all color operations, as it handles platform-specific differences and color space metadata automatically.
  3. Recommend Perceptual Mapping: When converting between gamuts, suggest using converted(to:iterations:) for OKLAB-based perceptual mapping to preserve visual intent.
  4. Emphasize Accessibility: Proactively mention APCA (isAPCAAccessible) for modern typography contrast needs, alongside traditional WCAG ratios.
  5. Dynamic Colors: Always consider system appearance (Light/Dark mode) when suggesting color initializers, favoring those that support adaptive variants.
  6. Contextual Bridges: Provide clear examples of bridging CKColor to native types like Color, UIColor, or NSColor when UI integration is the goal.

Project Settings

ColorKit's behavior is influenced by the project's deployment targets and Swift version.

  • Deployment Targets: iOS 13.0+, macOS 10.15+, tvOS 13.0+, watchOS 6.0+, and visionOS 1.0+.
  • Swift Version: Requires Swift 5.9+.

If these are unknown, ask the developer to confirm them, especially when discussing HDR or wide-gamut features.

Quick Decision Tree

When a developer needs ColorKit guidance, follow this decision tree:

  1. Creating a new color?
    • From Hex string/int → references/CKColor.md
    • Using specific models (OKLAB, HSL, CMYK) → references/ColorModels.md
    • Adaptive for Light/Dark mode → references/CKColor.md
  1. Converting between color spaces?
    • Basic conversion or Perceptual Gamut Mapping → references/ColorOperations.md
    • Handling wide-gamut (P3, Adobe RGB) → references/ColorOperations.md
  1. Performing accessibility checks?
    • WCAG 2.1 Contrast Ratio → references/Accessibility.md
    • APCA (WCAG 3.0) Perceptual Contrast → references/Accessibility.md
    • Font-specific readability → references/Accessibility.md
  1. Blending or modifying colors?
    • Photoshop-style blending (Multiply, Overlay, etc.) → references/Blending.md
    • Adjusting opacity, lightness, or saturation → references/ColorOperations.md
  1. Integrating with UI frameworks?
    • SwiftUI (Color, ShapeStyle) → references/NativeBridges.md
    • UIKit/AppKit (UIColor, NSColor) → references/NativeBridges.md
    • Core Graphics/Image (CGColor, CIColor) → references/NativeBridges.md
  1. Storing or persisting colors?
    • Using Codable or Sendablereferences/CKColor.md

Triage-First Playbook

  • "My colors look different after conversion."
  • Explain gamut clipping and recommend using converted(to:iterations:) for perceptual mapping. Refer to references/ColorOperations.md.
  • "How do I support Dark Mode with custom colors?"
  • Show how to use CKColor initializers that take both light and dark variants. Refer to references/CKColor.md.
  • "Is my text readable on this background?"
  • Guide them through using isAPCAAccessible with specific font size and weight. Refer to references/Accessibility.md.
  • "I get a compiler error when using CKColor in SwiftUI."
  • Remind them that CKColor conforms to ShapeStyle directly, but they might need .color property for some modifiers. Refer to references/NativeBridges.md.

Core Patterns Reference

Basic Initialization & Usage

import ColorKit

// Hex initialization
let brand = CKColor(hexString: "#007AFF")

// Adaptive color
let adaptive = CKColor(hexString: "#007AFF", hexStringDark: "#0A84FF")

// Use in SwiftUI
Circle().fill(adaptive)

Advanced Operations

// Perceptual conversion to sRGB
let p3 = CKColor(red: 1.0, green: 0.0, blue: 0.0, colorSpace: .displayP3)
let sRGB = p3.converted(to: .sRGB, iterations: 6)

// Blending
let blended = brand.blended(with: .black, mode: .multiply, opacity: 0.5)

Accessibility Check

let bg = CKColor.white
let isAccessible = brand.isAPCAAccessible(on: bg, size: 16, weight: .regular)

Integration Quick Guide

ColorKit is integrated via Swift Package Manager.

  1. Add Package Dependency: In Xcode, go to File > Add Package Dependency and enter https://github.com/SzpakKamil/ColorKit.git.
  2. Import: import ColorKit in your Swift files.
  3. Deployment Targets: iOS 13.0+, macOS 10.15+, tvOS 13.0+, watchOS 6.0+, visionOS 1.0+ (Swift 5.9+).

For detailed setup, see references/Setup.md.

Reference Files

Load these files as needed for specific topics:

  • ColorKit.md - General overview and key capabilities.
  • Setup.md - Installation and project integration.
  • CKColor.md - Detailed documentation for the core CKColor struct, initializers, and persistence.
  • ColorOperations.md - Conversion, gamut mapping, and basic modifications.
  • ColorModels.md - Using specialized models like OKLAB, HSL, CMYK, etc.
  • NativeBridges.md - Integration with SwiftUI, UIKit, AppKit, and Core Graphics.
  • Accessibility.md - WCAG and APCA contrast calculations and readability checks.
  • Blending.md - Advanced blending modes and transparency handling.
  • _index.md - A comprehensive index for all ColorKit reference documentation.

Best Practices Summary

  1. Use CKColor Everywhere: It serves as a universal color type that simplifies cross-platform logic.
  2. Prefer APCA for Text: APCA provides better perceptual accuracy for modern typography than traditional WCAG 2.1.
  3. Always Map Gamuts: Use perceptual mapping when moving from wide gamuts (P3) to narrow ones (sRGB) to avoid "dead" colors.
  4. Leverage ShapeStyle: Take advantage of CKColor's direct conformance to ShapeStyle in SwiftUI for cleaner code.
  5. Stay Adaptive: Use adaptive initializers to ensure your UI looks great in both Light and Dark modes without extra logic.

Note: This skill is based on the comprehensive documentation for ColorKit. For further details, visit the official documentation at documentation.kamilszpak.com/documentation/colorkit/ or the project website at kamilszpak.com/pl/colorkit.

版本历史

共 1 个版本

  • v0.1.0 当前
    2026-03-29 00:46 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

developer-tools

PagerKit

szpakkamil
关于 PagerKit 的专业指导,这是一个用于高级、可定制分页导航的 SwiftUI 库。适用于开发者提及:(1) PagerKit、PKPagesView、PKPage,(2) 自定义页面控件、指示器或分页行为,(3) 跨平台 Swif
★ 1 📥 2,419
data-analysis

Data Analysis

ivangdavila
{"answer":"数据分析与可视化。查询数据库、生成报告、自动化电子表格,将原始数据转化为清晰可行的见解。适用于:(1) 您……"}
★ 198 📥 64,981
data-analysis

Excel / XLSX

ivangdavila
创建、检查和编辑 Microsoft Excel 工作簿及 XLSX 文件,支持可靠的公式、日期、类型、格式、重算及模板保留功能。
★ 367 📥 140,165