Java编程100例包括详细步骤

上传人:bei****lei 文档编号:188046592 上传时间:2023-02-17 格式:DOC 页数:20 大小:310.47KB
收藏 版权申诉 举报 下载
Java编程100例包括详细步骤_第1页
第1页 / 共20页
Java编程100例包括详细步骤_第2页
第2页 / 共20页
Java编程100例包括详细步骤_第3页
第3页 / 共20页
资源描述:

《Java编程100例包括详细步骤》由会员分享,可在线阅读,更多相关《Java编程100例包括详细步骤(20页珍藏版)》请在装配图网上搜索。

1、Error! No text of specified style in document.第1章 变幻多姿的图表1.1 金字塔图案1问题描述打印出金字塔图案,如图1.1所示。2问题分析这个问题是一个很经典的循环应用的题目。我们都知道,打印输出的时候,都是从最左端输出,而这里,第一个星号是在中间。这实际是因为星号之前有很多空格。当我们使用问号来表示空格,实际的输出效果应该是图1.2的形式。 图1.1 金字塔图1.2 金字塔的分析图从图1.2分析,我们就可以发现这个题目的奥秘了。(1)确定程序框架从图1.2中,我们可以发现,一共需要打印5行,而每一行都是打印几个空格,然后再打印几个星号。这样我们

2、就可以写出程序框架了。程序框架代码如下:public class Ch1_1 public static void main(String args) * for(i=1;i=5;i+)/循环5次,打印5行 /打印若干个空格 /打印若干个星号 由于我们这里明确知道打印的行数,所以我们使用for循环来实现。下面我们就需要考虑如何打印每行的星号。(2)寻找空格和星号的规律从图1.2中,我们可以发现:第1行的空格为4个,第2行是3个,第3行是2个,每行依次递减,直至最后一行空格数为0;而星号数目是第1行是1个,第2行是3,第3行是5,每行依次递增2,直至最后一行星号数为9。总结数据,我们可以得到表1

3、.1所示的规律。表1.1 空格和星号的规律行数空格数星号数145111*21235232*21325353*21415474*21505595*21规律依次递减15行数依次递增2行数*21从表1.1中,我们不难发现行数和空格数、星号数之间有一种很有趣的联系。根据这个联系,我们就可以考虑完善我们上面的程序了。(3)打印空格数由于每行空格数有着“5行数”的规律。所以在第i行的时候,空格数就为5i。所以我们只要把5i个空格打印出来即可。对应代码如下:for(i=1;i=n;i+)for(j=1;j=n-i;j+)/根据外层行号,输出星号左边空格System.out.print( );虽然每行的空格数

4、不同,但是对于特定的行,其空格数是固定的,所以循环打印的次数是确定的。所以这里同样适用了for循环。(4)打印星号数由于每行星号数有着“行数*21”的规律。所以在第i行的时候,星号数就为2*i1。所以我们只要把2*i1个星号打印出来即可。对应代码如下:for(i=1;i=5;i+)for(k=1;k=2*i-1;k+)/根据外层行号,输出星号个数System.out.printf(*);(5)完整程序现在我们就需要把刚才的程序进行组合,构成我们的完整程序。import java.util.Scanner;public class Ch1_1 public static void main(St

5、ring args) int i,j,k,n;Scanner input=new Scanner(System.in);System.out.print(请输入金字塔层数:);n=input.nextInt(); /外层循环控制层数for(i=1;i=n;i+) /根据外层行号,输出星号左边空格for(j=1;j=n-i;j+)System.out.print( ); /根据外层行号,输出星号个数for(k=1;k=2*i-1;k+)System.out.printf(*); /一行结束,换行System.out.printf(n);(6)扩展训练为了方便大家训练,我们提供几个金字塔图案的同胞

6、兄弟倒金字塔、直角三角形,如图1.3所示。大家可以尝试和它们过过招。图1.3 各种形状图案1.2 九九乘法表1问题描述输出九九乘法口诀表,如图1.4所示。图1.4 九九乘法口诀表2问题分析观察九九乘法口诀表,可以得出图表的规律:总共有9行,第几行就有几个表达式。同时要注意每行表达式的规律:第j行,表达式就从j*1开始,一直到j*j结束,共有j个表达式,这个效果可以通过一次循环实现。这样的话,正好可以通过双重循环来控制输出,外层循环控制行数,内层循环控制列。还有个地方需要注意的是,内层和外层之间的联系,内层列的个数是根据外层的行数来控制的。(1)确定程序框架从图1.4中,我们可以发现,一共需要打

7、印9行,每行又有若干个表达式,可以通过双重循环来实现,外层循环控制行数,内层循环控制列,这样我们就可以写出程序框架了。程序框架代码如下:public class Ch1_2 public static void main(String args) /外循环控制行数for(int i=1;i10;i+) /内循环控制每行表达式个数for(int j=1; j=n; j+) /输出表达式 /一行结束换行System.out.println(); (2)寻找每行表达式个数规律从图1.4中,我们可以发现,第1行一个表达式,第2行两个表达式,第3行三个表达式,第几行就有几个表达式,所以内循环控制列的个数

8、的变量n等于控制外循环个数的变量i,所以内循环代码就可以写成如下形式:for(int j=1; j=i; j+) /内循环控制每行表达式个数,i代表行数(3)表达式写法表达式的写法都是一致:乘数1*乘数2=积。从图1.4中,我们可以发现每行表达式的规律:第i行,表达式就从i*1开始,一直到i*j结束。乘数1不变,一直是i,其实就是行数,乘数2从1变化到j,正好与内循环变量变化一样,所以乘数2就可以用j表示。所以表达式的写法如下:i+*+j+=+i*j /i代表行,j代表列(4)完整程序现在我们就需要把刚才的程序进行组合,构成我们的完整程序:public class Ch1_2 public s

9、tatic void main(String args) /外循环控制行数for(int i=1;i10;i+) /内循环控制每行表达式个数for(int j=1; j=i; j+) System.out.print( +i+*+j+=+(i*j); /一行结束换行System.out.println(); (5)运行结果运行程序,结果如图1.5所示。图1.5 程序输出结果1.3 余 弦 曲 线1问题描述在屏幕上画出余弦函数cos(x)曲线,如图1.6所示。图1.6 余弦函数cos(x)曲线2问题分析连续的曲线是由点组成的,点与点之间距离比较近,看上去就是曲线了,画图的关键是画出每个点。Jav

10、a提供了三角函数方法,直接调用cos()方法就可以根据x坐标计算出y坐标。需要注意的是,cos()方法输入的参数是弧度值,要进行坐标转换,同样,得到的结果也要进行转换处理。从图1.6中可以看出,这条余弦曲线有两个周期,我们可以把x坐标控制在0720。(1)确定程序框架从图1.6中,我们可以发现,整个图形包括x轴、y轴及余弦曲线。控制台不方便输出图形,这里以Applet形式输出。这样我们就可以写出程序框架了,代码如下:public class Ch1_3 extends Applet int x,y;public void start()/当一个Applet被系统调用时,系统会自动调用 star

11、t()方法Graphics g=getGraphics();/画画之前,必须先取得画笔/画x轴/画y轴/画cos(x)曲线(2)画x轴为了画出图1.6所示效果,我们可以把坐标原点设定为(360,200),x轴就是从左到右的很多点组成,通过循环语句很容易实现,代码如下:for(x=0;x=750;x+=1)g.drawString(,x,200);/画x轴细心的读者会发现,x轴上还有个箭头,这个是如何实现的呢,其实很简单,是由两条线段交汇而成。为方便起见,两条线段都与x轴成45角,很容易得到表达式的方程:y=x550,y=950x。代码如下:for(x=740;x=750;x+=1)g.draw

12、String(,x,x-550); /x轴上方斜线g.drawString(,x,950-x); /x轴下方斜线(3)画y轴参考上面x轴的绘制,很容易画出y轴,代码如下:/y轴for(y=0;x=385;y+=1)g.drawString(,360,y);/画y轴/y轴箭头for(x=360;x=370;x+=1)g.drawString(,x-10,375-x);g.drawString(,x,x-355);(4)画cox(x)曲线图形的主体是cox(x)曲线,从图1.6中可以看出,这条余弦曲线有两个周期,我们可以把x坐标控制在0720。cox(x)返回的结果小于1,为了看到图1.6效果,必

13、须进行放大处理,这里放大了80倍,同时把图形向下平移了200个像素。代码如下:/两个周期,即4for(x=0;x=720;x+=1)a=Math.cos(x*Math. PI/180);y=(int)(200+80*a); /放大80倍并向下平移200个像素g.drawString(,x,y);(5)完整程序现在我们就需要把刚才的程序进行组合,构成我们的完整程序:import java.applet.*;import java.awt.*;public class Ch1_3_2 extends Applet int x,y;public void start() /画画之前,必须先取得画笔G

14、raphics g=getGraphics(); /画x轴、y轴for(x=0;x=750;x+=1)g.drawString(,x,200);if(x=385) g.drawString(,360,x);g.drawString(Y,330,20); /画y轴箭头for(x=360;x=370;x+=1)g.drawString(,x-10,375-x);g.drawString(,x,x-355); /画x轴箭头g.drawString(X,735,230);for(x=740;x=750;x+=1)g.drawString(,x,x-550);g.drawString(,x,950-x)

15、; /画cox()曲线for(x=0;x=720;x+=1)double a=Math.cos(x*Math. PI/180+Math.PI);y=(int)(200+80*a);/放大80倍并向下平移200个像素g.drawString(,x,y);Ch1_3.html网页代码如下:余弦曲线测试 applet code=Ch1_3.class width=900height=600 (6)运行结果把Ch1_3.java文件编译后的Ch1_3.class文件放到Ch1_3.html网页同一目录下,直接用IE浏览器打开Ch1_3.html,运行程序,结果如图1.6所示。3扩展训练前面介绍的余弦曲

16、线的绘制,我们看到的是一个完整的静态图形,能否动态地展现绘制的过程?答案是肯定的,我们可以采用线程的方式来实现,参考代码如下:import java.applet.Applet;import java.awt.Color;import java.awt.Graphics;public class donghua_cos extends Applet implements Runnable/通过实现Runnable接口实现线程操作int x,y;double a;int xpos=0;Thread runner;boolean painted=false;public void init() /

17、Applet创建即启动执行,坐标初始化/ TODO Auto-generated method stubGraphics g=getGraphics();/画画之前,必须先取得画笔for(x=0;x=750;x+=1)/画x轴 g.drawString(,x,200); if(x=385) g.drawString(,360,x); g.drawString(Y,330,20);/画y轴for(x=360;x=370;x+=1)/画y轴箭头 g.drawString(,x-10,375-x); g.drawString(,x,x-355);g.drawString(X,735,230);for

18、(x=740;x=750;x+=1)/画x轴箭头 g.drawString(,x,x-550); g.drawString(,x,950-x);public void start() /Applet创建后自启动方法/ TODO Auto-generated method stubif(runner=null)runner=new Thread(this);/通过Thread类来启动Runnablerunner.start();/线程启动public void stop() /Applet生命周期结束后自启动方法/ TODO Auto-generated method stubif(runner

19、!=null)runner=null;/结束线程public void run() /线程运行方法/ TODO Auto-generated method stubwhile(true)for(xpos=0;xpos900-90;xpos+=3)/循环设置曲线x轴坐标边界repaint();/调用paint()方法tryThread.sleep(100);/线程休息100毫秒catch(InterruptedException e)if(painted)painted=false;public void paint(Graphics g)/画图方法for(x=0;x=xpos;x+=1)/循环

20、画曲线 a=Math.cos(x*Math. PI/180+Math.PI); y=(int)(200+80*a);/放大80倍并向下平移200个像素 g.drawString(,x,y);painted=true;1.4 奥运五环旗1问题描述图1.7 奥运五环旗在屏幕上画出奥运五环旗,如图1.7所示。2问题分析观察奥运五环旗的图案,直观的感觉,由五个圆组成,每个圆的颜色不一样,大小一样,按照一定的位置摆放,找到圆心坐标的规律,就可以通过Graphics类提供的绘制椭圆的方法drawOval()来实现画圆操作。(1)确定程序框架奥运五环旗由五个不同颜色的圆组成,我们可以通过循环依次输出五个圆环

21、。控制台不方便输出图形,这里以Applet形式输出。这样我们就可以写出程序框架了,代码如下:public class Ch1_4_3 extends Applet /简单实用为主/paint()方法是由浏览器调用的。每当Applet需要刷新的时候都会调用该方法public void paint(Graphics g) for(int i=0;i5;i+) /设置当前圆的颜色/根据圆心坐标画出当前圆 (2)圆环的坐标分析分析出圆的圆心坐标是画图的关键,对照图1.8标示,分析圆的位置规律。O图1.8 奥运五环旗坐标分析上面三个圆的圆心a、b、c的y坐标相同,下面两个圆的圆心d、e的y坐标相同,ab

22、=bc=ad=de,为保证两个圆相交,两个圆的圆心距离必须小于2r(r代表圆的半径)。f为ab的中点,adf组成直角三角形,af=ad/2,只要给定五个圆的任何一个圆心坐标,就可以推倒出其他几个圆的圆心坐标。我们这里使用数组来存放每个圆环的颜色、坐标。代码如下:/clr存储颜色private Color clr=Color.blue,Color.black,Color.red,Color.yellow,Color. green;/x存储圆心的x坐标private int x=100,136,172,118,154; /y存储圆心的y坐标private int y=60,60,60,91,91;

23、/r代表半径Private r=20;(3)画五环旗根据上面给出的圆的圆心坐标,通过循环语句控制,依次画出每个圆环。代码如下:for(int i=0;i5;i+)/设置颜色g.setColor(clri);/画圆,第一个参数代表圆心x坐标,第二个参数代表圆心y坐标g.drawOval(xi, yi, d, d);(4)完整程序现在我们就需要把刚才的程序进行组合,构成我们的完整程序:import java.awt.*;import java.awt.event.*;import java.applet.Applet;import java.awt.Color;import java.awt.Fo

24、nt;public class Ch1_4 extends Applet private Color clr=Color.blue,Color.black,Color.red,Color.yellow,Color.green;/clr存储颜色private int x=100,136,172,118,154; /x存储圆心的x坐标private int y=60,60,60,91,91;/y存储圆心的y坐标private int xy=100,60,136,60,172,60,118,91,154,91;/存储圆心的坐标private int r=20,d=40;public void pai

25、nt(Graphics g)/画图方法 Font font = new Font(楷体,Font.PLAIN,20);/文字字体、大小g.setFont(font);for(int i=0;i5;i+)/循环5次,画5个圆环g.setColor(clri);g.drawOval(xi, yi, d, d);/d代表椭圆外切矩形的长宽,相等代表圆g.setColor(Color.blue);/设置颜色g.setFont(font);g.drawString(奥运五环旗,120,169);/END PAINT/END CLASS图1.9 程序输出结果(5)运行结果再编写一个测试Ch1_4.html

26、文件,内容参考前面的代码,把Ch1_4.java文件编译后的Ch1_4.class文件放到Ch1_4.html文件同一目录下,直接用IE浏览器打开Ch1_4.html,运行程序,结果如图1.9所示。3扩展训练图1.9所示奥运五环旗没有图1.7看着舒服,线条有点细,如果能加粗就好了,可惜Graphics类创建的画笔的粗细是默认的,我们不能改变它。有人提出一个圆环可以由两个圆重叠而成,通过在一个圆的内部紧贴一个稍小的圆即可达到加粗线条的目的,这个思路是可以的,感觉比较麻烦哟,感兴趣可以试一下,有没有简单点的办法?答案是肯定的。我们可以通过Graphics2D类来实现,Graphics2D类扩展Gr

27、aphics类,以提供对几何形状、坐标转换、颜色管理和文本布局更为复杂的控制。参考代码如下:public void paint(Graphics g) Font font = new Font(楷体,Font.PLAIN,20);/文字字体、大小BasicStroke a=new BasicStroke(3.0f);/粗细设置对象(Graphics2D)g).setStroke(a);/设置粗细for(int i=0;i5;i+)/循环5次,画5个圆环(Graphics2D)g).setColor(clri);/设置圆环的颜色(Graphics2D)g).drawOval(xi, yi, d,

28、 d);g.setColor(Color.blue);/设置文字颜色g.setFont(font);g.drawString(奥运五环旗,120,169);/END PAINT1.5 杨 辉 三 角1问题描述根据输入行数,打印出杨辉三角形,如图1.10所示。2问题分析观察杨辉三角形的图案,可以发现其中的规律:三角形的竖边和斜边都是“1”,三角形里面的任意一个数字正好等于它正上方的数字和左上角的数字两个数字之和。第几行就有几个数字,可以把它补充成如图1.11所示效果。 图1.10 杨辉三角形 图1.11 方阵方阵(行列相等的矩阵)大家都很熟悉了,可以通过二维数组来处理方阵,一个双重循环就能实现,

29、外循环控制行数,内循环控制列来完成方阵内数字的计算和存储。(1)确定程序框架由前面的问题分析可知,先从键盘接收杨辉三角的高度,然后通过二维数组计算存储杨辉三角,最后把杨辉三角打印出来。程序框架代码如下:public class Ch1_5 public static void main(String args) System.out.print(请输入行数:); Scanner scanner = new Scanner(System.in); int num = scanner.nextInt();/键盘接收行数 int ary = getTriangle(num);/得到杨辉三角 prin

30、t(ary);/打印杨辉三角(2)得到杨辉三角由前面的问题分析可知,用二维数组计算存储杨辉三角,杨辉三角竖边、斜边都为1,可以先赋值,然后再给中间元素赋值,当前位置的值等于它的上方数和左上角上的数之和。程序代码如下:private static int getTriangle(int num) int ary = new intnumnum;/用二维数组存储 for(int i = 0; i ary.length; i+)/竖边、斜边置1aryi0 = 1;aryii = 1; for(int i = 1; i ary.length; i+)/外循环控制行数for(int j = 1; j =

31、 i; j+)/内循环控制列/里面部分,等于当前位置的上方和左上角之和aryij = aryi-1j-1 + aryi-1j;return ary;(3)打印杨辉三角杨辉三角保存在二维数组中,通过一个双重循环就可以打印出来,但是要注意的是,不需要把所有元素都打印出来,内循环列的控制要小于等于当前行数。程序代码如下:private static void print(int ary)for(int i=0;iary.length;i+)/外循环控制行for(int j=0;j=i;j+)/内循环控制列System.out.printf( %-3d, aryij);System.out.print

32、ln();/换行(4)完整程序现在我们就需要把刚才的程序进行组合,构成我们的完整程序:import java.util.Scanner;public class Ch1_5 public static void main(String args) System.out.print(请输入行数:); Scanner scanner = new Scanner(System.in); int num = scanner.nextInt();/从键盘接收行数 int ary = getTriangle(num);/得到杨辉三角 print(ary);/打印杨辉三角/得到杨辉三角private sta

33、tic int getTriangle(int num) int ary = new intnumnum;/用二维数组存储 for(int i = 0; i ary.length; i+)/竖边、斜边置1aryi0 = 1;aryii = 1; for(int i = 1; i ary.length; i+)/外循环控制行for(int j = 1; j = i; j+)/内循环控制列/里面部分,等于当前位置的上方和左上角之和aryij = aryi-1j-1 + aryi-1j;return ary;private static void print(int ary)for(int i=0;

34、iary.length;i+)/外循环控制行for(int j=0;j=i;j+)/内循环控制列System.out.printf( %-3d, aryij);System.out.println();/输出换行(5)运行结果运行程序,结果如图1.12所示。图1.12 程序输出结果3扩展训练图1.12输出的杨辉三角是直角三角形,能不能输出等腰三角形呢?答案是肯定的。等腰三角形类似于前面的金字塔图案,参考前面介绍的思路,不难输出等腰三角形。(1)参考代码import java.util.*;public class Ch1_5_2 public static void main(String a

35、rgs) Scanner in = new Scanner(System.in);/获取控制台输入对象 System.out.print(请输入行号: ); int m = in.nextInt();/从键盘接收输入 int n=2*m-1;/列元素个数 int arr=new intmn; for(int i=0;im;i+)/外循环控制行 for(int j=0;jn;j+)/内循环控制列 if(j=(m+i)/输出等腰三角形两边空格 System.out.print( ); else if(j=(m-i-1)|(j=(m+i-1)/计算并输出等腰三角形两个腰 arrij=1; Syste

36、m.out.printf(%-3d,arrij); else if(i+j)%2=0&m%2=0|(i+j)%2=1&m%2=1)/中间默认数字0用空格替换 System.out.print( ); else/计算并输出中间数字 arrij=arri-1j-1+arri-1j+1; System.out.printf(%-3d,arrij); System.out.println();/输出换行 (2)运行结果运行程序,结果如图1.13所示。图1.13 程序输出结果1.6 国际象棋棋盘1问题描述打印出国际象棋棋盘,如图1.14所示。图1.14 国际象棋棋盘2问题分析观察国际象棋棋盘的图案,可以

37、发现其中的规律:棋盘由八行八列黑白方块相间组成,可以用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方块还是白方块。这里我们使用了Swing的标签组件JLable,通过设置JLabel组件的背景色和透明度来实现黑白方块。(1)确定程序框架这是一个绘图案例,这里我们采用JFrame创建窗口,然后在窗口里添加JLabel标签组件,通过前面的问题分析可知,JLabel标签要设置一些属性实现黑白方块,然后显示窗口,实现如图1.14所示的效果。程序框架代码如下:public class Ch1_6 public static void main(String args) JFrame f=new

38、 JFrame(国际象棋棋盘);/窗口属性设置 JLabel l = new JLabel();/生成标签实例 /标签属性设置 f.add(l);/添加标签 f.setVisible(true);/显示窗口(2)窗口属性设置窗口属性设置包括窗口大小、位置等设置,其中窗口大小要满足能够容纳黑白方格,这里指定黑白方格大小为:20*20,那么窗口属性大小大概为:168*195。窗口位置可以随便指定,这里指定为:(350,200)。程序代码如下:/窗口设置大小f.setSize(168,195); /边框的长和宽 /窗口设置位置Point point=new Point(350,200);f.setL

39、ocation(point);ublic class Ch1_6 (3)标签属性设置标签的属性主要是标签的位置及背景色,棋盘是由八行八列黑白方块相间组成,可以通过双重循环来实现,用i控制行,j来控制列,位置很容易设置,根据i+j的和的变化来设置背景色,表示黑方块还是白方块。程序代码如下:int grids=8;/行数和列数int gridsize=20;/单元格的高和宽 for(int i=0; igrids; i+)for(int j=0; jgrids; j+)JLabel l = new JLabel();/生成标签实例l.setSize(gridsize,gridsize);/设置标签

40、大小l.setLocation(i*gridsize,j*gridsize);/设置标签位置if(i+j)%2=0) /当小方格的坐标和刚好是偶数时,l.setBackground(Color.black); /设置方格为黑色l.setOpaque(true); /设置为不透明 elsel.setBackground(Color.white); /设置方格为白色l.setOpaque(true); /设置为不透明 l.setBorder(BorderFactory.createLineBorder(Color.black); /设置边界为黑色(4)完整程序现在我们就需要把刚才的程序进行组合,构

41、成我们的完整程序:import java.awt.Color;import java.awt.Point;import javax.swing.BorderFactory;import javax.swing.JFrame;import javax.swing.JLabel;public class Ch1_6 public static void main(String args) JFrame f=new JFrame(国际象棋棋盘);/创建窗口/窗口设置大小f.setSize(168,195); /边框的长和宽 /窗口设置位置 Point point=new Point(350,200)

42、; f.setLocation(point); int grids=8;/行数和列数int gridsize=20;/单元格的高和宽 for(int i=0; igrids; i+)/外循环控制行 for(int j=0; jgrids; j+)/内循环控制列 JLabel l = new JLabel();/生成标签实例 l.setSize(gridsize,gridsize);/设置标签大小 l.setLocation(i*gridsize,j*gridsize);/设置标签位置 if(i+j)%2=0) /当小方格的坐标和刚好是偶数时, l.setBackground(Color.bla

43、ck); /设置方格为黑色 l.setOpaque(true); /设置为不透明 else l.setBackground(Color.white); /设置方格为白色l.setOpaque(true); /设置为不透明 l.setBorder(BorderFactory.createLineBorder(Color.black); /设置边界为黑色f.add(l);/添加标签 f.setVisible(true);/显示窗口。图1.15 国际象棋棋盘1.7 心 形 图1问题描述打印心形图案,如图1.16所示。图1.16 心形图案2问题分析心形图案的实现,重点是心形函数r=a(1sin),据说

44、这是笛卡尔死前寄出的最后一封情书的内容,这里面隐藏着一个刻骨铭心的秘密:“一生只为等待能手绘这个函数给我的人”。心形函数要做直角坐标系转换,然后投影到xOy平面上,就可以调用画椭圆方法来实现画心形图案。(1)确定程序框架为了提高图像的显示效果,须采用双缓冲技术。首先初始化缓冲区,接着绘制图像,然后再显示在Applet窗口中。程序框架代码如下:public class Ch1_7 extends Applet int width, height; Image image; /缓冲区对象 Graphics g1; public void init()/Applet初始化时调用 setBackgro

45、und(Color.black); /设置背景 this.setSize(350, 310); width = getSize().width; /获得窗口宽度 height = getSize().height; image = createImage(width, height); /创建图像对象 g1 = image.getGraphics(); public void paint(Graphics g)/绘图方法 g1.clearRect(0, 0, width, height); g1.setColor(Color.red); /在缓冲区绘制心形图案 /显示缓存区的可变Image对象

46、 g.drawImage(image, 0, 0, this); (2)绘制图案由前面的问题分析可知,心形函数为r=a(1sin),要做直角坐标系转换,然后投影到xOy平面上,坐标确定下来后调用画椭圆方法来画心形图案上的点。程序代码如下:for(i = 0; i = 90; i+) /控制横向变化 for(j = 0; j = 90; j+)/控制竖向变化 /转换为直角坐标 r = Math.PI / 45 * i * (1 - Math.sin(Math.PI / 45 * j) * 18; x = r * Math.cos(Math.PI / 45 * j) * Math.sin(Math.PI / 45 * i) + width / 2; /为了在中间显示,加了偏移量 y = -r * Math.sin(Math.PI / 45 * j) + height / 4;/为了在中间显示,加了偏移量 g1.fillOval(int) x, (int)y, 2,2);/绘制点19

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!