.. | .. |
---|
49 | 49 | |
---|
50 | 50 | } |
---|
51 | 51 | } |
---|
| 52 | + |
---|
| 53 | + public static String RemovePrefix(String s, String prefix) |
---|
| 54 | + { |
---|
| 55 | + if (s != null && prefix != null && s.startsWith(prefix)) |
---|
| 56 | + { |
---|
| 57 | + return s.substring(prefix.length()); |
---|
| 58 | + } |
---|
| 59 | + |
---|
| 60 | + return s; |
---|
| 61 | + } |
---|
| 62 | + |
---|
| 63 | + static void ParseFileSystem(java.io.File dir, iResourceCallBack callback, String prefix) |
---|
| 64 | + { |
---|
| 65 | + callback.ResourceCallBack(RemovePrefix(dir.toString(),prefix).split("/")); |
---|
| 66 | + File[] listFiles = dir.listFiles(); |
---|
| 67 | + if (listFiles != null) |
---|
| 68 | + { |
---|
| 69 | + for (java.io.File file : listFiles) |
---|
| 70 | + { |
---|
| 71 | + ParseFileSystem(file, callback, prefix); |
---|
| 72 | + } |
---|
| 73 | + } |
---|
| 74 | + } |
---|
| 75 | + |
---|
| 76 | + static interface iResourceCallBack |
---|
| 77 | + { |
---|
| 78 | + void ResourceCallBack(String[] path); |
---|
| 79 | + } |
---|
| 80 | + |
---|
| 81 | + static void ParseResources(String path, iResourceCallBack callback) |
---|
| 82 | + { |
---|
| 83 | + java.io.File jarFile = new java.io.File(Grafreed.class.getProtectionDomain().getCodeSource().getLocation().getPath()); |
---|
| 84 | + |
---|
| 85 | + if (jarFile.isFile()) |
---|
| 86 | + { |
---|
| 87 | + // Run with JAR file |
---|
| 88 | + try |
---|
| 89 | + { |
---|
| 90 | + java.util.jar.JarFile jar = new java.util.jar.JarFile(jarFile); |
---|
| 91 | + java.util.Enumeration<java.util.jar.JarEntry> entries = jar.entries(); //gives ALL entries in jar |
---|
| 92 | + while (entries.hasMoreElements()) |
---|
| 93 | + { |
---|
| 94 | + String name = entries.nextElement().getName(); |
---|
| 95 | + |
---|
| 96 | + if (name.startsWith(path + "/")) |
---|
| 97 | + callback.ResourceCallBack(RemovePrefix(name, path + "/").split("/")); |
---|
| 98 | + } |
---|
| 99 | + jar.close(); |
---|
| 100 | + } catch (Exception ex) |
---|
| 101 | + { |
---|
| 102 | + ex.printStackTrace(); |
---|
| 103 | + } |
---|
| 104 | + } else |
---|
| 105 | + { |
---|
| 106 | + // Run with IDE |
---|
| 107 | + final java.net.URL url = Object3D.class.getResource("/" + path); |
---|
| 108 | + if (url != null) |
---|
| 109 | + { |
---|
| 110 | + try |
---|
| 111 | + { |
---|
| 112 | + java.io.File apps = new java.io.File(url.toURI()); |
---|
| 113 | + ParseFileSystem(apps, callback, RemovePrefix(url.toString() + "/", "file:")); |
---|
| 114 | +// for (java.io.File app : apps.listFiles()) |
---|
| 115 | +// { |
---|
| 116 | +// //System.out.println(RemovePrefix(app.toString(), RemovePrefix(url.toString(), "file:") + "/")); |
---|
| 117 | +// } |
---|
| 118 | + } catch (Exception ex) |
---|
| 119 | + { |
---|
| 120 | + ex.printStackTrace(); |
---|
| 121 | + } |
---|
| 122 | + } |
---|
| 123 | + } |
---|
| 124 | + } |
---|
52 | 125 | |
---|
53 | 126 | public void init() |
---|
54 | 127 | { |
---|
.. | .. |
---|
58 | 131 | universe.material = new cMaterial(); |
---|
59 | 132 | //god.addChild(universe); |
---|
60 | 133 | universe.name = "Applet"; |
---|
61 | | - grafreeD = this; |
---|
| 134 | + grafreed = this; |
---|
62 | 135 | } |
---|
63 | 136 | |
---|
64 | 137 | /**/ |
---|
.. | .. |
---|
849 | 922 | |
---|
850 | 923 | //Monitor mon=MonitorFactory.start("myFirstMonitor"); |
---|
851 | 924 | standAlone = true; |
---|
852 | | - grafreeD = new Grafreed(); |
---|
853 | | - grafreeD.universe = new cGroup(); |
---|
854 | | - grafreeD.universe.name = "Grafreed"; |
---|
855 | | - grafreeD.universe.material = new cMaterial(); |
---|
| 925 | + grafreed = new Grafreed(); |
---|
| 926 | + grafreed.materials = ReadGFD(grafreed.getClass().getClassLoader().getResourceAsStream("gfd/materials.gfd")); |
---|
| 927 | + |
---|
| 928 | + grafreed.universe = new cGroup(); |
---|
| 929 | + grafreed.universe.name = "Grafreed"; |
---|
| 930 | + grafreed.universe.material = new cMaterial(); |
---|
856 | 931 | // theApplet3D.universe.textures = CameraPane.DEFAULT_TEXTURE; |
---|
857 | 932 | |
---|
858 | | - grafreeD.universe.root = true; |
---|
859 | | - grafreeD.universe.openEditWindow(null, true); //, true); |
---|
| 933 | + grafreed.universe.root = true; |
---|
| 934 | + grafreed.universe.openEditWindow(null, true); //, true); |
---|
860 | 935 | //mon.stop(); |
---|
861 | 936 | //System.out.println(mon); |
---|
862 | 937 | //timeflow.app.TimeflowAppLauncher.GetTimeFlow(); |
---|
| 938 | + |
---|
| 939 | + javax.swing.ToolTipManager.sharedInstance().setEnabled(Globals.TOOLTIPS); |
---|
863 | 940 | } |
---|
864 | 941 | |
---|
| 942 | + static Object3D materials; |
---|
| 943 | + |
---|
| 944 | + static Object3D ReadGFD(java.io.InputStream istream) |
---|
| 945 | + { |
---|
| 946 | + Object3D readobj = null; |
---|
| 947 | + |
---|
| 948 | + try |
---|
| 949 | + { |
---|
| 950 | + // Try compressed version first. |
---|
| 951 | + java.util.zip.GZIPInputStream zstream = new java.util.zip.GZIPInputStream(istream); |
---|
| 952 | + java.io.ObjectInputStream p = new java.io.ObjectInputStream(zstream); |
---|
| 953 | + |
---|
| 954 | + readobj = (Object3D) p.readObject(); |
---|
| 955 | + istream.close(); |
---|
| 956 | + |
---|
| 957 | + readobj.ResetDisplayList(); |
---|
| 958 | + } catch (Exception e) |
---|
| 959 | + { |
---|
| 960 | + if (!e.toString().contains("GZIP")) |
---|
| 961 | + e.printStackTrace(); |
---|
| 962 | + |
---|
| 963 | + try |
---|
| 964 | + { |
---|
| 965 | + java.io.ObjectInputStream p = new java.io.ObjectInputStream(istream); |
---|
| 966 | + |
---|
| 967 | + readobj = (Object3D) p.readObject(); |
---|
| 968 | + istream.close(); |
---|
| 969 | + |
---|
| 970 | + readobj.ResetDisplayList(); |
---|
| 971 | + } catch (Exception e2) |
---|
| 972 | + { |
---|
| 973 | + e2.printStackTrace(); |
---|
| 974 | + } |
---|
| 975 | + } |
---|
| 976 | + |
---|
| 977 | + return readobj; |
---|
| 978 | + } |
---|
| 979 | + |
---|
865 | 980 | // Timer callback |
---|
866 | 981 | public void actionPerformed(ActionEvent e) |
---|
867 | 982 | { |
---|
.. | .. |
---|
1085 | 1200 | } while (avail > 0 && numRead >= 0); |
---|
1086 | 1201 | return new String(data, 0, pos, "US-ASCII"); |
---|
1087 | 1202 | } |
---|
1088 | | - public static Grafreed grafreeD; |
---|
| 1203 | + public static Grafreed grafreed; |
---|
1089 | 1204 | public static boolean standAlone = true; |
---|
1090 | 1205 | public Composite universe; |
---|
1091 | 1206 | public static Object3D clipboard = new Object3D(); |
---|