ממשקי ה-API של Ink Brush מאפשרים ליצור ולהתאים אישית מברשות לציור על קנבס.
יצירת מברשת
כדי ליצור מברשת, משתמשים בשיטות ליצירת אובייקטים Brush עם ארגומנטים בעלי שם כמו Brush.createWithColorLong(). המחלקות האלה מאפשרות להגדיר את המאפיינים הבאים:
-
family: הסגנון של המברשת, בדומה לטיפוגרפיה או לגופן בטקסט. בקטעStockBrushesמפורטים הערכים הזמינים שלBrushFamily. -
color: צבע המברשת. אפשר להגדיר את הצבע באמצעותColorLong. size: עובי הבסיס של הקווים שנוצרו באמצעות המברשת.-
epsilon: המרחק הקטן ביותר שבו שתי נקודות בקו צריכות להיחשב כנפרדות. המרחק הזה קובע את רמת הפירוט או את רמת הדיוק של הגיאומטריה של הקו.- ערכים גבוהים יותר מפשטים את הקו יותר, מה שמאפשר שימוש בפחות זיכרון ועיבוד מהיר יותר, אבל עלול לגרום לאפקטים חזותיים לא רצויים כמו קצוות משוננים כשמגדילים את התצוגה.
- ערכים נמוכים יותר שומרים על יותר פרטים להגדלה באיכות גבוהה, אבל מגדילים את השימוש בזיכרון.
- אם יוצרים אב טיפוס עם סולם של יחידה אחת של פיקסל, כדאי להתחיל עם 0.1. באפליקציות לייצור שתומכות בדחיסויות מסך שונות, צריך להשתמש ביחידות שאינן תלויות בדחיסות (כמו dp) ולהתאים את אפסילון בהתאם.
val redBrush = Brush.createWithColorLong(
family = StockBrushes.pressurePen(),
colorLong = Color.RED.pack(),
size = 5F,
epsilon = 0.1F
)
שינוי המאפיינים של המכחול
אפשר ליצור עותק של מברשת קיימת באמצעות השיטה copy(). באמצעות השיטה הזו אפשר לשנות את כל המאפיינים של המברשת.
val blueBrush = redBrush.copy(colorLong = Color.BLUE.pack())
מכחולים בהתאמה אישית
While StockBrushes provides a versatile set of
common brushes, Ink API also offers an advanced path for creating entirely new
brush behaviors for unique artistic effects or to replicate specific existing
brushes for backward compatibility.
A custom BrushFamily is loaded from its serialized format. The required format
is the gzipped binary encoding of the
BrushFamily protocol buffer. This lets you load and use
custom brush files today. Once deserialized, the custom BrushFamily can be
used to create a new Brush with a specific color and size, just like any of
the StockBrushes families.
class CustomBrushes(val context: Context) {
private const val TAG = "CustomBrushes"
val brushes by lazy { loadCustomBrushes(context) }
@OptIn(ExperimentalInkCustomBrushApi::class)
private fun loadCustomBrushes(): List<CustomBrush> {
val brushFiles = mapOf(
"Calligraphy" to (R.raw.calligraphy to R.drawable.draw_24px),
"Flag Banner" to (R.raw.flag_banner to R.drawable.flag_24px),
"Graffiti" to (R.raw.graffiti to R.drawable.format_paint_24px),
// ...
)
val loadedBrushes = brushFiles.mapNotNull { (name, pair) ->
val (resourceId, icon) = pair
val brushFamily = context.resources.openRawResource(resourceId).use
{ inputStream ->
BrushFamily.decode(inputStream)
}
CustomBrush(name, icon, brushFamily.copy(clientBrushFamilyId = name))
}
return loadedBrushes
}
}
data class CustomBrush(
val name: String,
val icon: Int,
val brushFamily: BrushFamily
)