RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
图像翻转java代码 java获取图片旋转角度

java根据文字旋转图片方法

1、java本身肯定有这样的api来实现基本的文字转图片功能,果不其然,经过一番简单搜索,发现java.awt.Graphics类有一个方法,如下

创新互联公司专业为企业提供新平网站建设、新平做网站、新平网站设计、新平网站制作等企业网站建设、网页设计与制作、新平企业网站模板建站服务,10多年新平做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

2、经过简单测试,发现上述方法果然只能实现基本的文字转图片功能,无法换行,然后搜到一篇博文java文字转换成图片输出,算是一个比较完整的demo了,笔者的最终代码就是在此文代码的基础上修改而成,此demo中的文字也就一行不到的文字,所以无法看到换行的效果

3、刚开始打出来的图片上文字是方块乱码,解决方法是先在jdk目录下添加相应字体,如果依然乱码,要修改ide编辑器bin目录下的配置文件

4、为了实现真正的换行效果,笔者在drawstring方法外围加了一个for循环,就可以实现换行效果

5、如果文字过多的话,可能一张图片放不下,之前的做法是图片的高度不固定,根据文字的行数来确定,发现那样做的话,文字非常多的话图片就非常长,所以还是要生成多张图片,图片的张数就通过文字的总行数除以每张图片(固定宽高)的行数来得到

6、如果一行文字过多的话,超过图片宽度的文字会被隐藏掉,所以需要提前对文字进行处理,使用集合list来处理,先获取每个字的宽度,再获取每行能放多少字,再判断如果一行文字大于每行能存放的字数时,就进行切割处理

java 图像翻转 。。求解释 代码!!

在操作二维或三维的图形图像上,长期以来人们总结出了一些常用的变换矩阵,这些矩阵就像公式和定理一样被开发人员使用,楼主可以把这些矩阵当成公式来记忆,就像我们小时候背加法、乘法口诀一样。

如果楼主想了解得更深入一些,请往下看:

[ x']   [  m00  m01  m02  ] [ x ]   [ m00x + m01y + m02 ]

[ y'] = [  m10  m11  m12  ] [ y ] = [ m10x + m11y + m12 ]

[ 1 ]   [   0    0    1   ] [ 1 ]   [         1         ]

上面的式子是jdk文档中复制过来的,就是变换时的运算过程,也就是说变换后的坐标x'、y'是由一个3*3的矩阵与原坐标x、y相乘得出的,其中的m00~m12就是AffineTransform构造方法中的六个参数,另外,式子中的最后一行是固定的。

矩阵乘法就不用说了吧,最后得出的结果就是上式中的最后一列,可能写成下面这样会更容易理解:

x' = m00x + m01y + m02

y' = m10x + m11y + m12

看出什么了吗?其实这就是二维平面直角坐标系中的两个很简单的二元一次方程而已,方程定义的就是横纵坐标变换的规则。

以水平翻转为例,水平翻转是以图形/图像的垂直中线为轴来翻转的,因此任何一个点(x,y)变换后的坐标应该是y坐标不变,x坐标变为-x+width-1,即(-x+width-1,y),之所以减1是因为垂直中轴上的点不应该改变。

理解了上面的变换过程之后,将结果带入上面的两个二元一次方程,可以得出

m00=-1、m01=0、m02=width-1

m10=0、m11=1、m12=0

正好是你给的代码中的六个值(AffineTransform构造方法中的参数顺序为m00、m10、m01、m11、m02、m12)

其他几个变换道理是一样的

如何使用java旋转图片

废话不多说直接上代码:

import java.awt.Color;

import java.awt.Graphics2D;

import java.awt.Transparency;

import java.awt.geom.AffineTransform;

import java.awt.image.AffineTransformOp;

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;

import java.io.ByteArrayOutputStream;

import java.io.IOException;

import java.io.InputStream;

import javax.imageio.ImageIO;

import javax.imageio.stream.ImageOutputStream;

public class ImageChange {

public static InputStream rotateImg(BufferedImage image, int degree, Color bgcolor) throws IOException {

int iw = image.getWidth();//原始图象的宽度

int ih = image.getHeight();//原始图象的高度

int w = 0;

int h = 0;

int x = 0;

int y = 0;

degree = degree % 360;

if (degree  0)

degree = 360 + degree;//将角度转换到0-360度之间

double ang = Math.toRadians(degree);//将角度转为弧度

/**

*确定旋转后的图象的高度和宽度

*/

if (degree == 180 || degree == 0 || degree == 360) {

w = iw;

h = ih;

} else if (degree == 90 || degree == 270) {

w = ih;

h = iw;

} else {

int d = iw + ih;

w = (int) (d * Math.abs(Math.cos(ang)));

h = (int) (d * Math.abs(Math.sin(ang)));

}

x = (w / 2) - (iw / 2);//确定原点坐标

y = (h / 2) - (ih / 2);

BufferedImage rotatedImage = new BufferedImage(w, h, image.getType());

Graphics2D gs = (Graphics2D)rotatedImage.getGraphics();

if(bgcolor==null){

rotatedImage  = gs.getDeviceConfiguration().createCompatibleImage(w, h, Transparency.TRANSLUCENT);

}else{

gs.setColor(bgcolor);

gs.fillRect(0, 0, w, h);//以给定颜色绘制旋转后图片的背景

}

AffineTransform at = new AffineTransform();

at.rotate(ang, w / 2, h / 2);//旋转图象

at.translate(x, y);

AffineTransformOp op = new AffineTransformOp(at, AffineTransformOp.TYPE_BICUBIC);

op.filter(image, rotatedImage);

image = rotatedImage;

ByteArrayOutputStream  byteOut= new ByteArrayOutputStream();

ImageOutputStream iamgeOut = ImageIO.createImageOutputStream(byteOut);

ImageIO.write(image, "png", iamgeOut);

InputStream  inputStream = new ByteArrayInputStream(byteOut.toByteArray());

return inputStream;

}

}

利用java实现图片翻转的代码

重载渲染控件的paintComponent(Graphics

g)方法.

设你当前图像实例为img,已初始化,需要旋转的角度为ang

public

void

paintComponent(Graphics

g){

super.paintCompoent(g);

Graphics2D

g2d

=

(Graphics2D)g;

g2d.rotate(-angle);

g2d.drawImage(img,0,0,this.getWidth(),this.getHeight(),null);

}

Graphics,Graphics2D

类中有对当前描绘环境进行仿射变换的方法,包括translate,scale,rotate,也可以直接设置仿射变换矩阵,利用这点就可以根据所需要的实现方式来进行描绘.


网页题目:图像翻转java代码 java获取图片旋转角度
当前地址:http://scpingwu.com/article/dosccpd.html