axiom-ios-graphics
npx skills add https://github.com/fotescodev/ios-agent-skills --skill axiom-ios-graphics
Agent 安装分布
Skill 文档
iOS Graphics Router
You MUST use this skill for ANY GPU rendering, graphics programming, or display performance work.
When to Use
Use this router when:
- Porting OpenGL/OpenGL ES code to Metal
- Porting DirectX code to Metal
- Converting GLSL/HLSL shaders to Metal Shading Language
- Setting up MTKView or CAMetalLayer
- Debugging GPU rendering issues (black screen, wrong colors, crashes)
- Evaluating translation layers (MetalANGLE, MoltenVK)
- Optimizing GPU performance or fixing thermal throttling
- App stuck at 60fps on ProMotion device
- Configuring CADisplayLink or render loops
- Variable refresh rate display issues
Routing Logic
Metal Migration
Strategy decisions â /skill axiom-metal-migration
- Translation layer vs native rewrite decision
- Project assessment and migration planning
- Anti-patterns and common mistakes
- Pressure scenarios for deadline resistance
API reference & conversion â /skill axiom-metal-migration-ref
- GLSL â MSL shader conversion tables
- HLSL â MSL shader conversion tables
- GL/D3D API â Metal API equivalents
- MTKView setup, render pipelines, compute shaders
- Complete WWDC code examples
Diagnostics â /skill axiom-metal-migration-diag
- Black screen after porting
- Shader compilation errors
- Wrong colors or coordinate systems
- Performance regressions
- Time-cost analysis per diagnostic path
Display Performance
Frame rate & render loops â /skill axiom-display-performance
- App stuck at 60fps on ProMotion (120Hz) device
- MTKView or CADisplayLink configuration
- Variable refresh rate optimization
- System caps (Low Power Mode, Limit Frame Rate, Adaptive Power)
- Frame budget math (8.33ms for 120Hz)
- Measuring actual vs reported frame rate
Decision Tree
User asks about GPU/graphics/Metal/display
ââ "Should I use translation layer or native?" â metal-migration
ââ "How do I migrate/port/convert?" â metal-migration
ââ "Show me the API/code/example" â metal-migration-ref
ââ "How do I set up MTKView?" â metal-migration-ref
ââ "Something's broken/wrong/slow" â metal-migration-diag
ââ "Stuck at 60fps on ProMotion" â display-performance
ââ "CADisplayLink setup/configuration" â display-performance
ââ "Variable refresh rate issues" â display-performance
ââ "Frame rate not what I expect" â display-performance
Critical Patterns
metal-migration:
- Translation layer (MetalANGLE) for quick demos
- Native Metal rewrite for production
- State management differences (GL stateful â Metal explicit)
- Coordinate system gotchas (Y-flip, NDC differences)
metal-migration-ref:
- Complete shader type mappings
- API equivalent tables
- MTKView vs CAMetalLayer decision
- Render pipeline setup patterns
metal-migration-diag:
- GPU Frame Capture workflow (2-5 min vs 30+ min guessing)
- Shader debugger for variable inspection
- Metal validation layer for API misuse
- Performance regression diagnosis
display-performance:
- MTKView defaults to 60fps (must set preferredFramesPerSecond = 120)
- CADisplayLink preferredFrameRateRange for explicit rate control
- System caps: Low Power Mode, Limit Frame Rate, Thermal, Adaptive Power (iOS 26)
- 8.33ms frame budget for 120Hz
- UIScreen.maximumFramesPerSecond lies; CADisplayLink tells truth
Example Invocations
User: “Should I use MetalANGLE or rewrite in native Metal?”
â Invoke: /skill axiom-metal-migration
User: “I’m porting projectM from OpenGL ES to iOS”
â Invoke: /skill axiom-metal-migration
User: “How do I convert this GLSL shader to Metal?”
â Invoke: /skill axiom-metal-migration-ref
User: “Setting up MTKView for the first time”
â Invoke: /skill axiom-metal-migration-ref
User: “My ported app shows a black screen”
â Invoke: /skill axiom-metal-migration-diag
User: “Performance is worse after porting to Metal”
â Invoke: /skill axiom-metal-migration-diag
User: “My app is stuck at 60fps on iPhone Pro”
â Invoke: /skill axiom-display-performance
User: “How do I configure CADisplayLink for 120Hz?”
â Invoke: /skill axiom-display-performance
User: “ProMotion not working in my Metal app”
â Invoke: /skill axiom-display-performance