API BrushMực cung cấp một cách để tạo và tuỳ chỉnh các bút vẽ để vẽ trên canvas.
Tạo cọ vẽ
Để tạo một cọ vẽ, hãy sử dụng các phương thức của nhà máy Brush với các đối số được đặt tên, chẳng hạn như Brush.createWithColorLong(). Lớp này cho phép bạn đặt các thuộc tính sau:
family: Kiểu của cọ vẽ, tương tự như kiểu chữ hoặc phông chữ trong văn bản. Hãy xemStockBrushesđể biết các giá trịBrushFamilyhiện có.color: Màu cọ vẽ. Bạn có thể đặt màu bằngColorLong.size: Độ dày cơ bản của các nét vẽ được tạo bằng cọ vẽ.epsilon: Khoảng cách nhỏ nhất mà hai điểm trong nét vẽ phải được coi là riêng biệt, điều này kiểm soát mức độ chi tiết hoặc độ trung thực của hình học nét vẽ.- Giá trị càng cao thì nét vẽ càng đơn giản, giúp sử dụng ít bộ nhớ hơn và kết xuất nhanh hơn, nhưng có thể dẫn đến các hiện tượng giả tạo có thể nhìn thấy như các cạnh răng cưa khi phóng to.
- Các giá trị thấp hơn sẽ giữ lại nhiều chi tiết hơn để thu phóng chất lượng cao, nhưng làm tăng mức sử dụng bộ nhớ.
- Đối với việc tạo mẫu bằng thang đơn vị 1 px, 0,1 là một điểm khởi đầu tốt. Đối với các ứng dụng phát hành hỗ trợ nhiều mật độ màn hình, hãy sử dụng các đơn vị không phụ thuộc vào mật độ (chẳng hạn như dp) và điều chỉnh epsilon cho phù hợp.
val redBrush = Brush.createWithColorLong(
family = StockBrushes.pressurePen(),
colorLong = Color.RED.pack(),
size = 5F,
epsilon = 0.1F
)
Sửa đổi thuộc tính bút vẽ
Bạn có thể tạo bản sao của một cọ vẽ hiện có bằng phương thức copy(). Phương thức này cho phép bạn thay đổi bất kỳ thuộc tính nào của cọ vẽ.
val blueBrush = redBrush.copy(colorLong = Color.BLUE.pack())
Cọ vẽ tuỳ chỉnh
虽然 StockBrushes 提供了一组通用的多功能笔刷,但 Ink API 还提供了一种高级方法,用于创建全新的笔刷行为,以实现独特的艺术效果,或复制特定的现有笔刷以实现向后兼容性。
自定义 BrushFamily 从其序列化格式加载。所需格式为 BrushFamily 协议缓冲区的 gzip 压缩二进制编码。这样一来,您就可以立即加载和使用自定义笔刷文件。反序列化后,自定义 BrushFamily 可用于创建具有特定颜色和大小的新 Brush,就像任何 StockBrushes 系列一样。
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
)