大家好,今天小编来为大家解答fillrect这个问题,collection商务含义很多人还不知道,现在让我们一起来看看吧!
在网页设计和图形编程的世界里,有许多功能强大的工具和函数。其中,fillRect 函数就像一位低调的幕后英雄,默默地在幕后支撑着各种图形绘制工作。今天,就让我们一起来揭开它的神秘面纱,深入了解这个在许多开发者眼中看似普通,实则至关重要的函数。
一、什么是fillRect?
让我们来明确一下什么是 fillRect。简单来说,fillRect 是一个用于在画布上绘制矩形的函数。它接受四个参数:矩形的左上角 x 坐标、左上角 y 坐标、矩形的宽度和高度。当调用这个函数时,它会填充一个矩形的区域,而不是绘制一个边框。
“`
canvas.fillStyle = ‘red’;
canvas.fillRect(10, 10, 100, 100);
“`
上面的代码会在画布上绘制一个 100×100 的红色矩形。
二、fillRect 的应用场景
fillRect 函数的应用场景非常广泛。以下是一些常见的应用:
| 应用场景 | 代码示例 |
|---|---|
| 绘制按钮 | canvas.fillStyle=’blue’;canvas.fillRect(50,50,100,50); |
| 绘制表格边框 | canvas.strokeStyle=’black’;canvas.strokeRect(10,10,100,100); |
| 绘制游戏界面 | canvas.fillStyle=’green’;canvas.fillRect(50,50,100,100);canvas.fillText(‘Hello,world!’,50,80); |
| 绘制图表 | canvas.fillStyle=’red’;canvas.fillRect(10,10,100,100);canvas.fillRect(120,10,100,100);canvas.fillText(‘1’,100,60);canvas.fillText(‘2’,220,60); |
三、fillRect 的优化技巧
虽然 fillRect 函数本身非常简单,但在实际应用中,我们还可以通过一些技巧来提高效率。
1. 合理设置canvas.fillStyle和canvas.strokeStyle:在绘制多个图形时,可以预先设置好颜色,避免重复设置。
2. 使用clipPath:当需要绘制多个重叠的图形时,可以使用 clipPath 来控制图形的显示区域,提高绘制效率。
3. 合理利用canvas的transform属性:通过变换画布的坐标系,可以减少重复绘制的工作。
四、fillRect 与其他绘图函数的区别
虽然 fillRect 函数的功能相对简单,但它与其他绘图函数也有一些区别:
| 绘图函数 | 功能 | 优点 | 缺点 |
|---|---|---|---|
| fillRect | 绘制矩形 | 简单易用 | 功能单一 |
| strokeRect | 绘制矩形边框 | 可调整边框样式 | 功能单一 |
| arc | 绘制圆弧 | 可调整圆弧样式 | 功能单一 |
| beginPath&moveTo&lineTo | 绘制任意图形 | 可绘制任意图形 | 复杂性高 |
五、总结
fillRect 函数虽然功能单一,但在网页设计和图形编程中扮演着重要的角色。它简单易用,可以轻松地绘制各种矩形,是开发者们不可或缺的工具之一。
希望这篇文章能帮助你更好地了解 fillRect 函数,让你在今后的工作中更加得心应手。如果你有任何疑问或建议,欢迎在评论区留言交流。
graphics类 java 怎么用
Graphics类提供基本绘图方法,Graphics2D类提供更强大的绘图能力。
Graphics类提供基本的几何图形绘制方法,主要有:画线段、画矩形、画圆、画带颜色的图形、画椭圆、画圆弧、画多边形等。
1.画线
在窗口画一条线段,可以使用Graphics类的drawLine()方法:
drawLine(int x1,int y1,int x2,int y2)
例如,以下代码在点(3,3)与点(50,50)之间画线段,在点(100,100)处画一个点。
g.drawLine(3,3,50,50);//画一条线段
g.drawLine(100,100,100,100);//画一个点。
2.画矩形
有两种矩形:普通型和圆角型。
(1)画普通矩形有两个方法:
drawRect(int x,int y,int width,int height):画线框围起来的矩形。其中参数x和y指定左上角的位置,参数width和height是矩形的宽和高。
fillRect(int x,int y,int width,int height):是用预定的颜色填充一个矩形,得到一个着色的矩形块。
以下代码是画矩形的例子:
g.drawRect(80,100,40,25);//画线框
g.setColor(Color.yellow);g.fillRect(20,70,20,30);//画着色块
(2)画圆角矩形也有两个方法:
drawRoundRect(int x,int y,int width, int height, int arcWidth, int arcHeight):是用线围起来的圆角矩形。其中参数x和y指定矩形左上角的位置;参数width和heigth是矩形的宽和高;arcWidth和arcHeight分别是圆角弧的横向直径和圆角弧的纵向直径。
fillRoundRect(int x,int y,int width,int height,int arcWidth,int archeight):是用预定的颜色填充的圆角矩形。各参数的意义同前一个方法。
以下代码是画矩形的例子:
g.drawRoundRect(10,10,150,70,40,25);//画一个圆角矩形
g.setColor(Color.blue); g.fillRoundRect(80,100,100,100,60,40);//涂一个圆角矩形块
g.drawRoundRect(10,150,40,40,40,40);//画圆
g.setColor(Color.red); g.fillRoundRect(80,100,100,100,100,100);//画圆块
可以用画圆角矩形方法画圆形,当矩形的宽和高相等,圆角弧的横向直径和圆角弧的纵向直径也相等,并等于矩形的宽和高时,画的就是圆形。参见上述例子中的注释,前一个是画圆,后一个是涂圆块。
3.画三维矩形
画三维矩形有两个方法:
draw3DRect(int x,int y,int width,int height, boolean raised):画一个突出显示的矩形。其中x和y指定矩形左上角的位置,参数width和height是矩形的宽和高,参数raised是突出与否。
fill3DRect(int x,int y,int width,int height,boolean raised):用预定的颜色填充一个突出显示的矩形。
以下代码是画突出矩形的例子:
g.draw3DRect(80,100,40,25,true);//画一个线框
g.setColor(Color.yellow); g.fill3DRect(20,70,20,30,true);//画一个着色块
4.画椭圆形
椭圆形由椭圆的横轴和纵轴确定。画椭圆形有两个方法:
drawOval(int x,int y,int width,int height):是画用线围成的椭圆形。其中参数x和参数y指定椭圆形左上角的位置,参数width和height是横轴和纵轴。
fillOval(int x,int y,int width,int height):是用预定的颜色填充的椭圆形,是一个着色块。也可以用画椭圆形方法画圆形,当横轴和纵轴相等时,所画的椭圆形即为圆形。
以下代码是画椭圆形的例子:
g.drawOval(10,10,60,120);//画椭圆
g.setColor(Color.cyan);g.fillOval(100,30,60,60);//涂圆块
g.setColor(Color.magenta);g.fillOval(15,140,100,50);//涂椭圆
5.画圆弧
画圆弧有两个方法:
drawArc(int x,int y,int width,int height,int startAngle, int arcAngle):画椭圆一部分的圆弧线。椭圆的中心是它的外接矩形的中心,其中参数是外接矩形的左上角坐标(x,y),宽是width,高是heigh。参数startAngle的单位是“度”,起始角度0度是指3点钟方位.参数startAngle和arcAngle表示从startAngle角度开始,逆时针方向画arcAngle度的弧,约定,正值度数是逆时针方向,负值度数是顺时针方向,例如-90度是6点钟方位。
fillArc(int x,int y,int width, int height, int startAngle, int arcAngle):用setColor()方法设定的颜色,画着色椭圆的一部分。
以下代码是画圆弧的例子:
g.drawArc(10,40,90,50,0,180);//画圆弧线
g.drawArc(100,40,90,50,180,180);//画圆弧线
g.setColor(Color.yellow); g.fillArc(10,100,40,40,0,-270);//填充缺右上角的四分之三的椭圆
g.setColor(Color.green); g.fillArc(60,110,110,60,-90,-270);//填充缺左下角的四分之三的椭圆
6.画多边形
多边形是用多条线段首尾连接而成的封闭平面图。多边形线段端点的x坐标和y坐标分别存储在两个数组中,画多边形就是按给定的坐标点顺序用直线段将它们连起来。以下是画多边形常用的两个方法:
drawPolygon(int xpoints[],int yPoints[],int nPoints):画一个多边形
fillPolygon(int xPoints[],int yPoints[],int nPoints):用方法setColor()设定的颜色着色多边形。其中数组xPoints[]存储x坐标点,yPoints[]存储y坐标点,nPoints是坐标点个数。
注意,上述方法并不自动闭合多边形,要画一个闭合的多边形,给出的坐标点的最后一点必须与第一点相同.以下代码实现填充一个三角形和画一个八边形。
int px1[]={50,90,10,50};//首末点相重,才能画多边形
int py1[]={10,50,50,10};
int px2[]={140,180,170,180,140,100,110,140};
int py2[]={5,25,35,45,65,35,25,5};
g.setColor(Color.blue);
g.fillPolygon(px1,py1,4);
g.setColor(Color.red);
g.drawPolygon(px2,py2,9);
也可以用多边形对象画多边形。用多边形类Polygon创建一个多边形对象,然后用这个对象绘制多边形。Polygon类的主要方法:
Polygon():创建多边形对象,暂时没有坐标点。
Polygon(int xPoints[],int yPoints[],int nPoints):用指定的坐标点创建多边形对象。
addPoint():将一个坐标点加入到Polygon对象中。
drawPolygon(Polygon p):绘制多边形。
fillPolygon(Polygon p):和指定的颜色填充多边形。
例如,以下代码,画一个三角形和填充一个黄色的三角形。注意,用多边形对象画封闭多边形不要求首末点重合。
int x[]={140,180,170,180,140,100,110,100};
int y[]={5,25,35,45,65,45,35,25};
Polygon ponlygon1=new Polygon();
polygon1.addPoint(50,10);
polygon1.addPoint(90,50);
polygon1.addPoint(10,50);
g.drawPolygon(polygon1);
g.setColor(Color.yellow);
Polygon polygon2= new Polygon(x,y,8);
g.fillPolygon(polygon2);
7.擦除矩形块
当需要在一个着色图形的中间有一个空缺的矩形的情况,可用背景色填充一矩形块实现,相当于在该矩形块上使用了“橡皮擦”.实现的方法是:
clearRect(int x,int y, int width,int height):擦除一个由参数指定的矩形块的着色。
例如,以下代码实现在一个圆中擦除一个矩形块的着色:
g.setColor(Color.blue);
g.fillOval(50,50,100,100);g.clearRect(70,70,40,55);
8.限定作图显示区域
用一个矩形表示图形的显示区域,要求图形在指定的范围内有效,不重新计算新的坐标值,自动实现超出部分不显示。方法是clipRect(int x,int y,int width,int height),限制图形在指定区域内的显示,超出部分不显示。多个限制区有覆盖时,得到限制区域的交集区域。例如,代码:
g.clipRect(0,0,100,50);g.clipRect(50,25,100,50);
相当于
g.clipRect(50,25,50,25);
9.复制图形
利用Graphics类的方法copyArea()可以实现图形的复制,其使用格式是:
copyArea(int x,int y,int width,int height, int dx, int dy),dx和dy分别表示将图形粘贴到原位置偏移的像素点数,正值为往右或往下偏移是,负值为往左或往上偏移量。位移的参考点是要复制矩形的左上角坐标。
例如,以下代码示意图形的复制,将一个矩形的一部分、另一个矩形的全部分别自制。
g.drawRect(10,10,60,90);
g.fillRect(90,10,60,90);
g.copyArea(40,50,60,70,-20,80);
g.copyArea(110,50,60,60,10,80);
文章到此结束,如果本次分享的fillrect和collection商务含义的问题解决了您的问题,那么我们由衷的感到高兴!




