源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
查看: 481|回复: 14

[JSP编程] jsp实现生成中国国旗图片效果代码

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2015-10-30 12:44:34 | 显示全部楼层 |阅读模式
这篇文章主要介绍了jsp实现生成中国国旗图片效果代码,涉及JSP图形绘制及数学运算的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下

本文实例讲述了jsp实现生成中国国旗图片效果代码。分享给大家供大家参考,具体如下:

图片截图如下:

具体代码如下:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page contentType="image/jpeg" import="java.awt.*,
java.awt.image.*,java.util.*,javax.imageio.*,java.awt.Shape.*,java.awt.geom.*,com.sun.image.codec.jpeg.*" %>
<%
 out.clear();
 response.setContentType("image/jpeg");
 response.setHeader("Pragma","No-cache");
 response.setHeader("Cache-Control","no-cache");
 response.setDateHeader("Expires", 0);
 int width =300;
 int height = width/3*2; 
   double maxR = 0.15, minR = 0.05; 
   double maxX = 0.50, maxY = 0.50; 
   double[] minX = {0.75, 0.85, 0.85, 0.75}; 
   double[] minY = {0.35, 0.45, 0.60, 0.70}; 
 BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
 java.awt.Graphics2D g=(java.awt.Graphics2D)image.createGraphics();
 g.clearRect(0, 0,width,height);
 g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
 //画棋面
 g.setColor(java.awt.Color.red);
 g.fillRect(0, 0, width, height);
 //g.fillRect(50, 50, width, height);
 g.setColor(java.awt.Color.yellow);
 //画大五角星
    double ox = height*maxX, oy = height*maxY;
 g.fill(createPentacle(ox,oy,height*maxR,-Math.PI/2)); 
 //画小五角星
    for(int idx =0;idx < 4;idx ++){ 
      double sx = minX[idx]*height, sy = minY[idx]*height; 
      double theta = Math.atan2(oy-sy,ox-sx); 
      g.fill(createPentacle(sx,sy,height*minR,theta)); 
    } 
 g.dispose();
 out.clearBuffer(); 
 out = pageContext.pushBody();
 //ImageIO.write(image, "JPEG", response.getOutputStream());
  ServletOutputStream outStream = response.getOutputStream();
    JPEGImageEncoder encoder =JPEGCodec.createJPEGEncoder(outStream);
    encoder.encode(image);
    outStream.close();
%>
<%!
 public static java.awt.Shape createPentacle(double sx, double sy, double radius,double theta) {
 final double arc = Math.PI / 5;
 final double rad = Math.sin(Math.PI / 10) / Math.sin(3 * Math.PI / 10);
 GeneralPath path = new GeneralPath();
 path.moveTo(1, 0);
 for (int idx = 0; idx < 5; idx++) {
  path.lineTo(rad * Math.cos((1 + 2 * idx) * arc),rad * Math.sin((1 + 2 * idx) * arc));
  path.lineTo(Math.cos(2 * (idx + 1) * arc),Math.sin(2 * (idx + 1) * arc));
 }
 path.closePath();
 AffineTransform atf = AffineTransform.getScaleInstance(radius, radius);
 atf.translate(sx / radius, sy / radius);
 atf.rotate(theta);
 return atf.createTransformedShape(path);
 }
%>

将代码另存为jsp文件,放在运行目录下执行即可。

代码在tomcat6.0下测试通过

希望本文所述对大家JSP程序设计有所帮助。

回复

使用道具 举报

4

主题

1万

回帖

262

积分

中级会员

Rank: 3Rank: 3

积分
262
发表于 2022-8-12 12:31:06 | 显示全部楼层
啦啦啦啦啦啦哈哈哈
回复 支持 反对

使用道具 举报

4

主题

1万

回帖

262

积分

中级会员

Rank: 3Rank: 3

积分
262
发表于 2022-9-18 11:54:17 | 显示全部楼层
。。。。。。。。。。。。。。。
回复 支持 反对

使用道具 举报

2

主题

1万

回帖

381

积分

中级会员

Rank: 3Rank: 3

积分
381
发表于 2022-12-2 22:50:26 | 显示全部楼层
啊啊啊啊啊啊啊啊啊啊啊啊啊啊
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-3-5 21:54:56 | 显示全部楼层
你们谁看了弄洒了可能
回复 支持 反对

使用道具 举报

3

主题

1万

回帖

163

积分

注册会员

Rank: 2

积分
163
发表于 2023-4-3 01:32:31 | 显示全部楼层
的沙发水电费水电费
TS人妖演出表演服务q3268336102电话13168842816
回复 支持 反对

使用道具 举报

16

主题

1万

回帖

376

积分

中级会员

Rank: 3Rank: 3

积分
376
发表于 2023-8-7 06:45:05 | 显示全部楼层
啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦啦
回复 支持 反对

使用道具 举报

27

主题

1万

回帖

331

积分

中级会员

Rank: 3Rank: 3

积分
331
发表于 2023-10-3 14:37:42 | 显示全部楼层
天天源码社区论坛
回复 支持 反对

使用道具 举报

3

主题

1万

回帖

172

积分

注册会员

Rank: 2

积分
172
发表于 2023-10-15 14:01:10 | 显示全部楼层
论坛有你更精彩!
回复 支持 反对

使用道具 举报

1

主题

1万

回帖

176

积分

注册会员

Rank: 2

积分
176
发表于 2023-11-5 12:00:46 | 显示全部楼层
谢谢下载来看看
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2024-9-21 10:46 , Processed in 0.087692 second(s), 26 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表