绘制简单的图形
绘制矩形
与其它图形库不同,LCUI 提供的图形 API 只支持矩形这一种形式的图形绘制,不支持基于路径来绘制复杂图形。因此,对于其它复杂的图形,你需要手动编写代码填充像素来绘制。
LCUI 提供了一种绘制矩形的方法:
int Graph_FillRect(LCUI_Graph *graph, LCUI_Color color,
LCUI_Rect *rect, LCUI_BOOL with_alpha);
注意,该函数会将指定区域内的像素替换为指定颜色,而不是与原有颜色混合。
现在就来使用这个函数:
#include <LCUI.h>
#include <LCUI/graph.h>
#include <LCUI/image.h>
int main(void)
{
int i, j;
LCUI_Graph canvas;
LCUI_Color color;
LCUI_Rect rect;
Graph_Init(&canvas);
Graph_Create(&canvas, 150, 150);
for (i = 0; i < 6; ++i) {
for (j = 0; j < 6; ++j) {
color.red = (unsigned char)(255 - 42.5 * i);
color.green = (unsigned char)(255 - 42.5 * j);
color.blue = 0;
rect.x = j * 25;
rect.y = i * 25;
rect.width = 25;
rect.height = 25;
Graph_FillRect(&canvas, color, &rect, FALSE);
}
}
LCUI_WritePNGFile("test_fill_rect.png", &canvas);
Graph_Free(&canvas);
return 0;
}
在本示例里,我们用两层 for
循环来绘制方阵列,每个方格不同的颜色。结果如下图,但实现所用的代码却没那么绚丽。我们用了两个变量 i
和 j
来为每一个方格产生唯一的 RGB 色彩值,其中仅修改红 色和绿色通道的值,而保持蓝色通道的值不变。你可以通过修改这些颜色通道的值来产生各种各样的色板。通过增加渐变的频率,你还可以绘制出类似 Photoshop 里面的那样的调色板。
透明度
除了可以绘制实色图形,我们还可以绘制半透明的图形。通过设置画布的 opacity 属性或使用一个半透明颜色作为填充颜色。
opacity 属性影响整个图像的透明度,有效的取值范围是 0.0(完全透明)到 1.0(完全不透明),默认是 1.0。
opacity 的使用示例
在这个例子里,我们使用两个图像,一个填充四色格作为背景,另一个用作前景,设置其 opacity
属性为 0.2
,然后在前景图中填充一系列尺寸递增的半透明矩形并用 Graph_Mix()
函数将它 们混合到背景图上。最终结果是一个径向渐变效果。矩形叠加得越更多,原先所画的矩形的透明度会越低。通过增加循环次数,画更多的矩形,从中心到边缘部分,背景图会呈现逐渐消失的效果。
#include <LCUI.h>
#include <LCUI/graph.h>
#include <LCUI/image.h>
int main(void)
{
int i, size;
LCUI_Graph canvas;
LCUI_Graph fore_canvas;
LCUI_Rect rect;
Graph_Init(&canvas);
Graph_Init(&fore_canvas);
Graph_Create(&canvas, 150, 150);
// 画背景
rect.x = 0;
rect.y = 0;
rect.width = 75;
rect.height = 75;
Graph_FillRect(&canvas, RGB(255, 221, 0), &rect, FALSE);
rect.x = 75;
Graph_FillRect(&canvas, RGB(102, 204, 0), &rect, FALSE);
rect.x = 0;
rect.y = 75;
Graph_FillRect(&canvas, RGB(0, 153, 255), &rect, FALSE);
rect.x = 75;
Graph_FillRect(&canvas, RGB(255, 51, 0), &rect, FALSE);
// 设置前景的 opacity 值
fore_canvas.opacity = 0.2f;
// 仅当色彩模式为 ARGB 时 opacity 属性才会生效
fore_canvas.color_type = LCUI_COLOR_TYPE_ARGB;
for (i = 0; i < 7; ++i) {
size = 2 * (10 + 10 * i);
// 使用新尺寸重新创建前景图
Graph_Create(&fore_canvas, size, size);
// 重新填充颜色
Graph_FillRect(&fore_canvas, RGB(255, 255, 255), NULL, TRUE);
// 将前景图混合到背景图中
Graph_Mix(&canvas, &fore_canvas, 75 - size / 2, 75 - size / 2, FALSE);
}
LCUI_WritePNGFile("test_mix_rect_with_opacity.png", &canvas);
Graph_Free(&fore_canvas);
Graph_Free(&canvas);
return 0;
}
半透明色的使用示例
上个例子虽然用填充半透明色代替 opacity 属性也能实现同样的效果,但两个示例都共用同一示例代码的话未免有些无聊,所以我们换一种绘制方式,画一个正方形,将它分成四个填充不同颜色的长方形,每个长方形中都画一系列透明度从左递增的白色矩形:
#include <LCUI.h>
#include <LCUI/graph.h>
#include <LCUI/image.h>
#include <stdio.h>
int main(void)
{
int i, j;
LCUI_Graph canvas;
LCUI_Graph fore_canvas;
LCUI_Color color;
LCUI_Rect rect;
Graph_Init(&canvas);
Graph_Init(&fore_canvas);
Graph_Create(&canvas, 160, 160);
// 画背景
rect.x = 0;
rect.y = 0;
rect.width = 160;
rect.height = 40;
Graph_FillRect(&canvas, RGB(255, 221, 0), &rect, FALSE);
rect.y += 40;
Graph_FillRect(&canvas, RGB(102, 204, 0), &rect, FALSE);
rect.y += 40;
Graph_FillRect(&canvas, RGB(0, 153, 255), &rect, FALSE);
rect.y += 40;
Graph_FillRect(&canvas, RGB(255, 51, 0), &rect, FALSE);
color.red = 255;
color.green = 255;
color.blue = 255;
fore_canvas.color_type = LCUI_COLOR_TYPE_ARGB;
Graph_Create(&fore_canvas, 15, 30);
// 画半透明矩形
for (i = 0; i < 10; ++i) {
color.alpha = (unsigned char)(255 * (i + 1) / 10.0);
Graph_FillRect(&fore_canvas, color, NULL, TRUE);
for (j = 0; j < 4; ++j) {
Graph_Mix(&canvas, &fore_canvas, 5 + i * 15, 5 + j * 40, TRUE);
}
}
LCUI_WritePNGFile("test_fill_rect_with_rgba.png", &canvas);
Graph_Free(&fore_canvas);
Graph_Free(&canvas);
return 0;
}