Simple single-color 8x8x8 LED Cube with AVRs
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

AnimationUtility.java 5.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. /*
  2. * AnimationUtility.java
  3. *
  4. * Copyright 2011 Thomas Buck <xythobuz@me.com>
  5. * Copyright 2011 Max Nuding <max.nuding@gmail.com>
  6. * Copyright 2011 Felix Bäder <baeder.felix@gmail.com>
  7. *
  8. * This file is part of LED-Cube.
  9. *
  10. * LED-Cube is free software: you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation, either version 3 of the License, or
  13. * (at your option) any later version.
  14. *
  15. * LED-Cube is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public License
  21. * along with LED-Cube. If not, see <http://www.gnu.org/licenses/>.
  22. */
  23. import java.io.FileWriter;
  24. import java.io.File;
  25. import java.util.Scanner;
  26. import java.io.IOException;
  27. import java.util.ArrayList;
  28. import java.util.List;
  29. /**
  30. * A helper class that loads animations from a file or saves them to one.
  31. *
  32. * @author Thomas Buck
  33. * @author Max Nuding
  34. * @author Felix Bäder
  35. * @version 1.0
  36. */
  37. public class AnimationUtility {
  38. private static String lastError = null;
  39. /**
  40. * Read a file, return ArrayList with all animations in the file.
  41. *
  42. * @param path Path of file
  43. * @return Populated ArrayList
  44. * @throws Excpetion When something goes wrong with the Scanner...
  45. */
  46. public static Animation[] readFile(String path) throws Exception {
  47. Scanner sc = new Scanner(new File(path));
  48. Animation[] animations = new Animation[0];
  49. do {
  50. Animation tmp = readAnimation(sc);
  51. if (tmp == null) {
  52. return animations;
  53. }
  54. if (sc.hasNextLine()) {
  55. sc.nextLine();
  56. }
  57. extendArray(animations);
  58. animations[animations.length - 1] = tmp;
  59. } while (sc.hasNextLine());
  60. return animations;
  61. }
  62. private static void extendArray(Animation[] animations) {
  63. Animation newArray[] = new Animation[animations.length + 1];
  64. for (int i = 0; i < animations.length; i++) {
  65. newArray[i] = animations[i];
  66. }
  67. animations = newArray;
  68. }
  69. /**
  70. * Write a file with all Animations of an ArrayList
  71. *
  72. * @param path Path to write to
  73. * @param animations Array with all animations to be saved
  74. * @see AnimationUtility#getLastError() getLastError()
  75. */
  76. public static void writeFile(String path, Animation[] animations) {
  77. File f = new File(path);
  78. if (f.exists()) {
  79. try {
  80. f.delete();
  81. } catch (Exception e) {
  82. lastError = e.toString();
  83. return;
  84. }
  85. }
  86. FileWriter output = null;
  87. try {
  88. output = new FileWriter(f);
  89. for (int i = 0; i < animations.length; i++) {
  90. writeAnimation(animations[i], output, (i == (animations.length - 1)));
  91. }
  92. } catch (Exception e) {
  93. lastError = e.toString();
  94. return;
  95. } finally {
  96. if (output != null) {
  97. try {
  98. output.close();
  99. } catch (Exception e) {
  100. lastError = e.toString();
  101. }
  102. }
  103. }
  104. }
  105. /**
  106. * Get the last error that occured while writing
  107. *
  108. * @return Text of the exception that occured
  109. */
  110. public static String getLastError() {
  111. String tmp = lastError;
  112. lastError = null;
  113. return tmp;
  114. }
  115. private static Animation readAnimation(Scanner sc) {
  116. Animation anim = new Animation();
  117. AFrame f = null;
  118. int index = 0;
  119. String tmpSize = sc.nextLine().replaceAll("\\n", "");
  120. if (tmpSize.equals("")) {
  121. return null;
  122. }
  123. Integer tmpSizeAgain = new Integer(tmpSize);
  124. int size = tmpSizeAgain.intValue();
  125. anim.setName(sc.nextLine());
  126. while (size > 0) {
  127. f = readFrame(sc, index);
  128. anim.setFrame(f, index);
  129. index++;
  130. size--;
  131. }
  132. return anim;
  133. }
  134. private static AFrame readFrame(Scanner sc, int index) {
  135. AFrame frame = new AFrame();
  136. frame.setName(sc.nextLine());
  137. short[] d = {};
  138. for (int i = 0; i < 8; i++) {
  139. short[] data = hexConvert(sc.nextLine());
  140. d = concat(d, data);
  141. }
  142. frame.setData(d);
  143. d = hexConvert(sc.nextLine());
  144. frame.setTime(d[0]);
  145. return frame;
  146. }
  147. /*
  148. * private static short[] invert(short[] a){ short[] tmp = new
  149. * short[a.length]; int j = 0; for(int i = a.length-1; i >= 0; i--){ tmp[j]
  150. * = a[i]; j++; } return tmp; }
  151. */
  152. private static short[] concat(short[] a, short[] b) {
  153. short[] c = new short[a.length + b.length];
  154. System.arraycopy(a, 0, c, 0, a.length);
  155. System.arraycopy(b, 0, c, a.length, b.length);
  156. return c;
  157. }
  158. private static short[] hexConvert(String hex) {
  159. hex = hex.replaceAll("\\n", "");
  160. short[] tmp = new short[hex.length() / 2];
  161. for (int i = 0; i < hex.length(); i = i + 2) {
  162. char[] tmpString = new char[2];
  163. tmpString[0] = hex.charAt(i);
  164. tmpString[1] = hex.charAt(i + 1);
  165. String tmpS = String.copyValueOf(tmpString);
  166. if (i == 0) {
  167. tmp[0] = Short.parseShort(tmpS, 16);
  168. } else {
  169. tmp[i / 2] = Short.parseShort(tmpS, 16);
  170. }
  171. }
  172. return tmp;
  173. }
  174. private static void writeAnimation(Animation anim, FileWriter f,
  175. boolean last) throws IOException {
  176. f.write(anim.size() + "\n");
  177. f.write(anim.getName() + "\n");
  178. for (int i = 0; i < anim.size(); i++) {
  179. writeFrame(anim.getFrame(i), f);
  180. }
  181. if (!last) {
  182. f.write("\n");
  183. }
  184. }
  185. private static void writeFrame(AFrame fr, FileWriter f) throws IOException {
  186. f.write(fr.getName() + "\n");
  187. for (int i = 0; i < 8; i++) {
  188. writeLayer(fr.getLayer(i), f);
  189. }
  190. f.write(Integer.toString((fr.getTime() & 0xff) + 0x100, 16)
  191. .substring(1) + "\n");
  192. }
  193. private static void writeLayer(short[] l, FileWriter f) throws IOException {
  194. String hex = "";
  195. for (int i = 0; i < l.length; i++) {
  196. hex += Integer.toString((l[i] & 0xff) + 0x100, 16).substring(1);
  197. }
  198. hex += "\n";
  199. f.write(hex);
  200. }
  201. }