Java图形处理:构造缓冲图像及透明处理

需积分: 9 0 下载量 77 浏览量 更新于2024-08-18 收藏 9.22MB PPT 举报
"本资源是一份全面的JAVA自学教程,涵盖了从基础到高级的各种主题,包括Java环境配置、基本语法、类和接口、图形处理、用户界面技术、异常处理、多线程、输入输出、数据库技术、网络安全、Servlet和XML处理等多个方面。教程旨在帮助学习者深入理解Java编程,并提供了丰富的实例和习题进行实践。" 在Java编程中,构造缓冲图像对象是图形处理的一个重要环节,特别是在需要对图像进行动态渲染或复杂操作时。在提供的代码片段中,展示了如何创建和使用`BufferedImage`对象: ```java BufferedImage buf = new BufferedImage(w, h, BufferedImage.TYPE_INT_ARGB); ``` 这里,`BufferedImage`是一个二维数组,用于存储图像数据。参数`w`和`h`分别代表图像的宽度和高度,`TYPE_INT_ARGB`定义了像素数据的格式,表示每个像素由一个整数表示,包含透明度(Alpha)、红色(Red)、绿色(Green)和蓝色(Blue)四个通道。 接着,`createGraphics()`方法用于获取一个`Graphics`对象,它是进行图形绘制的基础: ```java Graphics tmpG = buf.createGraphics(); ``` `tmpG`可以用来在`buf`上绘制图像和其他图形元素。 然后,将一个已有的`img`图像绘制到`buf`上: ```java tmpG.drawImage(img, 10, 10, this); ``` 这里的`drawImage()`方法用于在指定位置绘制图像,参数分别表示图像左上角的坐标和调用者。 最后,将`buf`上的图像绘制到屏幕或其他图形目标上: ```java g.drawImage(buf, 10, 20, this); ``` 这里`g`可能是`Component`对象的`Graphics`上下文,用于在组件上显示图像。 此外,代码还提到了设置透明颜色对象,这里创建了一个半透明的蓝色: ```java Color transBlue = new Color(0, 0, 255, 100); g.setColor(transBlue); ``` `Color`类用于表示颜色,`transBlue`的最后一个参数(100)表示透明度,数值越小,透明度越高。 `GeneralPath`是用于构建复杂的形状和路径的类,可以组合直线、曲线和封闭区域: ```java GeneralPath path = new GeneralPath(); ``` 在实际应用中,可以向`path`添加点和路径,然后使用`Graphics`对象的`drawPath()`方法进行绘制。 在整个Java教程中,学习者会逐步掌握这些概念,从基础语法开始,逐渐过渡到高级特性,如图形处理、多线程和网络编程,最终能够独立开发复杂的Java应用程序。教程结构清晰,章节划分明确,适合自学者系统学习。

注释下段代码void put(struct prodcons * b, int data) { pthread_mutex_lock(&b->lock);//上锁 /*等待缓冲区非满*/ if (b->writepos == 0){ printf("第十七个数,wait for not full\n"); pthread_cond_signal(&b->notempty); pthread_cond_wait(&b->notfull,&b->lock); } /*写数据并且指针前移*/ b->buffer[b->writepos] = data; b->writepos++; if (b->writepos >= BUFFER_SIZE) b->writepos = 0; /*设置缓冲区非空信号*/ pthread_mutex_unlock(&b->lock); if (data == -1){ printf("最后,生产任务结束\n"); pthread_cond_signal(&b->notempty); } } /*--------------------------------------------------------*/ /*从缓冲区中读出一个整数 */ int get(struct prodcons * b) { int data; pthread_mutex_lock(&b->lock); /* 等待缓冲区非空*/ if (0 == b->readpos){ pthread_cond_signal(&b->notfull); pthread_cond_wait(&b->notempty,&b->lock); printf("wait for not empty\n"); } /* 读数据并且指针前移 */ data = b->buffer[b->readpos]; b->readpos++; if (b->readpos >= (BUFFER_SIZE)) b->readpos = 0; /* 设置缓冲区非满信号*/ pthread_mutex_unlock(&b->lock); return data; } /*--------------------------------------------------------*/ #define OVER (-1) struct prodcons buffer; /*--------------------------------------------------------*/ void * producer(void * data) { int n; for (n = 0; n <= 96; n++) { printf(" put-->%d\n", n); put(&buffer, n); } put(&buffer, OVER); printf("producer stopped!\n"); return NULL; } /*--------------------------------------------------------*/ void * consumer(void * data) { int d; while (1) { d = get(&buffer); if (d == OVER ) break; printf(" %d-->get\n", d); } printf("consumer stopped!\n"); return NULL; } /*--------------------------------------------------------*/ int main(void) { pthread_t th_a, th_b; void * retval; init(&buffer); pthread_create(&th_a, NULL, producer, 0); pthread_create(&th_b, NULL, consumer, 0); /* 等待生产者和消费者结束 */ pthread_join(th_a, &retval); pthread_join(th_b, &retval); return 0; }

2023-06-08 上传
2023-05-30 上传
2023-05-29 上传