POI4.1.0移动浮动文本框(XSSFSimpleShape)

1.问题引入

如下所示的文本框,怎么使用POI使其移动呢?
浮动文本框

2. 分析与解决

我POI的版本使用的是4.1.0,操作的是07版本(即.xlsx后缀的excel文件)。
在POI中,文本框是XSSFSimpleShape对象。
可以通过如下方式获取与移动文本框。需要注意的是
直接通过 XSSFSimpleShape s=(XSSFSimpleShape)shape;
s.getAnchor();得到的是XSSFAnchor对象,用XSSFAnchor移动文本框好像没有用,于是我转成了ClientAnchor ,通过设置row1 与row2控制其上下移动。还可以设置col1和col2控制其左右移动

List<POIXMLDocumentPart> list=sheet.getRelations();
int shift=5;
for(POIXMLDocumentPart part : list){
	if(part instanceof  XSSFDrawing){
		XSSFDrawing drawing=(XSSFDrawing) part;
		List<XSSFShape> shapes=drawing.getShapes();
		for(XSSFShape shape: shapes){
			if(shape instanceof XSSFSimpleShape){
				XSSFSimpleShape s=(XSSFSimpleShape)shape;
				ClientAnchor anchor=(ClientAnchor)s.getAnchor();
				anchor.setRow1(anchor.getRow1()+shift);
				anchor.setRow2(anchor.getRow2()+shift);
				}
			}
		}
}

3 .结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值