xM: improve the bundle icon a bit

This commit is contained in:
Přemysl Eric Janouch 2023-09-04 06:11:58 +02:00
parent 9e4692bb09
commit 13d2ff115b
Signed by: p
GPG Key ID: A0420B94F92B9493
1 changed files with 13 additions and 21 deletions

View File

@ -1,4 +1,4 @@
// gen-icon.awk: generate a program icon for xM in the Apple icon format
// gen-icon.swift: generate a program icon for xM in the Apple icon format
//
// Copyright (c) 2023, Přemysl Eric Janouch <p@janouch.name>
// SPDX-License-Identifier: 0BSD
@ -10,24 +10,17 @@ import Foundation
import ImageIO
import UniformTypeIdentifiers
// XXX: Not even AppKit provides real superelliptic squircles; screw it.
func drawSquircle(context: CGContext, bounds: CGRect, radius: CGFloat) {
context.move(to: CGPointMake(bounds.minX, bounds.maxY - radius))
context.addArc(
center: CGPointMake(bounds.minX + radius, bounds.maxY - radius),
radius: radius, startAngle: .pi, endAngle: .pi / 2, clockwise: true)
context.addLine(to: CGPointMake(bounds.maxX - radius, bounds.maxY))
context.addArc(
center: CGPointMake(bounds.maxX - radius, bounds.maxY - radius),
radius: radius, startAngle: .pi / 2, endAngle: 0, clockwise: true)
context.addLine(to: CGPointMake(bounds.maxX, bounds.maxY - radius))
context.addArc(
center: CGPointMake(bounds.maxX - radius, bounds.minY + radius),
radius: radius, startAngle: 0, endAngle: .pi / -2, clockwise: true)
context.addLine(to: CGPointMake(bounds.minX + radius, bounds.minY))
context.addArc(
center: CGPointMake(bounds.minX + radius, bounds.minY + radius),
radius: radius, startAngle: .pi / -2, endAngle: .pi, clockwise: true)
// Apple uses something that's close to a "quintic superellipse" in their icons,
// but doesn't quite match. Either way, it looks better than rounded rectangles.
func addSquircle(context: CGContext, bounds: CGRect) {
context.move(to: CGPoint(x: bounds.maxX, y: bounds.midY))
for theta in stride(from: 0.0, to: .pi * 2, by: .pi / 1e4) {
let x = pow(abs(cos(theta)), 2 / 5.0) * bounds.width / 2
* CGFloat(signOf: cos(theta), magnitudeOf: 1) + bounds.midX
let y = pow(abs(sin(theta)), 2 / 5.0) * bounds.height / 2
* CGFloat(signOf: sin(theta), magnitudeOf: 1) + bounds.midY
context.addLine(to: CGPoint(x: x, y: y))
}
context.closePath()
}
@ -42,8 +35,7 @@ func drawIcon(scale: CGFloat) -> CGImage? {
context.scaleBy(x: scale, y: scale)
let bounds = CGRectMake(100, 100, size.width - 200, size.height - 200)
// The radius was something like size.{width,height}/6.4, at least for iOS.
drawSquircle(context: context, bounds: bounds, radius: 180)
addSquircle(context: context, bounds: bounds)
let squircle = context.path!
// Gradients don't draw shadows, so draw it separately.