You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

XSSFBorderFormatting.java 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367
  1. /* ====================================================================
  2. Licensed to the Apache Software Foundation (ASF) under one or more
  3. contributor license agreements. See the NOTICE file distributed with
  4. this work for additional information regarding copyright ownership.
  5. The ASF licenses this file to You under the Apache License, Version 2.0
  6. (the "License"); you may not use this file except in compliance with
  7. the License. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. ==================================================================== */
  15. package org.apache.poi.xssf.usermodel;
  16. import org.apache.poi.ss.usermodel.BorderFormatting;
  17. import org.apache.poi.ss.usermodel.BorderStyle;
  18. import org.apache.poi.ss.usermodel.Color;
  19. import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTBorder;
  20. import org.openxmlformats.schemas.spreadsheetml.x2006.main.STBorderStyle;
  21. import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTBorderPr;
  22. import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTColor;
  23. /**
  24. * XSSF high level representation for Border Formatting component
  25. * of Conditional Formatting settings
  26. */
  27. public class XSSFBorderFormatting implements BorderFormatting {
  28. CTBorder _border;
  29. /*package*/ XSSFBorderFormatting(CTBorder border) {
  30. _border = border;
  31. }
  32. /**
  33. * @deprecated POI 3.15. Use {@link #getBorderBottomEnum()}.
  34. * This method will return an BorderStyle enum in the future.
  35. */
  36. @Override
  37. public short getBorderBottom() {
  38. return getBorderBottomEnum().getCode();
  39. }
  40. /**
  41. * @since POI 3.15
  42. */
  43. @Override
  44. public BorderStyle getBorderBottomEnum() {
  45. STBorderStyle.Enum ptrn = _border.isSetBottom() ? _border.getBottom().getStyle() : null;
  46. return ptrn == null ? BorderStyle.NONE : BorderStyle.valueOf((short)(ptrn.intValue() - 1));
  47. }
  48. /**
  49. * @deprecated POI 3.15. Use {@link #getBorderDiagonalEnum()}.
  50. * This method will return an BorderStyle enum in the future.
  51. */
  52. @Override
  53. public short getBorderDiagonal() {
  54. return getBorderDiagonalEnum().getCode();
  55. }
  56. /**
  57. * @since POI 3.15
  58. */
  59. @Override
  60. public BorderStyle getBorderDiagonalEnum() {
  61. STBorderStyle.Enum ptrn = _border.isSetDiagonal() ? _border.getDiagonal().getStyle() : null;
  62. return ptrn == null ? BorderStyle.NONE : BorderStyle.valueOf((short)(ptrn.intValue() - 1));
  63. }
  64. /**
  65. * @deprecated POI 3.15. Use {@link #getBorderLeftEnum()}.
  66. * This method will return an BorderStyle enum in the future.
  67. */
  68. @Override
  69. public short getBorderLeft() {
  70. return getBorderLeftEnum().getCode();
  71. }
  72. /**
  73. * @since POI 3.15
  74. */
  75. @Override
  76. public BorderStyle getBorderLeftEnum() {
  77. STBorderStyle.Enum ptrn = _border.isSetLeft() ? _border.getLeft().getStyle() : null;
  78. return ptrn == null ? BorderStyle.NONE : BorderStyle.valueOf((short)(ptrn.intValue() - 1));
  79. }
  80. /**
  81. * @deprecated POI 3.15. Use {@link #getBorderRightEnum()}.
  82. * This method will return an BorderStyle enum in the future.
  83. */
  84. @Override
  85. public short getBorderRight() {
  86. return getBorderRightEnum().getCode();
  87. }
  88. /**
  89. * @since POI 3.15
  90. */
  91. @Override
  92. public BorderStyle getBorderRightEnum() {
  93. STBorderStyle.Enum ptrn = _border.isSetRight() ? _border.getRight().getStyle() : null;
  94. return ptrn == null ? BorderStyle.NONE : BorderStyle.valueOf((short)(ptrn.intValue() - 1));
  95. }
  96. /**
  97. * @deprecated POI 3.15. Use {@link #getBorderTopEnum()}.
  98. * This method will return an BorderStyle enum in the future.
  99. */
  100. @Override
  101. public short getBorderTop() {
  102. return getBorderTopEnum().getCode();
  103. }
  104. /**
  105. * @since POI 3.15
  106. */
  107. @Override
  108. public BorderStyle getBorderTopEnum() {
  109. STBorderStyle.Enum ptrn = _border.isSetTop() ? _border.getTop().getStyle() : null;
  110. return ptrn == null ? BorderStyle.NONE : BorderStyle.valueOf((short)(ptrn.intValue() - 1));
  111. }
  112. @Override
  113. public XSSFColor getBottomBorderColorColor() {
  114. if(!_border.isSetBottom()) return null;
  115. CTBorderPr pr = _border.getBottom();
  116. return new XSSFColor(pr.getColor());
  117. }
  118. @Override
  119. public short getBottomBorderColor() {
  120. XSSFColor color = getBottomBorderColorColor();
  121. if (color == null) return 0;
  122. return color.getIndexed();
  123. }
  124. @Override
  125. public XSSFColor getDiagonalBorderColorColor() {
  126. if(!_border.isSetDiagonal()) return null;
  127. CTBorderPr pr = _border.getDiagonal();
  128. return new XSSFColor(pr.getColor());
  129. }
  130. @Override
  131. public short getDiagonalBorderColor() {
  132. XSSFColor color = getDiagonalBorderColorColor();
  133. if (color == null) return 0;
  134. return color.getIndexed();
  135. }
  136. @Override
  137. public XSSFColor getLeftBorderColorColor() {
  138. if(!_border.isSetLeft()) return null;
  139. CTBorderPr pr = _border.getLeft();
  140. return new XSSFColor(pr.getColor());
  141. }
  142. @Override
  143. public short getLeftBorderColor() {
  144. XSSFColor color = getLeftBorderColorColor();
  145. if (color == null) return 0;
  146. return color.getIndexed();
  147. }
  148. @Override
  149. public XSSFColor getRightBorderColorColor() {
  150. if(!_border.isSetRight()) return null;
  151. CTBorderPr pr = _border.getRight();
  152. return new XSSFColor(pr.getColor());
  153. }
  154. @Override
  155. public short getRightBorderColor() {
  156. XSSFColor color = getRightBorderColorColor();
  157. if (color == null) return 0;
  158. return color.getIndexed();
  159. }
  160. @Override
  161. public XSSFColor getTopBorderColorColor() {
  162. if(!_border.isSetTop()) return null;
  163. CTBorderPr pr = _border.getTop();
  164. return new XSSFColor(pr.getColor());
  165. }
  166. @Override
  167. public short getTopBorderColor() {
  168. XSSFColor color = getRightBorderColorColor();
  169. if (color == null) return 0;
  170. return color.getIndexed();
  171. }
  172. /**
  173. * @deprecated 3.15 beta 2. Use {@link #setBorderBottom(BorderStyle)}
  174. */
  175. @Override
  176. public void setBorderBottom(short border) {
  177. setBorderBottom(BorderStyle.valueOf(border));
  178. }
  179. @Override
  180. public void setBorderBottom(BorderStyle border) {
  181. CTBorderPr pr = _border.isSetBottom() ? _border.getBottom() : _border.addNewBottom();
  182. if(border == BorderStyle.NONE) _border.unsetBottom();
  183. else pr.setStyle(STBorderStyle.Enum.forInt(border.getCode() + 1));
  184. }
  185. /**
  186. * @deprecated 3.15 beta 2. Use {@link #setBorderDiagonal(BorderStyle)}
  187. */
  188. @Override
  189. public void setBorderDiagonal(short border) {
  190. setBorderDiagonal(BorderStyle.valueOf(border));
  191. }
  192. @Override
  193. public void setBorderDiagonal(BorderStyle border) {
  194. CTBorderPr pr = _border.isSetDiagonal() ? _border.getDiagonal() : _border.addNewDiagonal();
  195. if(border == BorderStyle.NONE) _border.unsetDiagonal();
  196. else pr.setStyle(STBorderStyle.Enum.forInt(border.getCode() + 1));
  197. }
  198. /**
  199. * @deprecated 3.15 beta 2. Use {@link #setBorderLeft(BorderStyle)}
  200. */
  201. @Override
  202. public void setBorderLeft(short border) {
  203. setBorderLeft(BorderStyle.valueOf(border));
  204. }
  205. @Override
  206. public void setBorderLeft(BorderStyle border) {
  207. CTBorderPr pr = _border.isSetLeft() ? _border.getLeft() : _border.addNewLeft();
  208. if(border == BorderStyle.NONE) _border.unsetLeft();
  209. else pr.setStyle(STBorderStyle.Enum.forInt(border.getCode() + 1));
  210. }
  211. /**
  212. * @deprecated 3.15 beta 2. Use {@link #setBorderRight(BorderStyle)}
  213. */
  214. @Override
  215. public void setBorderRight(short border) {
  216. setBorderRight(BorderStyle.valueOf(border));
  217. }
  218. @Override
  219. public void setBorderRight(BorderStyle border) {
  220. CTBorderPr pr = _border.isSetRight() ? _border.getRight() : _border.addNewRight();
  221. if(border == BorderStyle.NONE) _border.unsetRight();
  222. else pr.setStyle(STBorderStyle.Enum.forInt(border.getCode() + 1));
  223. }
  224. /**
  225. * @deprecated 3.15 beta 2. Use {@link #setBorderTop(BorderStyle)}
  226. */
  227. @Override
  228. public void setBorderTop(short border) {
  229. setBorderTop(BorderStyle.valueOf(border));
  230. }
  231. @Override
  232. public void setBorderTop(BorderStyle border) {
  233. CTBorderPr pr = _border.isSetTop() ? _border.getTop() : _border.addNewTop();
  234. if(border == BorderStyle.NONE) _border.unsetTop();
  235. else pr.setStyle(STBorderStyle.Enum.forInt(border.getCode() + 1));
  236. }
  237. @Override
  238. public void setBottomBorderColor(Color color) {
  239. XSSFColor xcolor = XSSFColor.toXSSFColor(color);
  240. if (xcolor == null) setBottomBorderColor((CTColor)null);
  241. else setBottomBorderColor(xcolor.getCTColor());
  242. }
  243. @Override
  244. public void setBottomBorderColor(short color) {
  245. CTColor ctColor = CTColor.Factory.newInstance();
  246. ctColor.setIndexed(color);
  247. setBottomBorderColor(ctColor);
  248. }
  249. public void setBottomBorderColor(CTColor color) {
  250. CTBorderPr pr = _border.isSetBottom() ? _border.getBottom() : _border.addNewBottom();
  251. if (color == null) {
  252. pr.unsetColor();
  253. } else {
  254. pr.setColor(color);
  255. }
  256. }
  257. @Override
  258. public void setDiagonalBorderColor(Color color) {
  259. XSSFColor xcolor = XSSFColor.toXSSFColor(color);
  260. if (xcolor == null) setDiagonalBorderColor((CTColor)null);
  261. else setDiagonalBorderColor(xcolor.getCTColor());
  262. }
  263. @Override
  264. public void setDiagonalBorderColor(short color) {
  265. CTColor ctColor = CTColor.Factory.newInstance();
  266. ctColor.setIndexed(color);
  267. setDiagonalBorderColor(ctColor);
  268. }
  269. public void setDiagonalBorderColor(CTColor color) {
  270. CTBorderPr pr = _border.isSetDiagonal() ? _border.getDiagonal() : _border.addNewDiagonal();
  271. if (color == null) {
  272. pr.unsetColor();
  273. } else {
  274. pr.setColor(color);
  275. }
  276. }
  277. @Override
  278. public void setLeftBorderColor(Color color) {
  279. XSSFColor xcolor = XSSFColor.toXSSFColor(color);
  280. if (xcolor == null) setLeftBorderColor((CTColor)null);
  281. else setLeftBorderColor(xcolor.getCTColor());
  282. }
  283. @Override
  284. public void setLeftBorderColor(short color) {
  285. CTColor ctColor = CTColor.Factory.newInstance();
  286. ctColor.setIndexed(color);
  287. setLeftBorderColor(ctColor);
  288. }
  289. public void setLeftBorderColor(CTColor color) {
  290. CTBorderPr pr = _border.isSetLeft() ? _border.getLeft() : _border.addNewLeft();
  291. if (color == null) {
  292. pr.unsetColor();
  293. } else {
  294. pr.setColor(color);
  295. }
  296. }
  297. @Override
  298. public void setRightBorderColor(Color color) {
  299. XSSFColor xcolor = XSSFColor.toXSSFColor(color);
  300. if (xcolor == null) setRightBorderColor((CTColor)null);
  301. else setRightBorderColor(xcolor.getCTColor());
  302. }
  303. @Override
  304. public void setRightBorderColor(short color) {
  305. CTColor ctColor = CTColor.Factory.newInstance();
  306. ctColor.setIndexed(color);
  307. setRightBorderColor(ctColor);
  308. }
  309. public void setRightBorderColor(CTColor color) {
  310. CTBorderPr pr = _border.isSetRight() ? _border.getRight() : _border.addNewRight();
  311. if (color == null) {
  312. pr.unsetColor();
  313. } else {
  314. pr.setColor(color);
  315. }
  316. }
  317. @Override
  318. public void setTopBorderColor(Color color) {
  319. XSSFColor xcolor = XSSFColor.toXSSFColor(color);
  320. if (xcolor == null) setTopBorderColor((CTColor)null);
  321. else setTopBorderColor(xcolor.getCTColor());
  322. }
  323. @Override
  324. public void setTopBorderColor(short color) {
  325. CTColor ctColor = CTColor.Factory.newInstance();
  326. ctColor.setIndexed(color);
  327. setTopBorderColor(ctColor);
  328. }
  329. public void setTopBorderColor(CTColor color) {
  330. CTBorderPr pr = _border.isSetTop() ? _border.getTop() : _border.addNewTop();
  331. if (color == null) {
  332. pr.unsetColor();
  333. } else {
  334. pr.setColor(color);
  335. }
  336. }
  337. }