Compare commits

...

130 Commits

Author SHA1 Message Date
OMGeeky
775aba3a3f refactor: improve bounds checking in getElementAt method in CommonEditor 2025-06-18 13:53:49 +02:00
OMGeeky
bec4ddb71c refactor: update object handling in ReplaceArea and TMXMapEditor for consistency 2025-06-18 13:53:31 +02:00
OMGeeky
58603d32a1 add todo 2025-06-16 12:38:12 +02:00
OMGeeky
829bb336b8 cleanup 2025-06-16 12:38:00 +02:00
OMGeeky
57cf71da17 refactor: simplify panel creation for rewards and conditions in DialogueEditor & NPCEditor 2025-06-16 12:33:35 +02:00
OMGeeky
84dbca6ce1 refactor: encapsulate death effect panel creation in CommonEditor 2025-06-16 12:12:25 +02:00
OMGeeky
d6d742feac cleanup 2025-06-16 11:46:54 +02:00
OMGeeky
b775be08fc refactor: update createListPanel to return a result object containing both panel and list 2025-06-16 11:46:22 +02:00
OMGeeky
63d6397da5 refactor: streamline list panel creation in DroplistEditor & ItemEditor 2025-06-16 11:16:12 +02:00
OMGeeky
ee6907efdd refactor: streamline requirements panel creation in DialogueEditor 2025-06-16 10:50:32 +02:00
OMGeeky
02210d7581 refactor: clean up formatting and remove unnecessary line breaks in editor classes 2025-06-16 10:45:01 +02:00
OMGeeky
8a7ad08aa7 refactor: add navigation handling for replies in CommonEditor and DialogueEditor 2025-06-16 10:44:44 +02:00
OMGeeky
0081c325bb refactor: simplify stages panel creation in QuestEditor 2025-06-16 10:25:50 +02:00
OMGeeky
e10bcfe20f refactor: remove isCollapsed parameter and handle collapsing logic in DialogueEditor 2025-06-16 10:17:30 +02:00
OMGeeky
9deac7047f formatting 2025-06-16 10:11:41 +02:00
OMGeeky
0befc5563b refactor: change more ListModel implementations to AtListModel 2025-06-16 10:11:06 +02:00
OMGeeky
f747c40520 refactor: change StagesListModel to AtListModel 2025-06-16 09:57:17 +02:00
OMGeeky
92be506c11 refactor: add option to enable up down buttons or not 2025-06-16 09:56:40 +02:00
OMGeeky
64ea5377bf refactor: extract common ListModel implementation to AtListModel
and use that for moving elements up and down
2025-06-16 09:46:14 +02:00
OMGeeky
719be70744 refactor: extract replies panel creation to CommonEditor 2025-06-16 09:28:21 +02:00
OMGeeky
8f846c6098 add lambda call interfaces for single and multiple arguments 2025-06-16 09:27:19 +02:00
OMGeeky
975d13f36f extract wordWrap function to common class 2025-06-16 08:31:22 +02:00
OMGeeky
0a1fef4198 refactor: simplify link method by extracting parsing/linking logic 2025-06-16 08:23:43 +02:00
OMGeeky
5809d33bb4 refactor: remove unnecessary blank lines in multiple classes 2025-06-16 08:23:31 +02:00
OMGeeky
d8797fa826 add .output.txt to .gitignore 2025-06-16 07:49:46 +02:00
OMGeeky
70055be6d2 improve usings 2025-05-03 20:16:57 +02:00
OMGeeky
286d95d83d improve imports 2025-05-03 20:14:45 +02:00
OMGeeky
04b704daf0 more de-duplication 2025-05-03 20:10:36 +02:00
OMGeeky
3f1f988808 fix missed null check 2025-05-03 20:07:28 +02:00
OMGeeky
e232c33339 more de-duplication 2025-05-03 20:07:28 +02:00
OMGeeky
4239beb825 de-dupe code 2025-05-03 20:07:28 +02:00
Nut.andor
e2fdf08fec new spritesheets index 2025-02-15 23:48:39 +01:00
Nut.andor
1555bd63db Version with actor condition description is 21 2025-02-15 17:04:23 +01:00
Nut.andor
56fff8a730 nsi 2025-02-15 16:53:27 +01:00
Nut.andor
dd7b3d5300 version nbr 2025-02-15 16:44:40 +01:00
Nut.andor
68affdde8c misc 2025-02-15 16:44:13 +01:00
Nut.andor
6cec8b835e nsi 2025-02-15 16:36:45 +01:00
Nut.andor
aa43382296 Merge branch 'pulls/1195352/7' 2025-02-15 16:34:58 +01:00
Nut.andor
ec346e9c98 command parameters 2025-02-15 16:33:12 +01:00
Nut.andor
61d5af822c Build scripts 2025-02-15 16:12:38 +01:00
Nut.andor
c2d05b2bff Pull Request #7: Build scripts 2025-02-15 16:03:43 +01:00
OMGeeky
e60378ab64 Refactor package.sh to simplify JAR creation and improve directory structure 2025-02-15 16:03:36 +01:00
Nut.andor
6578236775 Merge branch 'pulls/1195352/6' 2025-02-15 14:38:30 +01:00
OMGeeky
4fa2409c24 Update .gitignore to include /out and ATCS.jar, and adjust patterns for ATCS_v*.tar.gz 2025-02-15 02:03:22 +01:00
OMGeeky
b5aa453fd6 cleanup package.sh 2025-02-15 02:03:08 +01:00
OMGeeky
42f1c87278 re-enable XML validation in TMXMapReader and update package script to copy resources recursively 2025-02-15 01:47:11 +01:00
OMGeeky
9097b97316 Disable XML validation and external DTD loading in TMXMapReader
This is because of a weird error, that only happens, when the jar is built manually somehow...
2025-02-15 01:17:59 +01:00
OMGeeky
7965ecb4f1 Update ATContentStudio_jar.xml to replace library elements with extracted-dir elements for JAR files and modify misc.xml to set default project JDK 2025-02-15 01:11:51 +01:00
OMGeeky
01963517ba Update .gitignore to exclude ATCS_v*.tar.gz and old.sh files 2025-02-15 00:31:47 +01:00
OMGeeky
30bef443d5 Refactor package script to extract library files directly to TEMP_DIR and simplify classpath 2025-02-15 00:28:16 +01:00
OMGeeky
8d01716d93 Refactor package script to simplify JAR creation and archive process 2025-02-15 00:09:21 +01:00
OMGeeky
fce5cd71ff Fix package script to construct source path and compile all Java files from specified directories 2025-02-14 23:49:00 +01:00
OMGeeky
0cddbb04e9 Enhance build script to include additional source code folders for compilation 2025-02-14 23:44:39 +01:00
OMGeeky
00ec5fe49f Update build script to include all Java files in the compilation process 2025-02-14 23:25:39 +01:00
OMGeeky
5cdb42ae07 clean up script 2025-02-14 20:30:57 +01:00
OMGeeky
c98f51744b Add initial project configuration files and setup for ATContentStudio 2025-02-14 20:04:44 +01:00
Nut.andor
5550b257ca add description field to actor conditions 2024-12-28 14:53:02 +01:00
Nut.andor
619aa1075f Pull Request #6: add description field to actor conditions 2024-12-27 13:05:53 +01:00
OMGeeky
38a3ad85c8 add description field to actor conditions 2024-12-27 10:12:48 +01:00
OMGeeky
89f764b62b Merge branch 'AndorsTrailRelease:master' into master 2024-12-27 10:10:35 +01:00
Nut.andor
d81233d470 createProject 2024-08-26 23:23:14 +02:00
Nut.andor
e1685aa625 createProject 2024-08-26 23:23:06 +02:00
OMGeeky
ae3ca5d50a fix typo & improve path safety (space in path should now be allowed) 2024-06-16 17:17:07 +02:00
OMGeeky
a00b8fbc66 fix typo 2024-06-16 17:00:32 +02:00
OMGeeky
4d03c15e08 Improve some error messages 2024-02-08 18:38:11 +00:00
OMGeeky
4571bea429 fix missing " 2024-01-09 00:18:36 +01:00
OMGeeky
ecc9a35c69 Allow it to be ran on windows
(via Git-Bash)
2024-01-01 10:47:50 -08:00
OMGeeky
c4d71df4b1 Create a packaging script
This should create the zip file to distribute it
2023-12-31 14:06:31 +01:00
Nut.andor
a13dac467a Merge branch 'v0.6.20' 2023-12-26 00:43:43 +01:00
Nut.andor
e305dfd7bf new cats sprite 2023-12-26 00:35:59 +01:00
Nut.andor
80984a43af new Sprites (engine PR 59) 2023-10-03 21:20:32 +02:00
Nut.andor
2bc8b65264 version nbr 6.20
new requirements: date, dateEquals, time, timeEquals
new rewards: mapchange
2023-10-03 21:20:32 +02:00
Nut.andor
b2584a24cc export default 2023-09-24 00:25:29 +02:00
Nut.andor
1626a8340f Merge branch 'v0.6.19' 2023-09-10 19:32:25 +02:00
Nut.andor
5fe2dfe148 Merge branch 'pulls/1195352/4' into v0.6.19
Remove empty sprites from selection panel
2023-09-10 19:28:14 +02:00
Nut.andor
abc1e7c912 Ignore empty sprites in SpriteChooser 2023-09-10 19:23:30 +02:00
Nut.andor
317d6d4216 Let console open on start 2023-09-10 19:22:18 +02:00
Nut.andor
3628386019 Pull Request #4: Ignore empty sprites in SpriteChooser 2023-09-10 17:25:03 +02:00
OMGeeky
ada352a02c implement ignoring fully transparent sprites 2023-09-10 17:15:28 +02:00
OMGeeky
fc0d97aa2f reformat file & optimize usings 2023-09-10 16:11:02 +02:00
Nut.andor
7451f582ce bugfix sprite 2023-09-09 22:51:21 +02:00
Nut.andor
7b80bf5768 new png 2023-09-01 00:08:33 +02:00
Nut
ddd98c5a8f respawnspeed (originally spawnchance) renamed & added to UI
respawnspeed (originally spawnchance) renamed & added to UI
2023-08-31 23:55:14 +02:00
OMGeeky
0ef703d82e Merge remote-tracking branch 'omgeeky/spawnchance' into spawnchance 2023-08-31 23:50:15 +02:00
OMGeeky
2339a9307c respawnspeed (originally spawnchance) renamed & added to UI 2023-08-31 23:49:03 +02:00
Nut.andor
7dcdb90750 new version 2023-08-31 23:28:32 +02:00
OMGeeky
b638c31ebe update latest 2023-08-30 15:01:04 +02:00
OMGeeky
862f4b7366 respawnspeed (originally spawnchance) renamed & added to UI 2023-08-30 14:40:50 +02:00
Nut.andor
693de98212 Revert "v0.6.19"
This reverts commit 3f4bf58375.
2023-02-04 20:41:21 +01:00
Nut.andor
3f4bf58375 v0.6.19
png names
2023-02-04 03:09:18 +01:00
Nut.andor
7ae4d9d3f6 v0.6.18:
- https:
2022-09-03 23:16:48 +02:00
Nut.andor
0f20f0cd6d Sprites sorted
Missing sprites added (actorconditions, items, monster, effect)
monsters_warrior1 too much

monsters_arulir   makes ATCS crash??

and I omitted fatboy73 this time, because the png has so many holes that would be in ATCS at the beginning of NPCs
2022-02-05 03:53:59 +01:00
Nut.andor
481956cfa5 I probably didn't understand the concept of the nsi compiler, so instead of using relative or variable paths I only got it with a fix path 2022-01-30 00:24:39 +01:00
Nut.andor
7c282aae53 Missing sprites added (actorconditions, items, monster, effect)
and sorted
2022-01-29 02:16:38 +01:00
Nut.andor
1fd3e6253e Increased version number for the upcoming release 2022-01-28 23:50:07 +01:00
Gonk
70f61f0281 Prevent crash when creating a new replace area 2022-01-25 21:33:27 +01:00
Nut
2f82fd13a6 Merge pull request #2 from atsymboldot/worldmap-label-fix
Fix disappearing worldmap labels bug
2021-12-26 14:08:16 +01:00
Nut
f7e5785970 Merge pull request #1 from atsymboldot/master
Add spore immunity skill for Fungi Panic
2021-12-26 14:07:26 +01:00
Nut
084b23f641 helpful error message added 2021-12-26 14:02:14 +01:00
Nathan Watson
ff4d8a6b6c Fix disappearing worldmap labels bug
The "worldmap.labels" map is keyed by namedarea.id (corresponding to map.area), while the "mapLocations" map is keyed by map.id. This causes worldmap labels to be marked for removal when there's a namedarea.id that does not match any map.id, which happens to be true for all namedareas except crossglen and crossroads.

This logic is unnecessary anyway, because WorldMapView.pushToModel is only invoked by WorldmapSegment.pushToModel, which only triggers when maps are added or moved, but not deleted. Deletions are instead handled by WorldmapSegment.elementChanged. As such, it should never be the case that a label is removable in a pushToModel call.
2021-01-04 01:07:57 -08:00
Nathan Watson
45aff3d25b Add spore immunity skill for Fungi Panic 2020-10-11 13:49:22 -07:00
Nut
28a1d0b09e bosses 2020-10-04 22:09:43 +02:00
Gonk
b96568049f Added spritesheets 2020-08-09 20:23:22 +02:00
Gonk
e125b0339c Added the giant basilisk spritesheet. that also prevents errors during compression 2020-06-08 20:16:17 +02:00
Gonk
65456a110b Increased version number for the upcoming release 2020-05-01 20:37:07 +02:00
Gonk
a9bd84b9f2 Merged all changes from my fork. They are needed to work on AT v0.7.10 2020-05-01 20:30:17 +02:00
Gonk
1bab8dc42f Fix for ResourcesCompactor 2020-05-01 20:17:29 +02:00
Gonk
7863b73eda fixed missing png extension 2020-04-12 21:12:19 +02:00
Gonk
32e1b87e09 Corrected linking of spritesheets in tmx
- added or altered spritesheets are now linked with relative paths so that they can be committed to an ATCS project and don't have any unwanted path infomation included
- when exporting the project all links to spritesheets are now changed to ../drawable/FILENAME.PNG
2020-04-05 20:46:03 +02:00
Gonk
4b6be99d98 Changed damage modifier default value to 100% 2020-02-25 20:24:26 +01:00
Gonk
13847bb8cd Merge branch 'weapondamagemodifier' into jar20200220 2020-02-20 21:59:02 +01:00
Gonk
2d92a97689 Named the damage modifier according to the AT sources 2020-02-20 21:57:35 +01:00
Gonk
9c21c7cd02 Merge branch 'weapondamagemodifier' into jar20200121 2020-01-21 22:24:59 +01:00
Gonk
f4fd8ad5bb Merge branch 'wearremoverequirement' into jar20200121
# Conflicts:
#	src/com/gpl/rpg/atcontentstudio/model/gamedata/Requirement.java
#	src/com/gpl/rpg/atcontentstudio/ui/gamedataeditors/DialogueEditor.java
#	src/com/gpl/rpg/atcontentstudio/ui/map/TMXMapEditor.java
2020-01-21 22:24:42 +01:00
Gonk
63acc5bf2c Merge branch 'factionscoreequals' into jar20200121 2020-01-21 22:22:13 +01:00
Gonk
4c51353e93 Merge branch 'pofileencoding' into jar20200121 2020-01-21 22:21:58 +01:00
Gonk
7bf6bbfcd1 Merge branch 'poleweapon' into jar20200121 2020-01-21 22:21:21 +01:00
Gonk
7d40d56430 The damage modifier can now be edited, also added "on hit received" columns to the items comparator 2019-12-26 21:05:39 +01:00
Gonk
d7e83575e3 wearRemove requirement
wear and wearRemove behave similar and wear now also requires the value property
2019-11-11 21:53:25 +01:00
Gonk
811870184b factionscoreEquals 2019-10-13 17:57:41 +02:00
Gonk
7297f47b67 read and write po files using utf 8 encoding
until now the system default was used, which is especially on windows not utf 8
2019-09-04 23:33:41 +02:00
Gonk
20877f7850 Changed the order for the pole weapon proficency 2019-07-11 21:21:10 +02:00
Gonk
b3c8879be1 added pole weapon proficiency 2019-07-08 22:27:23 +02:00
Zukero
ac68006a69 v0.6.15 released.
Includes a way to view which tileset a tile is from on a map. It is
shown in the tooltip from the "Testing" tab of the map editor.
2019-05-31 10:28:16 +02:00
Zukero
92e07e76d2 Added Gonk to the contributors. 2019-05-31 09:55:17 +02:00
Gonk
5a3315da1a Added random requirement and a null pointer fix for the droplist editor
- used in conversations and replace areas
- using the droplist chance editor
2019-05-12 11:45:48 +02:00
Zukero
e12c6bcc25 Overhaul of the droplist's drop chance editor, planning to use it for
the random requirement type' chance too.
2019-04-24 00:45:57 +02:00
Zukero
44c4e1f998 Merge pull request #9 from Chriz76/maprefresh 2019-04-23 20:52:44 +02:00
Gonk
450b0de02a Adjusted external map change detection
On some systems changes by tiled were not detected and therefore the refresh button was greyed. The reason might have been that tiled recreates the files instead of changing them.
2019-04-20 21:35:59 +02:00
Zukero
57702a3a4a Lib updated. 2018-11-28 15:14:08 +01:00
71 changed files with 10861 additions and 11203 deletions

View File

@@ -14,6 +14,6 @@
<classpathentry kind="lib" path="lib/ui.jar"/> <classpathentry kind="lib" path="lib/ui.jar"/>
<classpathentry kind="lib" path="lib/bsh-2.0b4.jar"/> <classpathentry kind="lib" path="lib/bsh-2.0b4.jar"/>
<classpathentry kind="lib" path="lib/jsoup-1.10.2.jar" sourcepath="lib/jsoup-1.10.2-sources.jar"/> <classpathentry kind="lib" path="lib/jsoup-1.10.2.jar" sourcepath="lib/jsoup-1.10.2-sources.jar"/>
<classpathentry kind="lib" path="lib/AndorsTrainer_v0.1.4.jar"/> <classpathentry kind="lib" path="lib/AndorsTrainer_v0.1.5.jar"/>
<classpathentry kind="output" path="bin"/> <classpathentry kind="output" path="bin"/>
</classpath> </classpath>

11
.gitignore vendored
View File

@@ -1,3 +1,14 @@
/ATCS_v*.jar /ATCS_v*.jar
/Project /Project
/bin /bin
/packaging/tmp/
/out
packaging/common/lib
packaging/common/ATCS.jar
packaging/ATCS_*.zip
ATCS_v*.tar.gz
ATCS.jar
/packaging/common/ATCS.env.bat
/packaging/common/ATCS.env
/packaging/common/ATCS_v*.zip
/.output.txt

8
.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

18
.idea/artifacts/ATContentStudio_jar.xml generated Normal file
View File

@@ -0,0 +1,18 @@
<component name="ArtifactManager">
<artifact name="ATContentStudio:jar">
<output-path>$PROJECT_DIR$/out/artifacts/ATContentStudio_jar</output-path>
<root id="root">
<element id="archive" name="ATContentStudio.jar">
<element id="module-output" name="ATContentStudio" />
<element id="extracted-dir" path="$PROJECT_DIR$/lib/bsh-2.0b4.jar" path-in-jar="/" />
<element id="extracted-dir" path="$PROJECT_DIR$/lib/rsyntaxtextarea.jar" path-in-jar="/" />
<element id="extracted-dir" path="$PROJECT_DIR$/lib/prefuse.jar" path-in-jar="/" />
<element id="extracted-dir" path="$PROJECT_DIR$/lib/jsoup-1.10.2.jar" path-in-jar="/" />
<element id="extracted-dir" path="$PROJECT_DIR$/lib/json_simple-1.1.jar" path-in-jar="/" />
<element id="extracted-dir" path="$PROJECT_DIR$/lib/ui.jar" path-in-jar="/" />
<element id="extracted-dir" path="$PROJECT_DIR$/lib/AndorsTrainer_v0.1.5.jar" path-in-jar="/" />
<element id="extracted-dir" path="$PROJECT_DIR$/lib/jide-oss.jar" path-in-jar="/" />
</element>
</root>
</artifact>
</component>

4
.idea/misc.xml generated Normal file
View File

@@ -0,0 +1,4 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" default="true" />
</project>

8
.idea/modules.xml generated Normal file
View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/ATContentStudio.iml" filepath="$PROJECT_DIR$/ATContentStudio.iml" />
</modules>
</component>
</project>

6
.idea/vcs.xml generated Normal file
View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="" vcs="Git" />
</component>
</project>

View File

@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?> <?xml version="1.0" encoding="UTF-8" standalone="no"?>
<jardesc> <jardesc>
<jar path="ATContentStudio/ATCS_v0.6.14.jar"/> <jar path="ATContentStudio/ATCS_v0.6.20.jar"/>
<options buildIfNeeded="true" compress="true" descriptionLocation="/ATContentStudio/ATCS_JAR.jardesc" exportErrors="true" exportWarnings="true" includeDirectoryEntries="false" overwrite="false" saveDescription="true" storeRefactorings="false" useSourceFolders="false"/> <options buildIfNeeded="true" compress="true" descriptionLocation="/ATContentStudio/ATCS_JAR.jardesc" exportErrors="true" exportWarnings="true" includeDirectoryEntries="false" overwrite="false" saveDescription="true" storeRefactorings="false" useSourceFolders="false"/>
<storedRefactorings deprecationInfo="true" structuralOnly="false"/> <storedRefactorings deprecationInfo="true" structuralOnly="false"/>
<selectedProjects/> <selectedProjects/>

117
ATContentStudio.iml Normal file
View File

@@ -0,0 +1,117 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="EclipseModuleManager">
<libelement value="jar://$MODULE_DIR$/lib/jide-oss.jar!/" />
<libelement value="jar://$MODULE_DIR$/lib/json_simple-1.1.jar!/" />
<libelement value="jar://$MODULE_DIR$/lib/junit-4.10.jar!/" />
<libelement value="jar://$MODULE_DIR$/lib/prefuse.jar!/" />
<libelement value="jar://$MODULE_DIR$/lib/rsyntaxtextarea.jar!/" />
<libelement value="jar://$MODULE_DIR$/lib/ui.jar!/" />
<libelement value="jar://$MODULE_DIR$/lib/bsh-2.0b4.jar!/" />
<libelement value="jar://$MODULE_DIR$/lib/jsoup-1.10.2.jar!/" />
<libelement value="jar://$MODULE_DIR$/lib/AndorsTrainer_v0.1.5.jar!/" />
<src_description expected_position="0">
<src_folder value="file://$MODULE_DIR$/src" expected_position="0" />
<src_folder value="file://$MODULE_DIR$/res" expected_position="1" />
<src_folder value="file://$MODULE_DIR$/hacked-libtiled" expected_position="2" />
<src_folder value="file://$MODULE_DIR$/siphash-zackehh/src/main/java" expected_position="3" />
<src_folder value="file://$MODULE_DIR$/minify" expected_position="4" />
</src_description>
</component>
<component name="NewModuleRootManager">
<output url="file://$MODULE_DIR$/bin" />
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/hacked-libtiled" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/minify" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/res" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/siphash-zackehh/src/main/java" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
</content>
<orderEntry type="sourceFolder" forTests="false" />
<orderEntry type="inheritedJdk" />
<orderEntry type="module-library">
<library name="jide-oss.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/jide-oss.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</orderEntry>
<orderEntry type="module-library">
<library name="json_simple-1.1.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/json_simple-1.1.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</orderEntry>
<orderEntry type="module-library">
<library name="junit-4.10.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/junit-4.10.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</orderEntry>
<orderEntry type="module-library">
<library name="prefuse.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/prefuse.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</orderEntry>
<orderEntry type="module-library">
<library name="rsyntaxtextarea.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/rsyntaxtextarea.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</orderEntry>
<orderEntry type="module-library">
<library name="ui.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/ui.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</orderEntry>
<orderEntry type="module-library">
<library name="bsh-2.0b4.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/bsh-2.0b4.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</orderEntry>
<orderEntry type="module-library">
<library name="jsoup-1.10.2.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/jsoup-1.10.2.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$MODULE_DIR$/lib/jsoup-1.10.2-sources.jar!/" />
</SOURCES>
</library>
</orderEntry>
<orderEntry type="module-library">
<library name="AndorsTrainer_v0.1.5.jar">
<CLASSES>
<root url="jar://$MODULE_DIR$/lib/AndorsTrainer_v0.1.5.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</orderEntry>
</component>
</module>

127
createProject.bat Normal file
View File

@@ -0,0 +1,127 @@
@echo off
echo.
echo ***
echo *** createProject v1.0 (2024-08-24)
echo ***
echo *** This script will help to setup an ATCS project
echo *** and connect it to a repo on Github
echo ***
echo.
rem Save this script anywhere on your PC (e.g. C:\AT\createProject.bat)
rem Then open a command shell: CMD
rem and call the script in the shell.
if "%1"=="" goto :noParamError
echo You have entered:
echo.
echo ATCS-project: %1
echo in Directory: %2
echo Github user: %3
echo.
pause
if "%3"=="" goto :help
if not "%4"=="" goto :help
if not exist %2 md %2
rem --- Create ATCS project (if not already done)
:atcs
if not exist %2\%1\created\drawable\char_hero.png (
echo.
echo Do the following steps:
echo.
echo 1. Start ATCS
echo 2. Create your ATCS workspace in %2
echo 3. Add the new project %1
echo 4. Exit ATCS
echo.
pause
goto :atcs
) else (
echo ATCS Project exists
)
rem --- Create git repository
rem This is the really important part :)
rem -- go into project dir (even if we do not need to create the git repo)
echo cd %2\%1
cd %2\%1
if not exist %2\%1\readme.md (
echo creating readme
echo # %1 > readme.md
) else (
echo readme already exists
)
if not exist %2\%1\.gitignore (
echo creating gitignore
echo .workspace > .gitignore
echo .project >> .gitignore
echo altered/drawable >> .gitignore
echo altered/drawable/* >> .gitignore
echo created/drawable >> .gitignore
echo created/drawable/* >> .gitignore
echo tmp/res/values/loadresources.xml >> .gitignore
) else (
echo gitignore already existed
)
:git
if not exist %2\%1\.git (
echo Initializing git
git init -b main || (
echo "failed to init git. Please make sure it is installed"
pause
goto :git
)
:git_commit
git add readme.md
git add .gitignore
git commit -m "Init project" || (
echo "failed to create the initial commit."
pause
goto :git_commit
)
echo Done initializing git
) else (
echo git was already initialized
)
echo.
echo Now create your repo %1 on https://github.com/%3 (if not already done)
echo.
pause
echo pushing to git repo https://github.com/%3/%1.git
git remote add origin https://github.com/%3/%1.git
git push -u origin main
echo.
echo At last you have to find the repo in your git client:
echo - In Smartgit: Menu option: Repository / Search for repository
echo.
goto :end
:noParamError
echo.
echo You have given no parameter.
echo Maybe you have just double clicked it? That won't work.
echo I have opened a CMD shell for you. Enter the command in that shell.
start cmd
echo Please switch to the CMD shell
:help
echo.
echo Enter the command with 3 parameters:
echo %0 project path git-user
echo.
echo Example: %0 feygard_1 c:\AT\ATCS NutAndor
echo.
:end
echo.
echo *** End ***
pause

View File

@@ -913,7 +913,8 @@ public class TMXMapReader
private class MapEntityResolver implements EntityResolver private class MapEntityResolver implements EntityResolver
{ {
public InputSource resolveEntity(String publicId, String systemId) { public InputSource resolveEntity(String publicId, String systemId) {
if (systemId.equals("http://mapeditor.org/dtd/1.0/map.dtd")) { if (systemId.equals("http://mapeditor.org/dtd/1.0/map.dtd") ||
systemId.equals("https://mapeditor.org/dtd/1.0/map.dtd")) {
return new InputSource(TMXMapReader.class.getResourceAsStream( return new InputSource(TMXMapReader.class.getResourceAsStream(
"resources/map.dtd")); "resources/map.dtd"));
} }

View File

@@ -47,6 +47,9 @@ import java.util.Vector;
import java.util.zip.DeflaterOutputStream; import java.util.zip.DeflaterOutputStream;
import java.util.zip.GZIPOutputStream; import java.util.zip.GZIPOutputStream;
import com.gpl.rpg.atcontentstudio.model.GameSource.Type;
import com.gpl.rpg.atcontentstudio.model.maps.TMXMapSet;
import tiled.core.AnimatedTile; import tiled.core.AnimatedTile;
import tiled.core.Map; import tiled.core.Map;
import tiled.core.MapLayer; import tiled.core.MapLayer;
@@ -150,7 +153,7 @@ public class TMXMapWriter
} }
private void writeMap(Map map, XMLWriter w, String wp) throws IOException { private void writeMap(Map map, XMLWriter w, String wp) throws IOException {
w.writeDocType("map", null, "http://mapeditor.org/dtd/1.0/map.dtd"); w.writeDocType("map", null, "https://mapeditor.org/dtd/1.0/map.dtd");
w.startElement("map"); w.startElement("map");
w.writeAttribute("version", "1.0"); w.writeAttribute("version", "1.0");
@@ -238,7 +241,15 @@ public class TMXMapWriter
} else { } else {
w.startElement("tileset"); w.startElement("tileset");
w.writeAttribute("firstgid", getFirstGidForTileset(set)); w.writeAttribute("firstgid", getFirstGidForTileset(set));
w.writeAttribute("source", getRelativePath(wp, source)); if (set.sheet != null && set.sheet.parent.getDataType() == Type.source) {
String fileName = set.getName();
if (fileName.length() > 3 && !(fileName.substring(fileName.length() - 4).equalsIgnoreCase(".png"))) {
fileName += ".png";
}
w.writeAttribute("source", (TMXMapSet.DEFAULT_REL_PATH_TO_DRAWABLE + fileName).replace("\\", "/"));
} else {
w.writeAttribute("source", getRelativePath(wp, source));
}
if (set.getBaseDir() != null) { if (set.getBaseDir() != null) {
w.writeAttribute("basedir", set.getBaseDir()); w.writeAttribute("basedir", set.getBaseDir());
} }
@@ -279,7 +290,15 @@ public class TMXMapWriter
if (tileBitmapFile != null) { if (tileBitmapFile != null) {
w.startElement("image"); w.startElement("image");
w.writeAttribute("source", getRelativePath(wp, tileBitmapFile)); if (set.sheet != null && set.sheet.parent.getDataType() == Type.source) {
String fileName = set.getName();
if (fileName.length() > 3 && !(fileName.substring(fileName.length() - 4).equalsIgnoreCase(".png"))) {
fileName += ".png";
}
w.writeAttribute("source", (TMXMapSet.DEFAULT_REL_PATH_TO_DRAWABLE + fileName).replace("\\", "/"));
} else {
w.writeAttribute("source", getRelativePath(wp, tileBitmapFile));
}
if (set.sheetDimensions != null) { if (set.sheetDimensions != null) {
w.writeAttribute("width", set.sheetDimensions.width); w.writeAttribute("width", set.sheetDimensions.width);
w.writeAttribute("height", set.sheetDimensions.height); w.writeAttribute("height", set.sheetDimensions.height);

Binary file not shown.

Binary file not shown.

View File

@@ -1 +1 @@
v0.6.14 v0.6.21

2
packaging/Manifest.txt Normal file
View File

@@ -0,0 +1,2 @@
Manifest-Version: 1.0
Main-Class: com.gpl.rpg.atcontentstudio.ATContentStudio

View File

@@ -1,8 +1,9 @@
!include MUI2.nsh !include MUI2.nsh
!define VERSION "0.6.14" !define VERSION "0.6.21"
!define TRAINER_VERSION "0.1.4" !define TRAINER_VERSION "0.1.5"
!define JAVA_BIN "javaw" !define JAVA_BIN "java"
!define ATCS_SOURCE_DIR "C:\ATCS"
Name "Andor's Trail Content Studio v${VERSION}" Name "Andor's Trail Content Studio v${VERSION}"
OutFile "ATCS_v${VERSION}_Setup.exe" OutFile "ATCS_v${VERSION}_Setup.exe"
@@ -13,8 +14,8 @@ InstallDir "$PROGRAMFILES\ATCS\"
Var StartMenuFolder Var StartMenuFolder
!define MUI_WELCOMEPAGE_TITLE "Welcome to Andor's Trail Content Studio installer" !define MUI_WELCOMEPAGE_TITLE "Welcome to Andor's Trail Content Studio installer"
!define MUI_WELCOMEPAGE_TEXT "This will install Andor's Trail Content Studio v${VERSION} installer" !define MUI_WELCOMEPAGE_TEXT "This will install Andor's Trail Content Studio v${VERSION}"
!define MUI_FINISHPAGE_TEXT "Andor's Trail Content Studio v${VERSION} install completed !" !define MUI_FINISHPAGE_TEXT "Andor's Trail Content Studio v${VERSION} - Install completed !"
!define MUI_STARTMENUPAGE_DEFAULTFOLDER "Andor's Trail Content Studio" !define MUI_STARTMENUPAGE_DEFAULTFOLDER "Andor's Trail Content Studio"
!define MUI_PAGE_HEADER_TEXT "Installing Andor's Trail Content Studio v${VERSION}" !define MUI_PAGE_HEADER_TEXT "Installing Andor's Trail Content Studio v${VERSION}"
@@ -46,31 +47,33 @@ Var StartMenuFolder
!insertmacro MUI_UNPAGE_CONFIRM !insertmacro MUI_UNPAGE_CONFIRM
!insertmacro MUI_UNPAGE_INSTFILES !insertmacro MUI_UNPAGE_INSTFILES
!insertmacro MUI_LANGUAGE "English" !insertmacro MUI_LANGUAGE "English"
;------------------------------------------------------------------------------------
Section install Section install
;--- Create in ...\packaging\common\ ATCS.cmd ATCT.ico ATCS.jar
SetOutPath $INSTDIR SetOutPath $INSTDIR
file "ATCS.ico" file "ATCS.ico"
file "${ATCS_SOURCE_DIR}\packaging\common\ATCS.jar"
Delete "$INSTDIR\lib\*"
Call GetJRE Call GetJRE
Pop $R0 Pop $R0
; file "${ATCS_SOURCE_DIR}\packaging\common\ATCS.cmd"
; !insertmacro _ReplaceInFile "ATCS.cmd" "java.exe" "$R0" (It was too much work this way)
FileOpen $9 "ATCS.cmd" w FileOpen $9 "ATCS.cmd" w
FileWrite $9 '@echo off$\r$\n' FileWrite $9 '@echo off$\r$\n'
FileWrite $9 '$\r$\n' FileWrite $9 '$\r$\n'
FileWrite $9 'set "ATCS_DIR=%~dp0"$\r$\n' FileWrite $9 'set "ATCS_DIR=%~dp0"$\r$\n'
FileWrite $9 'set "MAX_MEM=512M"$\r$\n' FileWrite $9 'set "MAX_MEM=1024M"$\r$\n'
FileWrite $9 'set "CP=%ATCS_DIR%lib\*"$\r$\n' FileWrite $9 'set "CP=%ATCS_DIR%lib\*"$\r$\n'
FileWrite $9 'set "JAVA=$R0"$\r$\n' FileWrite $9 'set "JAVA=$R0"$\r$\n'
FileWrite $9 'set "JAVA_OPTS="$\r$\n' FileWrite $9 'set "JAVA_OPTS="$\r$\n'
FileWrite $9 'set "ENV_FILE=%ATCS_DIR%ATCS.env.bat"$\r$\n' FileWrite $9 'set "ENV_FILE=%ATCS_DIR%ATCS.env.bat"$\r$\n'
FileWrite $9 'set "MAIN_CLASS=com.gpl.rpg.atcontentstudio.ATContentStudio"$\r$\n' FileWrite $9 'set "MAIN_CLASS=com.gpl.rpg.atcontentstudio.ATContentStudio"$\r$\n'
FileWrite $9 '$\r$\n' FileWrite $9 '$\r$\n'
FileWrite $9 'if exist "%ENV_FILE%" ($\r$\n' FileWrite $9 'if exist "%ENV_FILE%" ($\r$\n'
FileWrite $9 ' call "%ENV_FILE%"$\r$\n' FileWrite $9 ' call "%ENV_FILE%"$\r$\n'
FileWrite $9 ') else ($\r$\n' FileWrite $9 ') else ($\r$\n'
FileWrite $9 ' echo REM set "MAX_MEM=%MAX_MEM%">"%ENV_FILE%"$\r$\n' FileWrite $9 ' echo REM set "MAX_MEM=%MAX_MEM%">"%ENV_FILE%"$\r$\n'
@@ -79,29 +82,15 @@ Section install
FileWrite $9 ' echo.>>"%ENV_FILE%"$\r$\n' FileWrite $9 ' echo.>>"%ENV_FILE%"$\r$\n'
FileWrite $9 ')$\r$\n' FileWrite $9 ')$\r$\n'
FileWrite $9 '$\r$\n' FileWrite $9 '$\r$\n'
FileWrite $9 'start "" "%JAVA%" %JAVA_OPTS% -Xmx%MAX_MEM% -cp "%CP%" %MAIN_CLASS%$\r$\n' FileWrite $9 'start "" "%JAVA%" %JAVA_OPTS% -Xmx%MAX_MEM% -jar ATCS.jar$\r$\n'
FileClose $9 FileClose $9
SetOutPath "$INSTDIR\lib\"
file "jide-oss.jar"
file "ui.jar"
file "AndorsTrainer_v${TRAINER_VERSION}.jar"
file "junit-4.10.jar"
file "json_simple-1.1.jar"
file "ATCS_v${VERSION}.jar"
file "rsyntaxtextarea.jar"
file "prefuse.jar"
file "bsh-2.0b4.jar"
file "jsoup-1.10.2.jar"
SetOutPath $INSTDIR
WriteUninstaller "$INSTDIR\Uninstall.exe" WriteUninstaller "$INSTDIR\Uninstall.exe"
!insertmacro MUI_STARTMENU_WRITE_BEGIN "ATCS" !insertmacro MUI_STARTMENU_WRITE_BEGIN "ATCS"
;Create shortcuts ;--- Create shortcuts
CreateDirectory "$SMPROGRAMS\$StartMenuFolder" CreateDirectory "$SMPROGRAMS\$StartMenuFolder"
CreateShortcut "$SMPROGRAMS\$StartMenuFolder\Andor's Trail Content Studio.lnk" "$INSTDIR\ATCS.cmd" "" "$INSTDIR\ATCS.ico" CreateShortcut "$SMPROGRAMS\$StartMenuFolder\Andor's Trail Content Studio.lnk" "$INSTDIR\ATCS.cmd" "" "$INSTDIR\ATCS.ico"
CreateShortcut "$SMPROGRAMS\$StartMenuFolder\Uninstall.lnk" "$INSTDIR\Uninstall.exe" CreateShortcut "$SMPROGRAMS\$StartMenuFolder\Uninstall.lnk" "$INSTDIR\Uninstall.exe"
@@ -110,6 +99,8 @@ Section install
SectionEnd SectionEnd
;------------------------------------------------------------------------------------
Section uninstall Section uninstall
Delete "$INSTDIR\lib\jide-oss.jar" Delete "$INSTDIR\lib\jide-oss.jar"
@@ -117,18 +108,17 @@ Section uninstall
Delete "$INSTDIR\lib\junit-4.10.jar" Delete "$INSTDIR\lib\junit-4.10.jar"
Delete "$INSTDIR\lib\json_simple-1.1.jar" Delete "$INSTDIR\lib\json_simple-1.1.jar"
Delete "$INSTDIR\lib\AndorsTrainer_v${TRAINER_VERSION}.jar" Delete "$INSTDIR\lib\AndorsTrainer_v${TRAINER_VERSION}.jar"
Delete "$INSTDIR\lib\ATCS_v${VERSION}.jar"
Delete "$INSTDIR\lib\rsyntaxtextarea.jar" Delete "$INSTDIR\lib\rsyntaxtextarea.jar"
Delete "$INSTDIR\lib\prefuse.jar" Delete "$INSTDIR\lib\prefuse.jar"
Delete "$INSTDIR\lib\bsh-2.0b4.jar" Delete "$INSTDIR\lib\bsh-2.0b4.jar"
Delete "$INSTDIR\lib\jsoup-1.10.2.jar" Delete "$INSTDIR\lib\jsoup-1.10.2.jar"
RMDir "$INSTDIR\lib\" RMDir "$INSTDIR\lib\"
Delete "$INSTDIR\ATCS.ico" Delete "$INSTDIR\ATCS.ico"
Delete "$INSTDIR\ATCS.cmd" Delete "$INSTDIR\ATCS.cmd"
Delete "$INSTDIR\ATCS.env.bat" Delete "$INSTDIR\ATCS.env.bat"
Delete "$INSTDIR\ATCS.jar"
Delete "$INSTDIR\Uninstall.exe" Delete "$INSTDIR\Uninstall.exe"
RMDir "$INSTDIR" RMDir "$INSTDIR"
!insertmacro MUI_STARTMENU_GETFOLDER "ATCS" $StartMenuFolder !insertmacro MUI_STARTMENU_GETFOLDER "ATCS" $StartMenuFolder
@@ -140,19 +130,20 @@ Section uninstall
SectionEnd SectionEnd
;------------------------------------------------------------------------------------
Function GetJRE Function GetJRE
; ;
; Find JRE (javaw.exe) ; Find JRE (java.exe)
; DISABLED 1 - in .\jre directory (JRE Installed with application) ; DISABLED 1 - in .\jre directory (JRE Installed with application)
; 2 - in JAVA_HOME environment variable ; 2 - in JAVA_HOME environment variable
; 3 - in the registry ; 3 - in the registry
; 4 - assume javaw.exe in current dir or PATH ; 4 - assume java.exe in current dir or PATH
Push $R0 Push $R0
Push $R1 Push $R1
;ClearErrors ;ClearErrors
;StrCpy $R0 "$EXEDIR\jre\bin\javaw.exe" ;StrCpy $R0 "$EXEDIR\jre\bin\java.exe"
;IfFileExists $R0 JreFound ;IfFileExists $R0 JreFound
;StrCpy $R0 "" ;StrCpy $R0 ""
@@ -172,4 +163,4 @@ Function GetJRE
JreFound: JreFound:
Pop $R1 Pop $R1
Exch $R0 Exch $R0
FunctionEnd FunctionEnd

18
packaging/common/ATCS.cmd Normal file
View File

@@ -0,0 +1,18 @@
@echo off
set "ATCS_DIR=%~dp0"
set "MAX_MEM=1024M"
set "JAVA=java.exe"
set "JAVA_OPTS=-DFONT_SCALE=1.0 -Dswing.aatext=true"
set "ENV_FILE=%ATCS_DIR%ATCS.env.bat"
if exist "%ENV_FILE%" (
call "%ENV_FILE%"
) else (
echo REM set "MAX_MEM=%MAX_MEM%">"%ENV_FILE%"
echo REM set "JAVA=%JAVA%">>"%ENV_FILE%"
echo REM set "JAVA_OPTS=%JAVA_OPTS%">>"%ENV_FILE%"
echo.>>"%ENV_FILE%"
)
start "" "%JAVA%" %JAVA_OPTS% -Xmx%MAX_MEM% -jar "%ATCS_DIR%\ATCS.jar"

BIN
packaging/common/ATCS.ico Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 24 KiB

21
packaging/common/ATCS.sh Executable file
View File

@@ -0,0 +1,21 @@
#!/bin/bash
ATCS_DIR=$(dirname $(readlink -f "$0" || greadlink -f "$0" || stat -f "$0"))
MAX_MEM=512M
JAVA=java
JAVA_OPTS='-DFONT_SCALE=1.0 -Dswing.aatext=true'
ENV_FILE=${ATCS_DIR}/ATCS.env
if [ -f ${ENV_FILE} ]; then
source ${ENV_FILE}
else
echo "#MAX_MEM=${MAX_MEM}" >${ENV_FILE}
echo "#JAVA=${JAVA}" >>${ENV_FILE}
echo "#JAVA_OPTS=${JAVA_OPTS}" >>${ENV_FILE}
echo "" >>${ENV_FILE}
fi
export ENV_FILE
$JAVA ${JAVA_OPTS} -Xmx${MAX_MEM} -jar ${ATCS_DIR}/ATCS.jar

View File

@@ -0,0 +1 @@
sh ./package.sh -windows

119
packaging/package.sh Executable file
View File

@@ -0,0 +1,119 @@
#!/bin/bash
# Script to build ATCS.jar, replicating IntelliJ artifact definition
# Linux and Windows compatible
# --- Platform Detection ---
if [ "$1" = "-windows" ]; then
echo "Got '-windows' flag. Running Windows version"
PLATFORM="WINDOWS"
else
echo "No '-windows' flag. Running Linux version"
PLATFORM="LINUX"
fi
# --- Configuration ---
PACKAGING_DIR=$(dirname "$(readlink -f "$0" || greadlink -f "$0" || stat -f "$0")")
ATCS_SOURCE_DIR=$(dirname "${PACKAGING_DIR}")
TEMP_DIR="${PACKAGING_DIR}/tmp"
JAR_LOCATION="${PACKAGING_DIR}/ATCS.jar" # Output JAR location as per script
MANIFEST_LOCATION="${PACKAGING_DIR}/Manifest.txt"
VERSION_FILE="${PACKAGING_DIR}/ATCS_latest"
SOURCE_BASE_DIR="${ATCS_SOURCE_DIR}/src" # Base directory for standard source code
LIB_BASE_DIR="${ATCS_SOURCE_DIR}/lib" # Base directory for libraries
OUTPUT_JAR_DIR="${PACKAGING_DIR}" # Directory where the final JAR will be placed - as per script
# --- **ADDITIONAL SOURCE CODE FOLDERS** ---
EXTRA_SOURCE_DIRS=(
"hacked-libtiled"
"minify"
"siphash-zackehh/src/main/java"
)
# --- Libraries to include (from IntelliJ artifact definition) ---
LIBRARIES=(
"AndorsTrainer_v0.1.5.jar"
"bsh-2.0b4.jar"
"jide-oss.jar"
"json_simple-1.1.jar"
"jsoup-1.10.2.jar"
"junit-4.10.jar"
"prefuse.jar"
"rsyntaxtextarea.jar"
"ui.jar"
)
# --- Get version ---
echo "Getting version"
VERSION=$(cat "${VERSION_FILE}")
echo "Got version ${VERSION}"
# --- Prepare temporary directory ---
echo "Removing tmp folder"
rm -rf "${TEMP_DIR}"
echo "Recreating tmp folder"
mkdir -p "${TEMP_DIR}"
# --- **EXTRACT lib files directly to TEMP_DIR** ---
echo 'Extracting lib files to TEMP_DIR'
for LIB in "${LIBRARIES[@]}"; do
echo "Extracting library: ${LIB}"
unzip -qo "${LIB_BASE_DIR}/${LIB}" -d "${TEMP_DIR}" # Extract JAR contents to TEMP_DIR root
done
# --- Set ClassPath ---
echo "Getting source files"
# Find all java files in source directories and compile them
SOURCE_FILES=$(find "${SOURCE_BASE_DIR}" "${EXTRA_SOURCE_DIRS[@]/#/${ATCS_SOURCE_DIR}/}" -name "*.java" -print)
#echo "SourceFiles: ${SOURCE_FILES}"
echo ""
# --- Build Java classes ---
echo 'Building java classes'
javac -cp "${TEMP_DIR}" -d "${TEMP_DIR}" ${SOURCE_FILES}
if [ $? -ne 0 ]; then
echo "Compilation failed. Please check errors above."
exit 1
fi
echo "Compilation successful"
# --- Copy res stuff to temp folder ---
echo "Copying some stuff to temp folder"
cp -r "${ATCS_SOURCE_DIR}"/res/* "${TEMP_DIR}/"
mkdir -p "${TEMP_DIR}/com/gpl/rpg/atcontentstudio/img"
mkdir -p "${TEMP_DIR}/tiled/io/resources/"
cp -r "${ATCS_SOURCE_DIR}"/src/com/gpl/rpg/atcontentstudio/img/* "${TEMP_DIR}/com/gpl/rpg/atcontentstudio/img/" # some icons
cp -r "${ATCS_SOURCE_DIR}"/hacked-libtiled/tiled/io/resources/* "${TEMP_DIR}/tiled/io/resources/" # dtd file for tmx maps
# --- Create JAR file ---
echo ""
echo "Creating jar at location: ${JAR_LOCATION}"
cd "${TEMP_DIR}" || exit # Change to temp dir for JAR command
# JAR command WITHOUT lib directory
jar cfm "${JAR_LOCATION}" "${MANIFEST_LOCATION}" -C . .
if [ $? -ne 0 ]; then
echo "JAR creation failed."
exit 1
fi
cd "${PACKAGING_DIR}" || exit # Go back to packaging dir
echo ''
echo "Done creating jar at ${JAR_LOCATION}"
cp -f "${JAR_LOCATION}" "${OUTPUT_JAR_DIR}/common/ATCS.jar" # Copy JAR to versioned name
# --- Create archive ---
if [ "$PLATFORM" = "LINUX" ]; then
cd "${OUTPUT_JAR_DIR}" || exit
echo "Creating archive"
tar caf "ATCS_${VERSION}.tar.gz" common/* # archive the 'common' folder which now contains the JAR and libs
echo "Created archive at ${OUTPUT_JAR_DIR}/ATCS_${VERSION}.tar.gz"
cd "${PACKAGING_DIR}" || exit
else
echo "Can't create zip files on windows yet. Please pack the content of the '${OUTPUT_JAR_DIR}/common/' folder yourself"
fi
echo "Script finished."

View File

@@ -1,64 +1,94 @@
atcs.spritesheet.actorconditions_1.category=actorcondition atcs.spritesheet.actorconditions_1.category=actorcondition
atcs.spritesheet.actorconditions_2.category=actorcondition atcs.spritesheet.actorconditions_2.category=actorcondition
atcs.spritesheet.actorconditions_japozero.category=actorcondition atcs.spritesheet.actorconditions_japozero.category=actorcondition
atcs.spritesheet.actorconditions_newb.category=actorcondition
atcs.spritesheet.actorconditions_omi1.category=actorcondition
atcs.spritesheet.actorconditions_omi2.category=actorcondition
atcs.spritesheet.effect_blood3.animate=true
atcs.spritesheet.effect_blood4.animate=true
atcs.spritesheet.effect_bluetentacle.animate=true
atcs.spritesheet.effect_heal2.animate=true
atcs.spritesheet.effect_miss1.animate=true
atcs.spritesheet.effect_poison1.animate=true
atcs.spritesheet.effect_tometik1.animate=true
atcs.spritesheet.effect_tometik2.animate=true
atcs.spritesheet.items_armours.category=item atcs.spritesheet.items_armours.category=item
atcs.spritesheet.items_armours_2.category=item atcs.spritesheet.items_armours_2.category=item
atcs.spritesheet.items_armours_3.category=item atcs.spritesheet.items_armours_3.category=item
atcs.spritesheet.items_weapons.category=item
atcs.spritesheet.items_weapons_2.category=item
atcs.spritesheet.items_weapons_3.category=item
atcs.spritesheet.items_jewelry.category=item
atcs.spritesheet.items_rings_1.category=item
atcs.spritesheet.items_necklaces_1.category=item
atcs.spritesheet.items_consumables.category=item
atcs.spritesheet.items_japozero.category=item
atcs.spritesheet.items_books.category=item atcs.spritesheet.items_books.category=item
atcs.spritesheet.items_consumables.category=item
atcs.spritesheet.items_consumables_omi1.category=item
atcs.spritesheet.items_feygard1.category=item
atcs.spritesheet.items_g03_package_omi1.category=item
atcs.spritesheet.items_japozero.category=item
atcs.spritesheet.items_jewelry.category=item
atcs.spritesheet.items_misc.category=item atcs.spritesheet.items_misc.category=item
atcs.spritesheet.items_misc_2.category=item atcs.spritesheet.items_misc_2.category=item
atcs.spritesheet.items_misc_3.category=item atcs.spritesheet.items_misc_3.category=item
atcs.spritesheet.items_misc_4.category=item atcs.spritesheet.items_misc_4.category=item
atcs.spritesheet.items_misc_5.category=item atcs.spritesheet.items_misc_5.category=item
atcs.spritesheet.items_misc_6.category=item atcs.spritesheet.items_misc_6.category=item
atcs.spritesheet.items_necklaces_1.category=item
atcs.spritesheet.items_newb.category=item
atcs.spritesheet.items_omgeeky.category=item
atcs.spritesheet.items_omi2.category=item
atcs.spritesheet.items_phoenix01.category=item
atcs.spritesheet.items_reterski_1.category=item atcs.spritesheet.items_reterski_1.category=item
atcs.spritesheet.items_rijackson_1.category=item
atcs.spritesheet.items_rings_1.category=item
atcs.spritesheet.items_tometik1.category=item atcs.spritesheet.items_tometik1.category=item
atcs.spritesheet.items_tometik2.category=item atcs.spritesheet.items_tometik2.category=item
atcs.spritesheet.items_tometik3.category=item atcs.spritesheet.items_tometik3.category=item
atcs.spritesheet.items_weapons.category=item
atcs.spritesheet.items_weapons_2.category=item
atcs.spritesheet.items_weapons_3.category=item
atcs.spritesheet.monsters_armor1.category=monster atcs.spritesheet.monsters_armor1.category=monster
atcs.spritesheet.monsters_arulirs.category=monster
atcs.spritesheet.monsters_cats.category=monster
atcs.spritesheet.monsters_dogs.category=monster atcs.spritesheet.monsters_dogs.category=monster
atcs.spritesheet.monsters_eye1.category=monster atcs.spritesheet.monsters_eye1.category=monster
atcs.spritesheet.monsters_eye2.category=monster atcs.spritesheet.monsters_eye2.category=monster
atcs.spritesheet.monsters_eye3.category=monster atcs.spritesheet.monsters_eye3.category=monster
atcs.spritesheet.monsters_eye4.category=monster atcs.spritesheet.monsters_eye4.category=monster
atcs.spritesheet.monsters_fatboy73.category=monster
atcs.spritesheet.monsters_ghost1.category=monster atcs.spritesheet.monsters_ghost1.category=monster
atcs.spritesheet.monsters_hydra1.category=monster
atcs.spritesheet.monsters_hydra1.sizex=64 atcs.spritesheet.monsters_gisons.category=monster
atcs.spritesheet.monsters_hydra1.sizey=64 atcs.spritesheet.monsters_guynmart.category=monster
atcs.spritesheet.monsters_insects.category=monster atcs.spritesheet.monsters_insects.category=monster
atcs.spritesheet.monsters_johny.category=monster
atcs.spritesheet.monsters_karvis1.category=monster
atcs.spritesheet.monsters_karvis2.category=monster
atcs.spritesheet.monsters_ld1.category=monster
atcs.spritesheet.monsters_ld2.category=monster
atcs.spritesheet.monsters_liches.category=monster atcs.spritesheet.monsters_liches.category=monster
atcs.spritesheet.monsters_mage.category=monster atcs.spritesheet.monsters_mage.category=monster
atcs.spritesheet.monsters_mage2.category=monster atcs.spritesheet.monsters_mage2.category=monster
atcs.spritesheet.monsters_maksiu1.category=monster
atcs.spritesheet.monsters_man1.category=monster atcs.spritesheet.monsters_man1.category=monster
atcs.spritesheet.monsters_men.category=monster atcs.spritesheet.monsters_men.category=monster
atcs.spritesheet.monsters_men2.category=monster atcs.spritesheet.monsters_men2.category=monster
atcs.spritesheet.monsters_misc.category=monster atcs.spritesheet.monsters_misc.category=monster
atcs.spritesheet.monsters_newb_1.category=monster
atcs.spritesheet.monsters_omi1.category=monster
atcs.spritesheet.monsters_omi1_b.category=monster
atcs.spritesheet.monsters_omi2.category=monster
atcs.spritesheet.monsters_phoenix01.category=monster
atcs.spritesheet.monsters_rats.category=monster atcs.spritesheet.monsters_rats.category=monster
atcs.spritesheet.monsters_rogue1.category=monster atcs.spritesheet.monsters_redshrike1.category=monster
atcs.spritesheet.monsters_skeleton1.category=monster
atcs.spritesheet.monsters_skeleton2.category=monster
atcs.spritesheet.monsters_snakes.category=monster
atcs.spritesheet.monsters_warrior1.category=monster
atcs.spritesheet.monsters_wraiths.category=monster
atcs.spritesheet.monsters_zombie1.category=monster
atcs.spritesheet.monsters_zombie2.category=monster
atcs.spritesheet.monsters_karvis1.category=monster
atcs.spritesheet.monsters_karvis2.category=monster
atcs.spritesheet.monsters_rltiles1.category=monster atcs.spritesheet.monsters_rltiles1.category=monster
atcs.spritesheet.monsters_rltiles2.category=monster atcs.spritesheet.monsters_rltiles2.category=monster
atcs.spritesheet.monsters_rltiles3.category=monster atcs.spritesheet.monsters_rltiles3.category=monster
atcs.spritesheet.monsters_rltiles4.category=monster atcs.spritesheet.monsters_rltiles4.category=monster
atcs.spritesheet.monsters_redshrike1.category=monster atcs.spritesheet.monsters_rogue1.category=monster
atcs.spritesheet.monsters_ld1.category=monster atcs.spritesheet.monsters_skeleton1.category=monster
atcs.spritesheet.monsters_ld2.category=monster atcs.spritesheet.monsters_skeleton2.category=monster
atcs.spritesheet.monsters_snakes.category=monster
atcs.spritesheet.monsters_tometik1.category=monster atcs.spritesheet.monsters_tometik1.category=monster
atcs.spritesheet.monsters_tometik2.category=monster atcs.spritesheet.monsters_tometik2.category=monster
atcs.spritesheet.monsters_tometik3.category=monster atcs.spritesheet.monsters_tometik3.category=monster
@@ -69,20 +99,36 @@ atcs.spritesheet.monsters_tometik7.category=monster
atcs.spritesheet.monsters_tometik8.category=monster atcs.spritesheet.monsters_tometik8.category=monster
atcs.spritesheet.monsters_tometik9.category=monster atcs.spritesheet.monsters_tometik9.category=monster
atcs.spritesheet.monsters_tometik10.category=monster atcs.spritesheet.monsters_tometik10.category=monster
atcs.spritesheet.monsters_warrior1.category=monster
atcs.spritesheet.monsters_unknown.category=monster
atcs.spritesheet.monsters_wraiths.category=monster
atcs.spritesheet.monsters_zombie1.category=monster
atcs.spritesheet.monsters_zombie2.category=monster
atcs.spritesheet.monsters_bosses_2x2.category=monster
atcs.spritesheet.monsters_bosses_2x2.sizex=64
atcs.spritesheet.monsters_bosses_2x2.sizey=64
atcs.spritesheet.monsters_cyclops.category=monster
atcs.spritesheet.monsters_cyclops.sizex=64
atcs.spritesheet.monsters_cyclops.sizey=96
atcs.spritesheet.monsters_demon1.category=monster atcs.spritesheet.monsters_demon1.category=monster
atcs.spritesheet.monsters_demon1.sizex=64 atcs.spritesheet.monsters_demon1.sizex=64
atcs.spritesheet.monsters_demon1.sizey=64 atcs.spritesheet.monsters_demon1.sizey=64
atcs.spritesheet.monsters_demon2.category=monster atcs.spritesheet.monsters_demon2.category=monster
atcs.spritesheet.monsters_demon2.sizex=64 atcs.spritesheet.monsters_demon2.sizex=64
atcs.spritesheet.monsters_demon2.sizey=64 atcs.spritesheet.monsters_demon2.sizey=64
atcs.spritesheet.monsters_cyclops.category=monster atcs.spritesheet.monsters_giantbasilisk.category=monster
atcs.spritesheet.monsters_cyclops.sizex=64 atcs.spritesheet.monsters_giantbasilisk.sizex=64
atcs.spritesheet.monsters_cyclops.sizey=96 atcs.spritesheet.monsters_giantbasilisk.sizey=64
atcs.spritesheet.effect_blood3.animate=true atcs.spritesheet.monsters_hydra1.category=monster
atcs.spritesheet.effect_blood4.animate=true atcs.spritesheet.monsters_hydra1.sizex=64
atcs.spritesheet.effect_bluetentacle.animate=true atcs.spritesheet.monsters_hydra1.sizey=64
atcs.spritesheet.effect_heal2.animate=true atcs.spritesheet.monsters_newb_2.category=monster
atcs.spritesheet.effect_poison1.animate=true atcs.spritesheet.monsters_newb_2.sizex=64
atcs.spritesheet.effect_tometik1.animate=true atcs.spritesheet.monsters_newb_2.sizey=32
atcs.spritesheet.effect_tometik2.animate=true atcs.spritesheet.monsters_newb_3.category=monster
atcs.spritesheet.monsters_guynmart.category=monster atcs.spritesheet.monsters_newb_3.sizex=64
atcs.spritesheet.monsters_newb_3.sizey=64
atcs.spritesheet.monsters_newb_4.category=monster
atcs.spritesheet.monsters_newb_4.sizex=32
atcs.spritesheet.monsters_newb_4.sizey=64

6
src/META-INF/MANIFEST.MF Normal file
View File

@@ -0,0 +1,6 @@
Manifest-Version: 1.0
Main-Class: com.gpl.rpg.atcontentstudio.ATContentStudio
Class-Path: jide-oss.jar jsoup-1.10.2.jar ui.jar junit-4.10.jar AndorsTr
ainer_v0.1.5.jar prefuse.jar rsyntaxtextarea.jar bsh-2.0b4.jar json_sim
ple-1.1.jar

View File

@@ -1,227 +1,234 @@
package com.gpl.rpg.atcontentstudio; package com.gpl.rpg.atcontentstudio;
import java.awt.Color; import java.awt.Color;
import java.awt.Desktop; import java.awt.Desktop;
import java.awt.Dimension; import java.awt.Dimension;
import java.awt.Font; import java.awt.Font;
import java.awt.Toolkit; import java.awt.Toolkit;
import java.awt.event.WindowAdapter; import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent; import java.awt.event.WindowEvent;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.net.URL; import java.net.URL;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.HashMap; import java.util.HashMap;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
import javax.swing.JEditorPane; import javax.swing.JEditorPane;
import javax.swing.JLabel; import javax.swing.JLabel;
import javax.swing.JOptionPane; import javax.swing.JOptionPane;
import javax.swing.UIDefaults; import javax.swing.UIDefaults;
import javax.swing.UIManager; import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException; import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.event.HyperlinkEvent; import javax.swing.event.HyperlinkEvent;
import javax.swing.event.HyperlinkListener; import javax.swing.event.HyperlinkListener;
import javax.swing.plaf.FontUIResource; import javax.swing.plaf.FontUIResource;
import prefuse.data.expression.parser.ExpressionParser; import prefuse.data.expression.parser.ExpressionParser;
import com.gpl.rpg.atcontentstudio.model.Workspace; import com.gpl.rpg.atcontentstudio.model.Workspace;
import com.gpl.rpg.atcontentstudio.ui.StudioFrame; import com.gpl.rpg.atcontentstudio.ui.StudioFrame;
import com.gpl.rpg.atcontentstudio.ui.WorkerDialog; import com.gpl.rpg.atcontentstudio.ui.WorkerDialog;
import com.gpl.rpg.atcontentstudio.ui.WorkspaceSelector; import com.gpl.rpg.atcontentstudio.ui.WorkspaceSelector;
public class ATContentStudio {
public class ATContentStudio {
public static final String APP_NAME = "Andor's Trail Content Studio";
public static final String APP_NAME = "Andor's Trail Content Studio"; public static final String APP_VERSION = "v0.6.21";
public static final String APP_VERSION = "v0.6.14";
public static final String CHECK_UPDATE_URL = "https://andorstrail.com/static/ATCS_latest";
public static final String CHECK_UPDATE_URL = "https://andorstrail.com/static/ATCS_latest"; public static final String DOWNLOAD_URL = "https://andorstrail.com/viewtopic.php?f=6&t=4806";
public static final String DOWNLOAD_URL = "https://andorstrail.com/viewtopic.php?f=6&t=4806";
public static final String FONT_SCALE_ENV_VAR_NAME = "FONT_SCALE";
public static final String FONT_SCALE_ENV_VAR_NAME = "FONT_SCALE";
public static boolean STARTED = false;
public static boolean STARTED = false; public static float SCALING = 1.0f;
public static float SCALING=1.0f; public static StudioFrame frame = null;
public static StudioFrame frame = null;
// Need to keep a strong reference to it, to avoid garbage collection that'll
//Need to keep a strong reference to it, to avoid garbage collection that'll reset these loggers. // reset these loggers.
public static final List<Logger> configuredLoggers = new LinkedList<Logger>(); public static final List<Logger> configuredLoggers = new LinkedList<Logger>();
/** /**
* @param args * @param args
*/ */
public static void main(String[] args) { public static void main(String[] args) {
String fontScaling = System.getProperty(FONT_SCALE_ENV_VAR_NAME); String fontScaling = System.getProperty(FONT_SCALE_ENV_VAR_NAME);
Float fontScale = null; Float fontScale = null;
if (fontScaling != null) { if (fontScaling != null) {
try { try {
fontScale = Float.parseFloat(fontScaling); fontScale = Float.parseFloat(fontScaling);
SCALING=fontScale; SCALING = fontScale;
} catch (NumberFormatException e) { } catch (NumberFormatException e) {
System.err.println("Failed to parse font scaling parameter. Using default."); System.err.println("Failed to parse font scaling parameter. Using default.");
e.printStackTrace(); e.printStackTrace();
} }
} }
ConfigCache.init(); ConfigCache.init();
try { try {
String laf = ConfigCache.getFavoriteLaFClassName(); String laf = ConfigCache.getFavoriteLaFClassName();
if (laf == null) laf = UIManager.getSystemLookAndFeelClassName(); if (laf == null)
UIManager.setLookAndFeel(laf); laf = UIManager.getSystemLookAndFeelClassName();
} catch (ClassNotFoundException e) { UIManager.setLookAndFeel(laf);
e.printStackTrace(); } catch (ClassNotFoundException e) {
} catch (InstantiationException e) { e.printStackTrace();
e.printStackTrace(); } catch (InstantiationException e) {
} catch (IllegalAccessException e) { e.printStackTrace();
e.printStackTrace(); } catch (IllegalAccessException e) {
} catch (UnsupportedLookAndFeelException e) { e.printStackTrace();
e.printStackTrace(); } catch (UnsupportedLookAndFeelException e) {
} e.printStackTrace();
}
scaleUIFont(); scaleUIFont();
//Need to keep a strong reference to it, to avoid garbage collection that'll reset this setting. // Need to keep a strong reference to it, to avoid garbage collection that'll
Logger l = Logger.getLogger(ExpressionParser.class.getName()); // reset this setting.
l.setLevel(Level.OFF); Logger l = Logger.getLogger(ExpressionParser.class.getName());
configuredLoggers.add(l); l.setLevel(Level.OFF);
configuredLoggers.add(l);
final WorkspaceSelector wsSelect = new WorkspaceSelector();
wsSelect.pack(); final WorkspaceSelector wsSelect = new WorkspaceSelector();
Dimension sdim = Toolkit.getDefaultToolkit().getScreenSize(); wsSelect.pack();
Dimension wdim = wsSelect.getSize(); Dimension sdim = Toolkit.getDefaultToolkit().getScreenSize();
wsSelect.setLocation((sdim.width - wdim.width)/2, (sdim.height - wdim.height)/2); Dimension wdim = wsSelect.getSize();
wsSelect.setVisible(true); wsSelect.setLocation((sdim.width - wdim.width) / 2, (sdim.height - wdim.height) / 2);
wsSelect.setVisible(true);
wsSelect.addWindowListener(new WindowAdapter() {
@Override wsSelect.addWindowListener(new WindowAdapter() {
public synchronized void windowClosed(WindowEvent e) { @Override
if (wsSelect.selected != null && !STARTED) { public synchronized void windowClosed(WindowEvent e) {
ATContentStudio.STARTED = true; if (wsSelect.selected != null && !STARTED) {
final File workspaceRoot = new File(wsSelect.selected); ATContentStudio.STARTED = true;
WorkerDialog.showTaskMessage("Loading your workspace...", null, new Runnable(){ final File workspaceRoot = new File(wsSelect.selected);
public void run() { WorkerDialog.showTaskMessage("Loading your workspace...", null, new Runnable() {
Workspace.setActive(workspaceRoot); public void run() {
if (Workspace.activeWorkspace.settings.useInternet.getCurrentValue() && Workspace.activeWorkspace.settings.checkUpdates.getCurrentValue()) { Workspace.setActive(workspaceRoot);
new Thread() { if (Workspace.activeWorkspace.settings.useInternet.getCurrentValue()
public void run() {checkUpdate();} && Workspace.activeWorkspace.settings.checkUpdates.getCurrentValue()) {
}.start(); new Thread() {
} public void run() {
frame = new StudioFrame(APP_NAME+" "+APP_VERSION); checkUpdate();
frame.setVisible(true); }
frame.setDefaultCloseOperation(StudioFrame.DO_NOTHING_ON_CLOSE); }.start();
}; }
}); frame = new StudioFrame(APP_NAME + " " + APP_VERSION);
for (File f : ConfigCache.getKnownWorkspaces()) { frame.setVisible(true);
if (workspaceRoot.equals(f)) { frame.setDefaultCloseOperation(StudioFrame.DO_NOTHING_ON_CLOSE);
if (!workspaceRoot.equals(ConfigCache.getLatestWorkspace())) { };
ConfigCache.setLatestWorkspace(f); });
} for (File f : ConfigCache.getKnownWorkspaces()) {
return; if (workspaceRoot.equals(f)) {
} if (!workspaceRoot.equals(ConfigCache.getLatestWorkspace())) {
} ConfigCache.setLatestWorkspace(f);
ConfigCache.addWorkspace(workspaceRoot); }
ConfigCache.setLatestWorkspace(workspaceRoot); return;
}
} }
} ConfigCache.addWorkspace(workspaceRoot);
}); ConfigCache.setLatestWorkspace(workspaceRoot);
}
}
private static void checkUpdate() { }
BufferedReader in = null; });
try { }
URL url = new URL(CHECK_UPDATE_URL);
in = new BufferedReader(new InputStreamReader(url.openStream())); private static void checkUpdate() {
BufferedReader in = null;
String inputLine, lastLine = null; try {
while ((inputLine = in.readLine()) != null) {lastLine = inputLine;} URL url = new URL(CHECK_UPDATE_URL);
if (lastLine != null && !lastLine.equals(APP_VERSION)) { in = new BufferedReader(new InputStreamReader(url.openStream()));
// for copying style String inputLine, lastLine = null;
JLabel label = new JLabel(); while ((inputLine = in.readLine()) != null) {
Font font = label.getFont(); lastLine = inputLine;
Color color = label.getBackground(); }
if (lastLine != null && !lastLine.equals(APP_VERSION)) {
// create some css from the label's font
StringBuffer style = new StringBuffer("font-family:" + font.getFamily() + ";"); // for copying style
style.append("font-weight:" + (font.isBold() ? "bold" : "normal") + ";"); JLabel label = new JLabel();
style.append("font-size:" + font.getSize() + "pt;"); Font font = label.getFont();
style.append("background-color: rgb("+color.getRed()+","+color.getGreen()+","+color.getBlue()+");"); Color color = label.getBackground();
JEditorPane ep = new JEditorPane("text/html", "<html><body style=\"" + style + "\">" // create some css from the label's font
+ "You are not running the latest ATCS version.<br/>" StringBuffer style = new StringBuffer("font-family:" + font.getFamily() + ";");
+ "You can get the latest version ("+lastLine+") by clicking the link below.<br/>" style.append("font-weight:" + (font.isBold() ? "bold" : "normal") + ";");
+ "<a href=\""+DOWNLOAD_URL+"\">"+DOWNLOAD_URL+"</a><br/>" style.append("font-size:" + font.getSize() + "pt;");
+ "<br/>" style.append("background-color: rgb(" + color.getRed() + "," + color.getGreen() + "," + color.getBlue()
+ "</body></html>"); + ");");
ep.setEditable(false); JEditorPane ep = new JEditorPane("text/html",
ep.setBorder(null); "<html><body style=\"" + style + "\">" + "You are not running the latest ATCS version.<br/>"
+ "You can get the latest version (" + lastLine + ") by clicking the link below.<br/>"
ep.addHyperlinkListener(new HyperlinkListener() { + "<a href=\"" + DOWNLOAD_URL + "\">" + DOWNLOAD_URL + "</a><br/>" + "<br/>"
+ "</body></html>");
@Override
public void hyperlinkUpdate(HyperlinkEvent e) { ep.setEditable(false);
try { ep.setBorder(null);
if (e.getEventType().equals(HyperlinkEvent.EventType.ACTIVATED)) {
Desktop.getDesktop().browse(e.getURL().toURI()); ep.addHyperlinkListener(new HyperlinkListener() {
}
} catch (IOException e1) { @Override
e1.printStackTrace(); public void hyperlinkUpdate(HyperlinkEvent e) {
} catch (URISyntaxException e1) { try {
e1.printStackTrace(); if (e.getEventType().equals(HyperlinkEvent.EventType.ACTIVATED)) {
} Desktop.getDesktop().browse(e.getURL().toURI());
} }
}); } catch (IOException e1) {
e1.printStackTrace();
JOptionPane.showMessageDialog(null, ep, "Update available", JOptionPane.INFORMATION_MESSAGE); } catch (URISyntaxException e1) {
} e1.printStackTrace();
} catch (MalformedURLException e) { }
e.printStackTrace(); }
} catch (IOException e) { });
e.printStackTrace();
} finally { JOptionPane.showMessageDialog(null, ep, "Update available", JOptionPane.INFORMATION_MESSAGE);
try { }
if (in != null) in.close(); } catch (MalformedURLException e) {
} catch (IOException e) { e.printStackTrace();
e.printStackTrace(); } catch (IOException e) {
} e.printStackTrace();
} } finally {
} try {
if (in != null)
public static void scaleUIFont() { in.close();
if (SCALING != 1.0f) { } catch (IOException e) {
System.out.println("Scaling fonts to "+SCALING); e.printStackTrace();
UIDefaults defaults = UIManager.getLookAndFeelDefaults(); }
Map<Object, Object> newDefaults = new HashMap<Object, Object>(); }
for (Enumeration<Object> e = defaults.keys(); e.hasMoreElements();) { }
Object key = e.nextElement();
Object value = defaults.get(key); public static void scaleUIFont() {
if (value instanceof Font) { if (SCALING != 1.0f) {
Font font = (Font) value; System.out.println("Scaling fonts to " + SCALING);
int newSize = (int)(font.getSize() * SCALING); UIDefaults defaults = UIManager.getLookAndFeelDefaults();
if (value instanceof FontUIResource) { Map<Object, Object> newDefaults = new HashMap<Object, Object>();
newDefaults.put(key, new FontUIResource(font.getName(), font.getStyle(), newSize)); for (Enumeration<Object> e = defaults.keys(); e.hasMoreElements();) {
} else { Object key = e.nextElement();
newDefaults.put(key, new Font(font.getName(), font.getStyle(), newSize)); Object value = defaults.get(key);
} if (value instanceof Font) {
} Font font = (Font) value;
} int newSize = (int) (font.getSize() * SCALING);
for (Object key : newDefaults.keySet()) { if (value instanceof FontUIResource) {
defaults.put(key, newDefaults.get(key)); newDefaults.put(key, new FontUIResource(font.getName(), font.getStyle(), newSize));
} } else {
} newDefaults.put(key, new Font(font.getName(), font.getStyle(), newSize));
} }
} }
}
for (Object key : newDefaults.keySet()) {
defaults.put(key, newDefaults.get(key));
}
}
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 275 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 703 B

View File

@@ -1,193 +1,219 @@
package com.gpl.rpg.atcontentstudio.model; package com.gpl.rpg.atcontentstudio.model;
import java.awt.Image; import java.awt.Image;
import java.io.Serializable; import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
import javax.swing.tree.TreeNode; import javax.swing.tree.TreeNode;
import com.gpl.rpg.atcontentstudio.model.bookmarks.BookmarkEntry; import com.gpl.rpg.atcontentstudio.model.bookmarks.BookmarkEntry;
public abstract class GameDataElement implements ProjectTreeNode, Serializable { public abstract class GameDataElement implements ProjectTreeNode, Serializable {
private static final long serialVersionUID = 2028934451226743389L; private static final long serialVersionUID = 2028934451226743389L;
public static enum State { public static enum State {
init, // We know the object exists, and have its key/ID. init, // We know the object exists, and have its key/ID.
parsed, // We know the object's properties, but related objects are referenced by ID only. parsed, // We know the object's properties, but related objects are referenced by ID only.
linked, // We know the object fully, and all links to related objects point to objects in the parsed state at least. linked, // We know the object fully, and all links to related objects point to objects in the parsed state at least.
created, // This is an object we are creating created, // This is an object we are creating
modified, // Whether altered or created, this item has been modified since creation from scratch or from JSON. modified, // Whether altered or created, this item has been modified since creation from scratch or from JSON.
saved // Whether altered or created, this item has been saved since last modification. saved // Whether altered or created, this item has been saved since last modification.
} }
public State state = State.init; public State state = State.init;
//Available from state init. //Available from state init.
public ProjectTreeNode parent; public ProjectTreeNode parent;
public boolean writable = false; public boolean writable = false;
public BookmarkEntry bookmark = null; public BookmarkEntry bookmark = null;
//List of objects whose transition to "linked" state made them point to this instance. //List of objects whose transition to "linked" state made them point to this instance.
private Map<GameDataElement, Integer> backlinks = new ConcurrentHashMap<GameDataElement, Integer>(); private Map<GameDataElement, Integer> backlinks = new ConcurrentHashMap<GameDataElement, Integer>();
public String id = null; public String id = null;
@Override @Override
public Enumeration<ProjectTreeNode> children() { public Enumeration<ProjectTreeNode> children() {
return null; return null;
} }
@Override @Override
public boolean getAllowsChildren() { public boolean getAllowsChildren() {
return false; return false;
} }
@Override @Override
public TreeNode getChildAt(int arg0) { public TreeNode getChildAt(int arg0) {
return null; return null;
} }
@Override @Override
public int getChildCount() { public int getChildCount() {
return 0; return 0;
} }
@Override @Override
public int getIndex(TreeNode arg0) { public int getIndex(TreeNode arg0) {
return 0; return 0;
} }
@Override @Override
public TreeNode getParent() { public TreeNode getParent() {
return parent; return parent;
} }
@Override @Override
public boolean isLeaf() { public boolean isLeaf() {
return true; return true;
} }
@Override @Override
public void childrenAdded(List<ProjectTreeNode> path) { public void childrenAdded(List<ProjectTreeNode> path) {
path.add(0,this); path.add(0,this);
parent.childrenAdded(path); parent.childrenAdded(path);
} }
@Override @Override
public void childrenChanged(List<ProjectTreeNode> path) { public void childrenChanged(List<ProjectTreeNode> path) {
path.add(0,this); path.add(0,this);
parent.childrenChanged(path); parent.childrenChanged(path);
} }
@Override @Override
public void childrenRemoved(List<ProjectTreeNode> path) { public void childrenRemoved(List<ProjectTreeNode> path) {
path.add(0,this); path.add(0,this);
parent.childrenRemoved(path); parent.childrenRemoved(path);
} }
@Override @Override
public void notifyCreated() { public void notifyCreated() {
childrenAdded(new ArrayList<ProjectTreeNode>()); childrenAdded(new ArrayList<ProjectTreeNode>());
} }
@Override @Override
public abstract String getDesc(); public abstract String getDesc();
public static String getStaticDesc() { public static String getStaticDesc() {
return "GameDataElements"; return "GameDataElements";
} }
public abstract void parse(); public abstract void parse();
public abstract void link(); public abstract void link();
@Override @Override
public Project getProject() { public Project getProject() {
return parent == null ? null : parent.getProject(); return parent == null ? null : parent.getProject();
} }
public Image getIcon() { public Image getIcon() {
return null; return null;
} }
@Override @Override
public Image getClosedIcon() {return null;} public Image getClosedIcon() {return null;}
@Override @Override
public Image getOpenIcon() {return null;} public Image getOpenIcon() {return null;}
@Override @Override
public Image getLeafIcon() { public Image getLeafIcon() {
return getIcon(); return getIcon();
} }
public abstract GameDataElement clone(); public abstract GameDataElement clone();
public abstract void elementChanged(GameDataElement oldOne, GameDataElement newOne); public abstract void elementChanged(GameDataElement oldOne, GameDataElement newOne);
@Override @Override
public GameSource.Type getDataType() { public GameSource.Type getDataType() {
if (parent == null) { if (parent == null) {
System.out.println("blerf."); System.out.println("blerf.");
} }
return parent.getDataType(); return parent.getDataType();
} }
public List<BacklinksListener> backlinkListeners = new ArrayList<GameDataElement.BacklinksListener>(); public List<BacklinksListener> backlinkListeners = new ArrayList<GameDataElement.BacklinksListener>();
public void addBacklinkListener(BacklinksListener l) { public void addBacklinkListener(BacklinksListener l) {
backlinkListeners.add(l); backlinkListeners.add(l);
} }
public void removeBacklinkListener(BacklinksListener l) { public void removeBacklinkListener(BacklinksListener l) {
backlinkListeners.remove(l); backlinkListeners.remove(l);
} }
public void addBacklink(GameDataElement gde) { public void addBacklink(GameDataElement gde) {
if (!backlinks.containsKey(gde)) { if (!backlinks.containsKey(gde)) {
backlinks.put(gde, 1); backlinks.put(gde, 1);
for (BacklinksListener l : backlinkListeners) { for (BacklinksListener l : backlinkListeners) {
l.backlinkAdded(gde); l.backlinkAdded(gde);
} }
} else { } else {
backlinks.put(gde, backlinks.get(gde) + 1); backlinks.put(gde, backlinks.get(gde) + 1);
} }
} }
public void removeBacklink(GameDataElement gde) { public void removeBacklink(GameDataElement gde) {
if (backlinks.get(gde) == null) return; if (backlinks.get(gde) == null) return;
backlinks.put(gde, backlinks.get(gde) - 1); backlinks.put(gde, backlinks.get(gde) - 1);
if (backlinks.get(gde) == 0) { if (backlinks.get(gde) == 0) {
backlinks.remove(gde); backlinks.remove(gde);
for (BacklinksListener l : backlinkListeners) { for (BacklinksListener l : backlinkListeners) {
l.backlinkRemoved(gde); l.backlinkRemoved(gde);
} }
} }
} }
public Set<GameDataElement> getBacklinks() { public Set<GameDataElement> getBacklinks() {
return backlinks.keySet(); return backlinks.keySet();
} }
public static interface BacklinksListener { public static interface BacklinksListener {
public void backlinkAdded(GameDataElement gde); public void backlinkAdded(GameDataElement gde);
public void backlinkRemoved(GameDataElement gde); public void backlinkRemoved(GameDataElement gde);
} }
@Override @Override
public boolean isEmpty() { public boolean isEmpty() {
return false; return false;
} }
public boolean needsSaving() { public boolean needsSaving() {
return this.state == State.modified || this.state == State.created; return this.state == State.modified || this.state == State.created;
} }
public abstract String getProjectFilename(); public abstract String getProjectFilename();
public abstract void save(); public abstract void save();
public abstract List<SaveEvent> attemptSave(); public abstract List<SaveEvent> attemptSave();
} /**
* Checks if the current state indicates that parsing/linking should be skipped.
* @return true if the operation should be skipped, false otherwise
*/
protected boolean shouldSkipParseOrLink() {
if (this.state == State.created || this.state == State.modified || this.state == State.saved) {
//This type of state is unrelated to parsing/linking.
return true;
}
if (this.state == State.linked) {
//Already linked.
return true;
}
return false;
}
/**
* Ensures the element is parsed if needed based on its current state.
*/
protected void ensureParseIfNeeded() {
if (this.state == State.init) {
//Not parsed yet.
this.parse();
}
}
}

View File

@@ -11,6 +11,10 @@ import java.io.IOException;
import java.io.Serializable; import java.io.Serializable;
import java.io.StringReader; import java.io.StringReader;
import java.io.StringWriter; import java.io.StringWriter;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
import java.util.Enumeration; import java.util.Enumeration;
@@ -74,7 +78,9 @@ import com.gpl.rpg.atcontentstudio.utils.FileUtils;
public class Project implements ProjectTreeNode, Serializable { public class Project implements ProjectTreeNode, Serializable {
private static final long serialVersionUID = 4807454973303366758L; private static final long serialVersionUID = 4807454973303366758L;
private static final String drawablePath = TMXMapSet.DEFAULT_REL_PATH_TO_DRAWABLE.replace("\\", "/");
//Every instance field that is not transient will be saved in this file. //Every instance field that is not transient will be saved in this file.
public static final String SETTINGS_FILE = ".project"; public static final String SETTINGS_FILE = ".project";
@@ -1079,10 +1085,16 @@ public class Project implements ProjectTreeNode, Serializable {
public void run() { public void run() {
Notification.addInfo("Exporting project \""+name+"\" as "+target.getAbsolutePath()); Notification.addInfo("Exporting project \""+name+"\" as "+target.getAbsolutePath());
File tmpDir = exportProjectToTmpDir(); File tmpDir;
try {
tmpDir = exportProjectToTmpDir();
FileUtils.writeToZip(tmpDir, target);
FileUtils.deleteDir(tmpDir);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
FileUtils.writeToZip(tmpDir, target);
FileUtils.deleteDir(tmpDir);
Notification.addSuccess("Project \""+name+"\" exported as "+target.getAbsolutePath()); Notification.addSuccess("Project \""+name+"\" exported as "+target.getAbsolutePath());
} }
@@ -1096,10 +1108,16 @@ public class Project implements ProjectTreeNode, Serializable {
public void run() { public void run() {
Notification.addInfo("Exporting project \""+name+"\" into "+target.getAbsolutePath()); Notification.addInfo("Exporting project \""+name+"\" into "+target.getAbsolutePath());
File tmpDir = exportProjectToTmpDir(); File tmpDir;
try {
tmpDir = exportProjectToTmpDir();
FileUtils.copyOver(tmpDir, target);
FileUtils.deleteDir(tmpDir);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
FileUtils.copyOver(tmpDir, target);
FileUtils.deleteDir(tmpDir);
Notification.addSuccess("Project \""+name+"\" exported into "+target.getAbsolutePath()); Notification.addSuccess("Project \""+name+"\" exported into "+target.getAbsolutePath());
} }
@@ -1107,7 +1125,7 @@ public class Project implements ProjectTreeNode, Serializable {
}); });
} }
public File exportProjectToTmpDir() { public File exportProjectToTmpDir() throws IOException {
File tmpDir = new File(baseFolder, "tmp"); File tmpDir = new File(baseFolder, "tmp");
FileUtils.deleteDir(tmpDir); FileUtils.deleteDir(tmpDir);
tmpDir.mkdir(); tmpDir.mkdir();
@@ -1139,12 +1157,12 @@ public class Project implements ProjectTreeNode, Serializable {
writtenFiles = new LinkedList<String>(); writtenFiles = new LinkedList<String>();
for (File createdMapFile : createdContent.gameMaps.mapFolder.listFiles()) { for (File createdMapFile : createdContent.gameMaps.mapFolder.listFiles()) {
if (createdMapFile.getName().equalsIgnoreCase("worldmap.xml")) continue; if (createdMapFile.getName().equalsIgnoreCase("worldmap.xml")) continue;
FileUtils.copyFile(createdMapFile, new File(tmpMapDir, createdMapFile.getName())); copyTmxConverted(createdMapFile.toPath(), Paths.get(tmpMapDir.getAbsolutePath(), createdMapFile.getName()));
writtenFiles.add(createdMapFile.getName()); writtenFiles.add(createdMapFile.getName());
} }
for (File alteredMapFile : alteredContent.gameMaps.mapFolder.listFiles()) { for (File alteredMapFile : alteredContent.gameMaps.mapFolder.listFiles()) {
if (alteredMapFile.getName().equalsIgnoreCase("worldmap.xml")) continue; if (alteredMapFile.getName().equalsIgnoreCase("worldmap.xml")) continue;
FileUtils.copyFile(alteredMapFile, new File(tmpMapDir, alteredMapFile.getName())); copyTmxConverted(alteredMapFile.toPath(), Paths.get(tmpMapDir.getAbsolutePath(), alteredMapFile.getName()));
writtenFiles.add(alteredMapFile.getName()); writtenFiles.add(alteredMapFile.getName());
} }
writtenFilesPerDataType.put(TMXMap.class, writtenFiles); writtenFilesPerDataType.put(TMXMap.class, writtenFiles);
@@ -1177,6 +1195,16 @@ public class Project implements ProjectTreeNode, Serializable {
return tmpDir; return tmpDir;
} }
private void copyTmxConverted(Path from, Path to) throws IOException {
String xml = new String(Files.readAllBytes(from), StandardCharsets.UTF_8);
xml = xml.replace("../../altered/spritesheets/", drawablePath);
xml = xml.replace("../../created/spritesheets/", drawablePath);
xml = xml.replace("../spritesheets/", drawablePath);
xml = xml.replace("../spritesheets/", drawablePath);
Files.write(to, xml.getBytes(StandardCharsets.UTF_8));
}
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public List<String> writeDataDeltaForDataType(GameDataCategory<? extends JSONElement> created, GameDataCategory<? extends JSONElement> altered, GameDataCategory<? extends JSONElement> source, Class<? extends JSONElement> gdeClass, File targetFolder) { public List<String> writeDataDeltaForDataType(GameDataCategory<? extends JSONElement> created, GameDataCategory<? extends JSONElement> altered, GameDataCategory<? extends JSONElement> source, Class<? extends JSONElement> gdeClass, File targetFolder) {
List<String> filenamesToWrite = new LinkedList<String>(); List<String> filenamesToWrite = new LinkedList<String>();

View File

@@ -1,372 +1,374 @@
package com.gpl.rpg.atcontentstudio.model.gamedata; package com.gpl.rpg.atcontentstudio.model.gamedata;
import java.awt.Image; import java.awt.Image;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.FileReader; import java.io.FileReader;
import java.io.IOException; import java.io.IOException;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.json.simple.parser.JSONParser; import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException; import org.json.simple.parser.ParseException;
import com.gpl.rpg.atcontentstudio.Notification; import com.gpl.rpg.atcontentstudio.Notification;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.GameSource; import com.gpl.rpg.atcontentstudio.model.GameSource;
public class ActorCondition extends JSONElement { public class ActorCondition extends JSONElement {
private static final long serialVersionUID = -3969824899972048507L; private static final long serialVersionUID = -3969824899972048507L;
public static final Integer MAGNITUDE_CLEAR = -99; public static final Integer MAGNITUDE_CLEAR = -99;
public static final Integer DURATION_FOREVER = 999;; public static final Integer DURATION_FOREVER = 999;;
public static final Integer DURATION_NONE = 0; public static final Integer DURATION_NONE = 0;
// Available from init state // Available from init state
//public String id; inherited. //public String id; inherited.
public String icon_id; public String icon_id;
public String display_name; public String display_name;
public String description;
// Available from parsed state
public ACCategory category = null; // Available from parsed state
public Integer positive = null; public ACCategory category = null;
public Integer stacking = null; public Integer positive = null;
public RoundEffect round_effect = null; public Integer stacking = null;
public RoundEffect full_round_effect = null; public RoundEffect round_effect = null;
public AbilityEffect constant_ability_effect = null; public RoundEffect full_round_effect = null;
public AbilityEffect constant_ability_effect = null;
public enum ACCategory {
spiritual, public enum ACCategory {
mental, spiritual,
physical, mental,
blood physical,
} blood
}
public static enum VisualEffectID {
redSplash public static enum VisualEffectID {
,blueSwirl redSplash
,greenSplash ,blueSwirl
,miss ,greenSplash
} ,miss
}
public static class RoundEffect implements Cloneable {
// Available from parsed state public static class RoundEffect implements Cloneable {
public VisualEffectID visual_effect = null; // Available from parsed state
public Integer hp_boost_min = null; public VisualEffectID visual_effect = null;
public Integer hp_boost_max = null; public Integer hp_boost_min = null;
public Integer ap_boost_min = null; public Integer hp_boost_max = null;
public Integer ap_boost_max = null; public Integer ap_boost_min = null;
public Integer ap_boost_max = null;
public Object clone() {
try { public Object clone() {
return super.clone(); try {
} catch (CloneNotSupportedException e) { return super.clone();
e.printStackTrace(); } catch (CloneNotSupportedException e) {
} e.printStackTrace();
return null; }
} return null;
} }
}
public static class AbilityEffect implements Cloneable {
// Available from parsed state public static class AbilityEffect implements Cloneable {
public Integer max_hp_boost = null; // Available from parsed state
public Integer max_ap_boost = null; public Integer max_hp_boost = null;
public Integer increase_move_cost = null; public Integer max_ap_boost = null;
public Integer increase_use_cost = null; public Integer increase_move_cost = null;
public Integer increase_reequip_cost = null; public Integer increase_use_cost = null;
public Integer increase_attack_cost = null; public Integer increase_reequip_cost = null;
public Integer increase_attack_chance = null; public Integer increase_attack_cost = null;
public Integer increase_damage_min = null; public Integer increase_attack_chance = null;
public Integer increase_damage_max = null; public Integer increase_damage_min = null;
public Integer increase_critical_skill = null; public Integer increase_damage_max = null;
public Integer increase_block_chance = null; public Integer increase_critical_skill = null;
public Integer increase_damage_resistance = null; public Integer increase_block_chance = null;
public Integer increase_damage_resistance = null;
public Object clone() {
try { public Object clone() {
return super.clone(); try {
} catch (CloneNotSupportedException e) { return super.clone();
e.printStackTrace(); } catch (CloneNotSupportedException e) {
} e.printStackTrace();
return null; }
} return null;
} }
}
@Override
public String getDesc() { @Override
return (needsSaving() ? "*" : "")+display_name+" ("+id+")"; public String getDesc() {
} return (needsSaving() ? "*" : "")+display_name+" ("+id+")";
}
@SuppressWarnings("rawtypes")
public static void fromJson(File jsonFile, GameDataCategory<ActorCondition> category) { @SuppressWarnings("rawtypes")
JSONParser parser = new JSONParser(); public static void fromJson(File jsonFile, GameDataCategory<ActorCondition> category) {
FileReader reader = null; JSONParser parser = new JSONParser();
try { FileReader reader = null;
reader = new FileReader(jsonFile); try {
List actorConditions = (List) parser.parse(reader); reader = new FileReader(jsonFile);
for (Object obj : actorConditions) { List actorConditions = (List) parser.parse(reader);
Map aCondJson = (Map)obj; for (Object obj : actorConditions) {
ActorCondition aCond = fromJson(aCondJson); Map aCondJson = (Map)obj;
aCond.jsonFile = jsonFile; ActorCondition aCond = fromJson(aCondJson);
aCond.parent = category; aCond.jsonFile = jsonFile;
if (aCond.getDataType() == GameSource.Type.created || aCond.getDataType() == GameSource.Type.altered) { aCond.parent = category;
aCond.writable = true; if (aCond.getDataType() == GameSource.Type.created || aCond.getDataType() == GameSource.Type.altered) {
} aCond.writable = true;
category.add(aCond); }
} category.add(aCond);
} catch (FileNotFoundException e) { }
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); } catch (FileNotFoundException e) {
e.printStackTrace(); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
} catch (IOException e) { e.printStackTrace();
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); } catch (IOException e) {
e.printStackTrace(); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
} catch (ParseException e) { e.printStackTrace();
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); } catch (ParseException e) {
e.printStackTrace(); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
} finally { e.printStackTrace();
if (reader != null) } finally {
try { if (reader != null)
reader.close(); try {
} catch (IOException e) { reader.close();
e.printStackTrace(); } catch (IOException e) {
} e.printStackTrace();
} }
} }
}
@SuppressWarnings("rawtypes")
public static ActorCondition fromJson(String jsonString) throws ParseException { @SuppressWarnings("rawtypes")
Map aCondJson = (Map) new JSONParser().parse(jsonString); public static ActorCondition fromJson(String jsonString) throws ParseException {
ActorCondition aCond = fromJson(aCondJson); Map aCondJson = (Map) new JSONParser().parse(jsonString);
aCond.parse(aCondJson); ActorCondition aCond = fromJson(aCondJson);
return aCond; aCond.parse(aCondJson);
} return aCond;
}
@SuppressWarnings("rawtypes")
public static ActorCondition fromJson(Map aCondJson) { @SuppressWarnings("rawtypes")
ActorCondition aCond = new ActorCondition(); public static ActorCondition fromJson(Map aCondJson) {
aCond.icon_id = (String) aCondJson.get("iconID"); ActorCondition aCond = new ActorCondition();
aCond.id = (String) aCondJson.get("id"); aCond.icon_id = (String) aCondJson.get("iconID");
aCond.display_name = (String) aCondJson.get("name"); aCond.id = (String) aCondJson.get("id");
return aCond; aCond.display_name = (String) aCondJson.get("name");
} return aCond;
}
@SuppressWarnings("rawtypes")
@Override @SuppressWarnings("rawtypes")
public void parse(Map aCondJson) { @Override
public void parse(Map aCondJson) {
if (aCondJson.get("category") != null) this.category = ACCategory.valueOf((String) aCondJson.get("category"));
this.positive = JSONElement.getInteger((Number) aCondJson.get("isPositive")); if (aCondJson.get("description") != null) this.description = (String) aCondJson.get("description");
Map abilityEffect = (Map) aCondJson.get("abilityEffect"); if (aCondJson.get("category") != null) this.category = ACCategory.valueOf((String) aCondJson.get("category"));
if (abilityEffect != null) { this.positive = JSONElement.getInteger((Number) aCondJson.get("isPositive"));
this.constant_ability_effect = new AbilityEffect(); Map abilityEffect = (Map) aCondJson.get("abilityEffect");
this.constant_ability_effect.increase_attack_chance = JSONElement.getInteger((Number) abilityEffect.get("increaseAttackChance")); if (abilityEffect != null) {
if (abilityEffect.get("increaseAttackDamage") != null) { this.constant_ability_effect = new AbilityEffect();
this.constant_ability_effect.increase_damage_min = JSONElement.getInteger((Number) (((Map)abilityEffect.get("increaseAttackDamage")).get("min"))); this.constant_ability_effect.increase_attack_chance = JSONElement.getInteger((Number) abilityEffect.get("increaseAttackChance"));
this.constant_ability_effect.increase_damage_max = JSONElement.getInteger((Number) (((Map)abilityEffect.get("increaseAttackDamage")).get("max"))); if (abilityEffect.get("increaseAttackDamage") != null) {
} this.constant_ability_effect.increase_damage_min = JSONElement.getInteger((Number) (((Map)abilityEffect.get("increaseAttackDamage")).get("min")));
this.constant_ability_effect.max_hp_boost = JSONElement.getInteger((Number) abilityEffect.get("increaseMaxHP")); this.constant_ability_effect.increase_damage_max = JSONElement.getInteger((Number) (((Map)abilityEffect.get("increaseAttackDamage")).get("max")));
this.constant_ability_effect.max_ap_boost = JSONElement.getInteger((Number) abilityEffect.get("increaseMaxAP")); }
this.constant_ability_effect.increase_move_cost = JSONElement.getInteger((Number) abilityEffect.get("increaseMoveCost")); this.constant_ability_effect.max_hp_boost = JSONElement.getInteger((Number) abilityEffect.get("increaseMaxHP"));
this.constant_ability_effect.increase_use_cost = JSONElement.getInteger((Number) abilityEffect.get("increaseUseItemCost")); this.constant_ability_effect.max_ap_boost = JSONElement.getInteger((Number) abilityEffect.get("increaseMaxAP"));
this.constant_ability_effect.increase_reequip_cost = JSONElement.getInteger((Number) abilityEffect.get("increaseReequipCost")); this.constant_ability_effect.increase_move_cost = JSONElement.getInteger((Number) abilityEffect.get("increaseMoveCost"));
this.constant_ability_effect.increase_attack_cost = JSONElement.getInteger((Number) abilityEffect.get("increaseAttackCost")); this.constant_ability_effect.increase_use_cost = JSONElement.getInteger((Number) abilityEffect.get("increaseUseItemCost"));
this.constant_ability_effect.increase_critical_skill = JSONElement.getInteger((Number) abilityEffect.get("increaseCriticalSkill")); this.constant_ability_effect.increase_reequip_cost = JSONElement.getInteger((Number) abilityEffect.get("increaseReequipCost"));
this.constant_ability_effect.increase_block_chance = JSONElement.getInteger((Number) abilityEffect.get("increaseBlockChance")); this.constant_ability_effect.increase_attack_cost = JSONElement.getInteger((Number) abilityEffect.get("increaseAttackCost"));
this.constant_ability_effect.increase_damage_resistance = JSONElement.getInteger((Number) abilityEffect.get("increaseDamageResistance")); this.constant_ability_effect.increase_critical_skill = JSONElement.getInteger((Number) abilityEffect.get("increaseCriticalSkill"));
} this.constant_ability_effect.increase_block_chance = JSONElement.getInteger((Number) abilityEffect.get("increaseBlockChance"));
this.stacking = JSONElement.getInteger((Number) aCondJson.get("isStacking")); this.constant_ability_effect.increase_damage_resistance = JSONElement.getInteger((Number) abilityEffect.get("increaseDamageResistance"));
Map roundEffect = (Map) aCondJson.get("roundEffect"); }
if (roundEffect != null) { this.stacking = JSONElement.getInteger((Number) aCondJson.get("isStacking"));
this.round_effect = new RoundEffect(); Map roundEffect = (Map) aCondJson.get("roundEffect");
if (roundEffect.get("increaseCurrentHP") != null) { if (roundEffect != null) {
this.round_effect.hp_boost_max = JSONElement.getInteger((Number) (((Map)roundEffect.get("increaseCurrentHP")).get("max"))); this.round_effect = new RoundEffect();
this.round_effect.hp_boost_min = JSONElement.getInteger((Number) (((Map)roundEffect.get("increaseCurrentHP")).get("min"))); if (roundEffect.get("increaseCurrentHP") != null) {
} this.round_effect.hp_boost_max = JSONElement.getInteger((Number) (((Map)roundEffect.get("increaseCurrentHP")).get("max")));
if (roundEffect.get("increaseCurrentAP") != null) { this.round_effect.hp_boost_min = JSONElement.getInteger((Number) (((Map)roundEffect.get("increaseCurrentHP")).get("min")));
this.round_effect.ap_boost_max = JSONElement.getInteger((Number) (((Map)roundEffect.get("increaseCurrentAP")).get("max"))); }
this.round_effect.ap_boost_min = JSONElement.getInteger((Number) (((Map)roundEffect.get("increaseCurrentAP")).get("min"))); if (roundEffect.get("increaseCurrentAP") != null) {
} this.round_effect.ap_boost_max = JSONElement.getInteger((Number) (((Map)roundEffect.get("increaseCurrentAP")).get("max")));
String vfx = (String) roundEffect.get("visualEffectID"); this.round_effect.ap_boost_min = JSONElement.getInteger((Number) (((Map)roundEffect.get("increaseCurrentAP")).get("min")));
this.round_effect.visual_effect = null; }
if (vfx != null) { String vfx = (String) roundEffect.get("visualEffectID");
try { this.round_effect.visual_effect = null;
this.round_effect.visual_effect = VisualEffectID.valueOf(vfx); if (vfx != null) {
} catch(IllegalArgumentException e) {} try {
} this.round_effect.visual_effect = VisualEffectID.valueOf(vfx);
} } catch(IllegalArgumentException e) {}
Map fullRoundEffect = (Map) aCondJson.get("fullRoundEffect"); }
if (fullRoundEffect != null) { }
this.full_round_effect = new RoundEffect(); Map fullRoundEffect = (Map) aCondJson.get("fullRoundEffect");
if (fullRoundEffect.get("increaseCurrentHP") != null) { if (fullRoundEffect != null) {
this.full_round_effect.hp_boost_max = JSONElement.getInteger((Number) (((Map)fullRoundEffect.get("increaseCurrentHP")).get("max"))); this.full_round_effect = new RoundEffect();
this.full_round_effect.hp_boost_min = JSONElement.getInteger((Number) (((Map)fullRoundEffect.get("increaseCurrentHP")).get("min"))); if (fullRoundEffect.get("increaseCurrentHP") != null) {
} this.full_round_effect.hp_boost_max = JSONElement.getInteger((Number) (((Map)fullRoundEffect.get("increaseCurrentHP")).get("max")));
if (fullRoundEffect.get("increaseCurrentAP") != null) { this.full_round_effect.hp_boost_min = JSONElement.getInteger((Number) (((Map)fullRoundEffect.get("increaseCurrentHP")).get("min")));
this.full_round_effect.ap_boost_max = JSONElement.getInteger((Number) (((Map)fullRoundEffect.get("increaseCurrentAP")).get("max"))); }
this.full_round_effect.ap_boost_min = JSONElement.getInteger((Number) (((Map)fullRoundEffect.get("increaseCurrentAP")).get("min"))); if (fullRoundEffect.get("increaseCurrentAP") != null) {
} this.full_round_effect.ap_boost_max = JSONElement.getInteger((Number) (((Map)fullRoundEffect.get("increaseCurrentAP")).get("max")));
String vfx = (String) fullRoundEffect.get("visualEffectID"); this.full_round_effect.ap_boost_min = JSONElement.getInteger((Number) (((Map)fullRoundEffect.get("increaseCurrentAP")).get("min")));
this.full_round_effect.visual_effect = null; }
if (vfx != null) { String vfx = (String) fullRoundEffect.get("visualEffectID");
try { this.full_round_effect.visual_effect = null;
this.full_round_effect.visual_effect = VisualEffectID.valueOf(vfx); if (vfx != null) {
} catch(IllegalArgumentException e) {} try {
} this.full_round_effect.visual_effect = VisualEffectID.valueOf(vfx);
} } catch(IllegalArgumentException e) {}
this.state = State.parsed; }
}
} this.state = State.parsed;
@Override }
public void link() {
if (this.state == State.created || this.state == State.modified || this.state == State.saved) { @Override
//This type of state is unrelated to parsing/linking. public void link() {
return; if (shouldSkipParseOrLink()) {
} return;
if (this.state == State.init) { }
//Not parsed yet. ensureParseIfNeeded();
this.parse(); if (this.icon_id != null) {
} else if (this.state == State.linked) { String spritesheetId = this.icon_id.split(":")[0];
//Already linked. if (getProject().getSpritesheet(spritesheetId) == null) {
return; System.out.println("Actor Condition");
} System.out.println(this.id);
if (this.icon_id != null) { System.out.println("failed to load spritesheet:");
String spritesheetId = this.icon_id.split(":")[0]; System.out.println(spritesheetId);
if (getProject().getSpritesheet(spritesheetId) == null) { System.out.println("while creating backlink for icon_id:");
System.out.println(this.id); System.out.println(this.icon_id);
} }
getProject().getSpritesheet(spritesheetId).addBacklink(this); getProject().getSpritesheet(spritesheetId).addBacklink(this);
} }
this.state = State.linked; this.state = State.linked;
} }
public static String getStaticDesc() { public static String getStaticDesc() {
return "Actor Conditions"; return "Actor Conditions";
} }
@Override @Override
public Image getIcon() { public Image getIcon() {
return getProject().getIcon(icon_id); return getProject().getIcon(icon_id);
} }
public Image getImage() { public Image getImage() {
return getProject().getImage(icon_id); return getProject().getImage(icon_id);
} }
@Override @Override
public JSONElement clone() { public JSONElement clone() {
ActorCondition clone = new ActorCondition(); ActorCondition clone = new ActorCondition();
clone.jsonFile = this.jsonFile; clone.jsonFile = this.jsonFile;
clone.state = this.state; clone.state = this.state;
clone.id = this.id; clone.id = this.id;
clone.display_name = this.display_name; clone.display_name = this.display_name;
clone.icon_id = this.icon_id; clone.description = this.description;
clone.category = this.category; clone.icon_id = this.icon_id;
clone.positive = this.positive; clone.category = this.category;
clone.stacking = this.stacking; clone.positive = this.positive;
if (this.round_effect != null) { clone.stacking = this.stacking;
clone.round_effect = (RoundEffect) this.round_effect.clone(); if (this.round_effect != null) {
} clone.round_effect = (RoundEffect) this.round_effect.clone();
if (this.constant_ability_effect != null) { }
clone.constant_ability_effect = (AbilityEffect) constant_ability_effect.clone(); if (this.constant_ability_effect != null) {
} clone.constant_ability_effect = (AbilityEffect) constant_ability_effect.clone();
if (this.full_round_effect != null) { }
clone.full_round_effect = (RoundEffect) this.full_round_effect.clone(); if (this.full_round_effect != null) {
} clone.full_round_effect = (RoundEffect) this.full_round_effect.clone();
return clone; }
} return clone;
}
@Override
public void elementChanged(GameDataElement oldOne, GameDataElement newOne) { @Override
//Nothing to link to. public void elementChanged(GameDataElement oldOne, GameDataElement newOne) {
} //Nothing to link to.
}
@SuppressWarnings({ "rawtypes", "unchecked" })
@Override @SuppressWarnings({ "rawtypes", "unchecked" })
public Map toJson() { @Override
Map jsonAC = new LinkedHashMap(); public Map toJson() {
jsonAC.put("id", this.id); Map jsonAC = new LinkedHashMap();
if (this.icon_id != null) jsonAC.put("iconID", this.icon_id); jsonAC.put("id", this.id);
if (this.display_name != null) jsonAC.put("name", this.display_name); if (this.icon_id != null) jsonAC.put("iconID", this.icon_id);
if (this.category != null) jsonAC.put("category", this.category.toString()); if (this.display_name != null) jsonAC.put("name", this.display_name);
if (this.positive != null && this.positive == 1) jsonAC.put("isPositive", this.positive); if (this.description != null) jsonAC.put("description", this.description);
if (this.stacking != null && this.stacking == 1) jsonAC.put("isStacking", this.stacking); if (this.category != null) jsonAC.put("category", this.category.toString());
if (this.round_effect != null) { if (this.positive != null && this.positive == 1) jsonAC.put("isPositive", this.positive);
Map jsonRound = new LinkedHashMap(); if (this.stacking != null && this.stacking == 1) jsonAC.put("isStacking", this.stacking);
if (this.round_effect.visual_effect != null) jsonRound.put("visualEffectID", this.round_effect.visual_effect.toString()); if (this.round_effect != null) {
if (this.round_effect.hp_boost_min != null || this.round_effect.hp_boost_max != null) { Map jsonRound = new LinkedHashMap();
Map jsonHP = new LinkedHashMap(); if (this.round_effect.visual_effect != null) jsonRound.put("visualEffectID", this.round_effect.visual_effect.toString());
if (this.round_effect.hp_boost_min != null) jsonHP.put("min", this.round_effect.hp_boost_min); if (this.round_effect.hp_boost_min != null || this.round_effect.hp_boost_max != null) {
else jsonHP.put("min", 0); Map jsonHP = new LinkedHashMap();
if (this.round_effect.hp_boost_max != null) jsonHP.put("max", this.round_effect.hp_boost_max); if (this.round_effect.hp_boost_min != null) jsonHP.put("min", this.round_effect.hp_boost_min);
else jsonHP.put("max", 0); else jsonHP.put("min", 0);
jsonRound.put("increaseCurrentHP", jsonHP); if (this.round_effect.hp_boost_max != null) jsonHP.put("max", this.round_effect.hp_boost_max);
} else jsonHP.put("max", 0);
if (this.round_effect.ap_boost_min != null || this.round_effect.ap_boost_max != null) { jsonRound.put("increaseCurrentHP", jsonHP);
Map jsonAP = new LinkedHashMap(); }
if (this.round_effect.ap_boost_min != null) jsonAP.put("min", this.round_effect.ap_boost_min); if (this.round_effect.ap_boost_min != null || this.round_effect.ap_boost_max != null) {
else jsonAP.put("min", 0); Map jsonAP = new LinkedHashMap();
if (this.round_effect.ap_boost_max != null) jsonAP.put("max", this.round_effect.ap_boost_max); if (this.round_effect.ap_boost_min != null) jsonAP.put("min", this.round_effect.ap_boost_min);
else jsonAP.put("max", 0); else jsonAP.put("min", 0);
jsonRound.put("increaseCurrentAP", jsonAP); if (this.round_effect.ap_boost_max != null) jsonAP.put("max", this.round_effect.ap_boost_max);
} else jsonAP.put("max", 0);
jsonAC.put("roundEffect", jsonRound); jsonRound.put("increaseCurrentAP", jsonAP);
} }
if (this.full_round_effect != null) { jsonAC.put("roundEffect", jsonRound);
Map jsonFullRound = new LinkedHashMap(); }
if (this.full_round_effect.visual_effect != null) jsonFullRound.put("visualEffectID", this.full_round_effect.visual_effect.toString()); if (this.full_round_effect != null) {
if (this.full_round_effect.hp_boost_min != null || this.full_round_effect.hp_boost_max != null) { Map jsonFullRound = new LinkedHashMap();
Map jsonHP = new LinkedHashMap(); if (this.full_round_effect.visual_effect != null) jsonFullRound.put("visualEffectID", this.full_round_effect.visual_effect.toString());
if (this.full_round_effect.hp_boost_min != null) jsonHP.put("min", this.full_round_effect.hp_boost_min); if (this.full_round_effect.hp_boost_min != null || this.full_round_effect.hp_boost_max != null) {
else jsonHP.put("min", 0); Map jsonHP = new LinkedHashMap();
if (this.full_round_effect.hp_boost_max != null) jsonHP.put("max", this.full_round_effect.hp_boost_max); if (this.full_round_effect.hp_boost_min != null) jsonHP.put("min", this.full_round_effect.hp_boost_min);
else jsonHP.put("max", 0); else jsonHP.put("min", 0);
jsonFullRound.put("increaseCurrentHP", jsonHP); if (this.full_round_effect.hp_boost_max != null) jsonHP.put("max", this.full_round_effect.hp_boost_max);
} else jsonHP.put("max", 0);
if (this.full_round_effect.ap_boost_min != null || this.full_round_effect.ap_boost_max != null) { jsonFullRound.put("increaseCurrentHP", jsonHP);
Map jsonAP = new LinkedHashMap(); }
if (this.full_round_effect.ap_boost_min != null) jsonAP.put("min", this.full_round_effect.ap_boost_min); if (this.full_round_effect.ap_boost_min != null || this.full_round_effect.ap_boost_max != null) {
else jsonAP.put("min", 0); Map jsonAP = new LinkedHashMap();
if (this.full_round_effect.ap_boost_max != null) jsonAP.put("max", this.full_round_effect.ap_boost_max); if (this.full_round_effect.ap_boost_min != null) jsonAP.put("min", this.full_round_effect.ap_boost_min);
else jsonAP.put("max", 0); else jsonAP.put("min", 0);
jsonFullRound.put("increaseCurrentAP", jsonAP); if (this.full_round_effect.ap_boost_max != null) jsonAP.put("max", this.full_round_effect.ap_boost_max);
} else jsonAP.put("max", 0);
jsonAC.put("fullRoundEffect", jsonFullRound); jsonFullRound.put("increaseCurrentAP", jsonAP);
} }
if (this.constant_ability_effect != null) { jsonAC.put("fullRoundEffect", jsonFullRound);
Map jsonAbility = new LinkedHashMap(); }
if (this.constant_ability_effect.increase_attack_chance != null) jsonAbility.put("increaseAttackChance", this.constant_ability_effect.increase_attack_chance); if (this.constant_ability_effect != null) {
if (this.constant_ability_effect.increase_damage_min != null || this.constant_ability_effect.increase_damage_max != null) { Map jsonAbility = new LinkedHashMap();
Map jsonAD = new LinkedHashMap(); if (this.constant_ability_effect.increase_attack_chance != null) jsonAbility.put("increaseAttackChance", this.constant_ability_effect.increase_attack_chance);
if (this.constant_ability_effect.increase_damage_min != null) jsonAD.put("min", this.constant_ability_effect.increase_damage_min); if (this.constant_ability_effect.increase_damage_min != null || this.constant_ability_effect.increase_damage_max != null) {
else jsonAD.put("min", 0); Map jsonAD = new LinkedHashMap();
if (this.constant_ability_effect.increase_damage_max != null) jsonAD.put("max", this.constant_ability_effect.increase_damage_max); if (this.constant_ability_effect.increase_damage_min != null) jsonAD.put("min", this.constant_ability_effect.increase_damage_min);
else jsonAD.put("max", 0); else jsonAD.put("min", 0);
jsonAbility.put("increaseAttackDamage", jsonAD); if (this.constant_ability_effect.increase_damage_max != null) jsonAD.put("max", this.constant_ability_effect.increase_damage_max);
} else jsonAD.put("max", 0);
if (this.constant_ability_effect.max_hp_boost != null) jsonAbility.put("increaseMaxHP", this.constant_ability_effect.max_hp_boost); jsonAbility.put("increaseAttackDamage", jsonAD);
if (this.constant_ability_effect.max_ap_boost != null) jsonAbility.put("increaseMaxAP", this.constant_ability_effect.max_ap_boost); }
if (this.constant_ability_effect.increase_move_cost != null) jsonAbility.put("increaseMoveCost", this.constant_ability_effect.increase_move_cost); if (this.constant_ability_effect.max_hp_boost != null) jsonAbility.put("increaseMaxHP", this.constant_ability_effect.max_hp_boost);
if (this.constant_ability_effect.increase_use_cost != null) jsonAbility.put("increaseUseItemCost", this.constant_ability_effect.increase_use_cost); if (this.constant_ability_effect.max_ap_boost != null) jsonAbility.put("increaseMaxAP", this.constant_ability_effect.max_ap_boost);
if (this.constant_ability_effect.increase_reequip_cost != null) jsonAbility.put("increaseReequipCost", this.constant_ability_effect.increase_reequip_cost); if (this.constant_ability_effect.increase_move_cost != null) jsonAbility.put("increaseMoveCost", this.constant_ability_effect.increase_move_cost);
if (this.constant_ability_effect.increase_attack_cost != null) jsonAbility.put("increaseAttackCost", this.constant_ability_effect.increase_attack_cost); if (this.constant_ability_effect.increase_use_cost != null) jsonAbility.put("increaseUseItemCost", this.constant_ability_effect.increase_use_cost);
if (this.constant_ability_effect.increase_critical_skill != null) jsonAbility.put("increaseCriticalSkill", this.constant_ability_effect.increase_critical_skill); if (this.constant_ability_effect.increase_reequip_cost != null) jsonAbility.put("increaseReequipCost", this.constant_ability_effect.increase_reequip_cost);
if (this.constant_ability_effect.increase_block_chance != null) jsonAbility.put("increaseBlockChance", this.constant_ability_effect.increase_block_chance); if (this.constant_ability_effect.increase_attack_cost != null) jsonAbility.put("increaseAttackCost", this.constant_ability_effect.increase_attack_cost);
if (this.constant_ability_effect.increase_damage_resistance != null) jsonAbility.put("increaseDamageResistance", this.constant_ability_effect.increase_damage_resistance); if (this.constant_ability_effect.increase_critical_skill != null) jsonAbility.put("increaseCriticalSkill", this.constant_ability_effect.increase_critical_skill);
jsonAC.put("abilityEffect", jsonAbility); if (this.constant_ability_effect.increase_block_chance != null) jsonAbility.put("increaseBlockChance", this.constant_ability_effect.increase_block_chance);
} if (this.constant_ability_effect.increase_damage_resistance != null) jsonAbility.put("increaseDamageResistance", this.constant_ability_effect.increase_damage_resistance);
return jsonAC; jsonAC.put("abilityEffect", jsonAbility);
} }
return jsonAC;
@Override }
public String getProjectFilename() {
return "actorconditions_"+getProject().name+".json"; @Override
} public String getProjectFilename() {
return "actorconditions_"+getProject().name+".json";
} }
}

View File

@@ -0,0 +1,184 @@
package com.gpl.rpg.atcontentstudio.model.gamedata;
import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.Project;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
public final class Common {
public static void linkConditions(List<?extends ConditionEffect> conditions, Project proj, GameDataElement backlink) {
if (conditions != null) {
for (ConditionEffect ce : conditions) {
if (ce.condition_id != null) ce.condition = proj.getActorCondition(ce.condition_id);
if (ce.condition != null) ce.condition.addBacklink(backlink);
}
}
}
public static class TimedConditionEffect extends ConditionEffect {
//Available from parsed state
public Integer duration = null;
public Double chance = null;
public TimedConditionEffect createClone() {
TimedConditionEffect cclone = new TimedConditionEffect();
cclone.magnitude = this.magnitude;
cclone.condition_id = this.condition_id;
cclone.condition = this.condition;
cclone.chance = this.chance;
cclone.duration = this.duration;
return cclone;
}
}
public static class ConditionEffect {
//Available from parsed state
public Integer magnitude = null;
public String condition_id = null;
//Available from linked state
public ActorCondition condition = null;
}
@SuppressWarnings("rawtypes")
public static ArrayList<TimedConditionEffect> parseTimedConditionEffects(List conditionsSourceJson) {
ArrayList<TimedConditionEffect> conditions_source;
if (conditionsSourceJson != null && !conditionsSourceJson.isEmpty()) {
conditions_source = new ArrayList<>();
for (Object conditionJsonObj : conditionsSourceJson) {
Map conditionJson = (Map) conditionJsonObj;
TimedConditionEffect condition = new TimedConditionEffect();
readConditionEffect(condition, conditionJson);
condition.duration = JSONElement.getInteger((Number) conditionJson.get("duration"));
if (conditionJson.get("chance") != null)
condition.chance = JSONElement.parseChance(conditionJson.get("chance").toString());
conditions_source.add(condition);
}
} else {
conditions_source = null;
}
return conditions_source;
}
@SuppressWarnings("rawtypes")
private static void readConditionEffect(ConditionEffect condition, Map conditionJson) {
condition.condition_id = (String) conditionJson.get("condition");
condition.magnitude = JSONElement.getInteger((Number) conditionJson.get("magnitude"));
}
@SuppressWarnings("rawtypes")
public static Common.DeathEffect parseDeathEffect(Map killEffect) {
Common.DeathEffect kill_effect = new Common.DeathEffect();
readDeathEffect(killEffect, kill_effect);
return kill_effect;
}
@SuppressWarnings("rawtypes")
public static HitEffect parseHitEffect(Map hitEffect) {
Common.HitEffect hit_effect = new Common.HitEffect();
readHitEffect(hitEffect, hit_effect);
return hit_effect;
}
@SuppressWarnings("rawtypes")
public static HitReceivedEffect parseHitReceivedEffect(Map hitReceivedEffect) {
HitReceivedEffect hit_received_effect = new Common.HitReceivedEffect();
readHitEffect(hitReceivedEffect, hit_received_effect);
if (hitReceivedEffect.get("increaseAttackerCurrentHP") != null) {
hit_received_effect.hp_boost_max_target = JSONElement.getInteger((Number) (((Map) hitReceivedEffect.get("increaseAttackerCurrentHP")).get("max")));
hit_received_effect.hp_boost_min_target = JSONElement.getInteger((Number) (((Map) hitReceivedEffect.get("increaseAttackerCurrentHP")).get("min")));
}
if (hitReceivedEffect.get("increaseAttackerCurrentAP") != null) {
hit_received_effect.ap_boost_max_target = JSONElement.getInteger((Number) (((Map) hitReceivedEffect.get("increaseAttackerCurrentAP")).get("max")));
hit_received_effect.ap_boost_min_target = JSONElement.getInteger((Number) (((Map) hitReceivedEffect.get("increaseAttackerCurrentAP")).get("min")));
}
return hit_received_effect;
}
@SuppressWarnings("rawtypes")
private static void readDeathEffect(Map killEffect, DeathEffect kill_effect) {
if (killEffect.get("increaseCurrentHP") != null) {
kill_effect.hp_boost_min = JSONElement.getInteger((Number) (((Map) killEffect.get("increaseCurrentHP")).get("min")));
kill_effect.hp_boost_max = JSONElement.getInteger((Number) (((Map) killEffect.get("increaseCurrentHP")).get("max")));
}
if (killEffect.get("increaseCurrentAP") != null) {
kill_effect.ap_boost_min = JSONElement.getInteger((Number) (((Map) killEffect.get("increaseCurrentAP")).get("min")));
kill_effect.ap_boost_max = JSONElement.getInteger((Number) (((Map) killEffect.get("increaseCurrentAP")).get("max")));
}
List conditionsSourceJson = (List) killEffect.get("conditionsSource");
kill_effect.conditions_source = parseTimedConditionEffects(conditionsSourceJson);
}
@SuppressWarnings("rawtypes")
private static void readHitEffect(Map hitEffect, HitEffect hit_effect) {
readDeathEffect(hitEffect, hit_effect);
List conditionsTargetJson = (List) hitEffect.get("conditionsTarget");
hit_effect.conditions_target = parseTimedConditionEffects(conditionsTargetJson);
}
public static class DeathEffect {
//Available from parsed state
public Integer hp_boost_min = null;
public Integer hp_boost_max = null;
public Integer ap_boost_min = null;
public Integer ap_boost_max = null;
public List<TimedConditionEffect> conditions_source = null;
}
public static class HitEffect extends DeathEffect {
//Available from parsed state
public List<TimedConditionEffect> conditions_target = null;
}
public static class HitReceivedEffect extends Common.HitEffect {
//Available from parsed state
public Integer hp_boost_min_target = null;
public Integer hp_boost_max_target = null;
public Integer ap_boost_min_target = null;
public Integer ap_boost_max_target = null;
}
public static void copyDeathEffectValues(Common.DeathEffect target, Common.DeathEffect source, GameDataElement backlink) {
target.ap_boost_max = source.ap_boost_max;
target.ap_boost_min = source.ap_boost_min;
target.hp_boost_max = source.hp_boost_max;
target.hp_boost_min = source.hp_boost_min;
if (source.conditions_source != null) {
target.conditions_source = new ArrayList<>();
for (Common.TimedConditionEffect c : source.conditions_source) {
Common.TimedConditionEffect cclone = c.createClone();
if (cclone.condition != null) {
cclone.condition.addBacklink(backlink);
}
target.conditions_source.add(cclone);
}
}
}
public static void copyHitEffectValues(Common.HitEffect target, Common.HitEffect source, GameDataElement backlink) {
copyDeathEffectValues(target, source, backlink);
if (source.conditions_target != null) {
target.conditions_target = new ArrayList<>();
for (Common.TimedConditionEffect c : source.conditions_target) {
Common.TimedConditionEffect cclone = c.createClone();
if (cclone.condition != null) {
cclone.condition.addBacklink(backlink);
}
target.conditions_target.add(cclone);
}
}
}
public static void copyHitReceivedEffectValues(Common.HitReceivedEffect target, Common.HitReceivedEffect source, GameDataElement backlink) {
copyHitEffectValues(target, source, backlink);
target.ap_boost_max_target = source.ap_boost_max_target;
target.ap_boost_min_target = source.ap_boost_min_target;
target.hp_boost_max_target = source.hp_boost_max_target;
target.hp_boost_min_target = source.hp_boost_min_target;
}
}

View File

@@ -1,468 +1,463 @@
package com.gpl.rpg.atcontentstudio.model.gamedata; package com.gpl.rpg.atcontentstudio.model.gamedata;
import java.awt.Image; import java.awt.Image;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.FileReader; import java.io.FileReader;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.json.simple.parser.JSONParser; import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException; import org.json.simple.parser.ParseException;
import com.gpl.rpg.atcontentstudio.Notification; import com.gpl.rpg.atcontentstudio.Notification;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.GameSource; import com.gpl.rpg.atcontentstudio.model.GameSource;
import com.gpl.rpg.atcontentstudio.model.Project; import com.gpl.rpg.atcontentstudio.model.Project;
import com.gpl.rpg.atcontentstudio.model.gamedata.Requirement.RequirementType; import com.gpl.rpg.atcontentstudio.model.gamedata.Requirement.RequirementType;
import com.gpl.rpg.atcontentstudio.model.maps.TMXMap; import com.gpl.rpg.atcontentstudio.model.maps.TMXMap;
import com.gpl.rpg.atcontentstudio.ui.DefaultIcons; import com.gpl.rpg.atcontentstudio.ui.DefaultIcons;
public class Dialogue extends JSONElement { public class Dialogue extends JSONElement {
private static final long serialVersionUID = -6872164604703134683L; private static final long serialVersionUID = -6872164604703134683L;
//Available from init state //Available from init state
//public String id = null; inherited. //public String id = null; inherited.
public String message = null; public String message = null;
//Available from parsed state; //Available from parsed state;
public List<Reward> rewards = null; public List<Reward> rewards = null;
public List<Reply> replies = null; public List<Reply> replies = null;
public String switch_to_npc_id = null; public String switch_to_npc_id = null;
//Available from linked state; //Available from linked state;
public NPC switch_to_npc = null; public NPC switch_to_npc = null;
public static class Reward { public static class Reward {
//Available from parsed state //Available from parsed state
public RewardType type = null; public RewardType type = null;
public String reward_obj_id = null; public String reward_obj_id = null;
public Integer reward_value = null; public Integer reward_value = null;
public String map_name = null; public String map_name = null;
//Available from linked state //Available from linked state
public GameDataElement reward_obj = null; public GameDataElement reward_obj = null;
public TMXMap map = null; public TMXMap map = null;
public enum RewardType { public enum RewardType {
questProgress, questProgress,
removeQuestProgress, removeQuestProgress,
dropList, dropList,
skillIncrease, skillIncrease,
actorCondition, actorCondition,
actorConditionImmunity, actorConditionImmunity,
alignmentChange, alignmentChange,
alignmentSet, alignmentSet,
giveItem, giveItem,
createTimer, createTimer,
spawnAll, spawnAll,
removeSpawnArea, removeSpawnArea,
deactivateSpawnArea, deactivateSpawnArea,
activateMapObjectGroup, activateMapObjectGroup,
deactivateMapObjectGroup, deactivateMapObjectGroup,
changeMapFilter changeMapFilter,
} mapchange
} }
}
public static class Reply {
public static class Reply {
public static final String GO_NEXT_TEXT = "N";
public static final String SHOP_PHRASE_ID = "S"; public static final String GO_NEXT_TEXT = "N";
public static final String FIGHT_PHRASE_ID = "F"; public static final String SHOP_PHRASE_ID = "S";
public static final String EXIT_PHRASE_ID = "X"; public static final String FIGHT_PHRASE_ID = "F";
public static final String REMOVE_PHRASE_ID = "R"; public static final String EXIT_PHRASE_ID = "X";
public static final String REMOVE_PHRASE_ID = "R";
public static final List<String> KEY_PHRASE_ID = Arrays.asList(new String[]{SHOP_PHRASE_ID, FIGHT_PHRASE_ID, EXIT_PHRASE_ID, REMOVE_PHRASE_ID});
public static final List<String> KEY_PHRASE_ID = Arrays.asList(new String[]{SHOP_PHRASE_ID, FIGHT_PHRASE_ID, EXIT_PHRASE_ID, REMOVE_PHRASE_ID});
//Available from parsed state
public String text = null; //Available from parsed state
public String next_phrase_id = null; public String text = null;
public List<Requirement> requirements = null; public String next_phrase_id = null;
public List<Requirement> requirements = null;
//Available from linked state
public Dialogue next_phrase = null; //Available from linked state
public Dialogue next_phrase = null;
}
}
@Override
public String getDesc() { @Override
return (needsSaving() ? "*" : "")+id; public String getDesc() {
} return (needsSaving() ? "*" : "")+id;
}
public static String getStaticDesc() {
return "Dialogues"; public static String getStaticDesc() {
} return "Dialogues";
}
@SuppressWarnings("rawtypes")
public static void fromJson(File jsonFile, GameDataCategory<Dialogue> category) { @SuppressWarnings("rawtypes")
JSONParser parser = new JSONParser(); public static void fromJson(File jsonFile, GameDataCategory<Dialogue> category) {
FileReader reader = null; JSONParser parser = new JSONParser();
try { FileReader reader = null;
reader = new FileReader(jsonFile); try {
List dialogues = (List) parser.parse(reader); reader = new FileReader(jsonFile);
for (Object obj : dialogues) { List dialogues = (List) parser.parse(reader);
Map dialogueJson = (Map)obj; for (Object obj : dialogues) {
Dialogue dialogue = fromJson(dialogueJson); Map dialogueJson = (Map)obj;
dialogue.jsonFile = jsonFile; Dialogue dialogue = fromJson(dialogueJson);
dialogue.parent = category; dialogue.jsonFile = jsonFile;
if (dialogue.getDataType() == GameSource.Type.created || dialogue.getDataType() == GameSource.Type.altered) { dialogue.parent = category;
dialogue.writable = true; if (dialogue.getDataType() == GameSource.Type.created || dialogue.getDataType() == GameSource.Type.altered) {
} dialogue.writable = true;
category.add(dialogue); }
} category.add(dialogue);
} catch (FileNotFoundException e) { }
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); } catch (FileNotFoundException e) {
e.printStackTrace(); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
} catch (IOException e) { e.printStackTrace();
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); } catch (IOException e) {
e.printStackTrace(); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
} catch (ParseException e) { e.printStackTrace();
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); } catch (ParseException e) {
e.printStackTrace(); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
} finally { e.printStackTrace();
if (reader != null) } finally {
try { if (reader != null)
reader.close(); try {
} catch (IOException e) { reader.close();
e.printStackTrace(); } catch (IOException e) {
} e.printStackTrace();
} }
} }
}
@SuppressWarnings("rawtypes")
public static Dialogue fromJson(String jsonString) throws ParseException { @SuppressWarnings("rawtypes")
Map dialogueJson = (Map) new JSONParser().parse(jsonString); public static Dialogue fromJson(String jsonString) throws ParseException {
Dialogue dialogue = fromJson(dialogueJson); Map dialogueJson = (Map) new JSONParser().parse(jsonString);
dialogue.parse(dialogueJson); Dialogue dialogue = fromJson(dialogueJson);
return dialogue; dialogue.parse(dialogueJson);
} return dialogue;
}
@SuppressWarnings("rawtypes")
public static Dialogue fromJson(Map dialogueJson) { @SuppressWarnings("rawtypes")
Dialogue dialogue = new Dialogue(); public static Dialogue fromJson(Map dialogueJson) {
dialogue.id = (String) dialogueJson.get("id"); Dialogue dialogue = new Dialogue();
dialogue.message = (String) dialogueJson.get("message"); dialogue.id = (String) dialogueJson.get("id");
return dialogue; dialogue.message = (String) dialogueJson.get("message");
} return dialogue;
}
@SuppressWarnings("rawtypes")
@Override @SuppressWarnings("rawtypes")
public void parse(Map dialogueJson) { @Override
this.switch_to_npc_id = (String) dialogueJson.get("switchToNPC"); public void parse(Map dialogueJson) {
List repliesJson = (List) dialogueJson.get("replies"); this.switch_to_npc_id = (String) dialogueJson.get("switchToNPC");
if (repliesJson != null && !repliesJson.isEmpty()) { List repliesJson = (List) dialogueJson.get("replies");
this.replies = new ArrayList<Dialogue.Reply>(); if (repliesJson != null && !repliesJson.isEmpty()) {
for (Object replyJsonObj : repliesJson) { this.replies = new ArrayList<Dialogue.Reply>();
Map replyJson = (Map)replyJsonObj; for (Object replyJsonObj : repliesJson) {
Reply reply = new Reply(); Map replyJson = (Map)replyJsonObj;
reply.text = (String) replyJson.get("text"); Reply reply = new Reply();
reply.next_phrase_id = (String) replyJson.get("nextPhraseID"); reply.text = (String) replyJson.get("text");
List requirementsJson = (List) replyJson.get("requires"); reply.next_phrase_id = (String) replyJson.get("nextPhraseID");
if (requirementsJson != null && !requirementsJson.isEmpty()) { List requirementsJson = (List) replyJson.get("requires");
reply.requirements = new ArrayList<Requirement>(); if (requirementsJson != null && !requirementsJson.isEmpty()) {
for (Object requirementJsonObj : requirementsJson) { reply.requirements = new ArrayList<Requirement>();
Map requirementJson = (Map) requirementJsonObj; for (Object requirementJsonObj : requirementsJson) {
Requirement requirement = new Requirement(); Map requirementJson = (Map) requirementJsonObj;
requirement.jsonFile = this.jsonFile; Requirement requirement = new Requirement();
requirement.parent = this; requirement.jsonFile = this.jsonFile;
if (requirementJson.get("requireType") != null) requirement.type = RequirementType.valueOf((String) requirementJson.get("requireType")); requirement.parent = this;
requirement.required_obj_id = (String) requirementJson.get("requireID"); if (requirementJson.get("requireType") != null) requirement.type = RequirementType.valueOf((String) requirementJson.get("requireType"));
if (requirementJson.get("value") != null) requirement.required_value = JSONElement.getInteger(Integer.parseInt(requirementJson.get("value").toString())); requirement.required_obj_id = (String) requirementJson.get("requireID");
if (requirementJson.get("negate") != null) requirement.negated = (Boolean) requirementJson.get("negate"); if (requirementJson.get("value") != null) requirement.required_value = JSONElement.getInteger(Integer.parseInt(requirementJson.get("value").toString()));
requirement.state = State.parsed; if (requirementJson.get("negate") != null) requirement.negated = (Boolean) requirementJson.get("negate");
reply.requirements.add(requirement); requirement.state = State.parsed;
} reply.requirements.add(requirement);
} }
this.replies.add(reply); }
} this.replies.add(reply);
} }
List rewardsJson = (List) dialogueJson.get("rewards"); }
if (rewardsJson != null && !rewardsJson.isEmpty()) { List rewardsJson = (List) dialogueJson.get("rewards");
this.rewards = new ArrayList<Dialogue.Reward>(); if (rewardsJson != null && !rewardsJson.isEmpty()) {
for (Object rewardJsonObj : rewardsJson) { this.rewards = new ArrayList<Dialogue.Reward>();
Map rewardJson = (Map)rewardJsonObj; for (Object rewardJsonObj : rewardsJson) {
Reward reward = new Reward(); Map rewardJson = (Map)rewardJsonObj;
if (rewardJson.get("rewardType") != null) reward.type = Reward.RewardType.valueOf((String) rewardJson.get("rewardType")); Reward reward = new Reward();
if (rewardJson.get("rewardID") != null) reward.reward_obj_id = (String) rewardJson.get("rewardID"); if (rewardJson.get("rewardType") != null) reward.type = Reward.RewardType.valueOf((String) rewardJson.get("rewardType"));
if (rewardJson.get("value") != null) reward.reward_value = JSONElement.getInteger((Number) rewardJson.get("value")); if (rewardJson.get("rewardID") != null) reward.reward_obj_id = (String) rewardJson.get("rewardID");
if (rewardJson.get("mapName") != null) reward.map_name = (String) rewardJson.get("mapName"); if (rewardJson.get("value") != null) reward.reward_value = JSONElement.getInteger((Number) rewardJson.get("value"));
this.rewards.add(reward); if (rewardJson.get("mapName") != null) reward.map_name = (String) rewardJson.get("mapName");
} this.rewards.add(reward);
} }
this.state = State.parsed; }
} this.state = State.parsed;
}
@Override
public void link() { @Override
if (this.state == State.created || this.state == State.modified || this.state == State.saved) { public void link() {
//This type of state is unrelated to parsing/linking. if (shouldSkipParseOrLink()) {
return; return;
} }
if (this.state == State.init) { ensureParseIfNeeded();
//Not parsed yet. Project proj = getProject();
this.parse(); if (proj == null) {
} else if (this.state == State.linked) { Notification.addError("Error linking dialogue "+id+". No parent project found.");
//Already linked. return;
return; }
} if (this.switch_to_npc_id != null) this.switch_to_npc = proj.getNPC(this.switch_to_npc_id);
Project proj = getProject(); if (this.switch_to_npc != null) this.switch_to_npc.addBacklink(this);
if (proj == null) {
Notification.addError("Error linking dialogue "+id+". No parent project found."); if (replies != null) {
return; for (Reply reply : replies) {
} if (reply.next_phrase_id != null) {
if (this.switch_to_npc_id != null) this.switch_to_npc = proj.getNPC(this.switch_to_npc_id); if (!Reply.KEY_PHRASE_ID.contains(reply.next_phrase_id)) {
if (this.switch_to_npc != null) this.switch_to_npc.addBacklink(this); reply.next_phrase = proj.getDialogue(reply.next_phrase_id);
}
if (replies != null) { }
for (Reply reply : replies) { if (reply.next_phrase != null) reply.next_phrase.addBacklink(this);
if (reply.next_phrase_id != null) { if (reply.requirements != null) {
if (!Reply.KEY_PHRASE_ID.contains(reply.next_phrase_id)) { for (Requirement requirement : reply.requirements) {
reply.next_phrase = proj.getDialogue(reply.next_phrase_id); requirement.link();
} }
} }
if (reply.next_phrase != null) reply.next_phrase.addBacklink(this); }
if (reply.requirements != null) { }
for (Requirement requirement : reply.requirements) { if (rewards != null) {
requirement.link(); for (Reward reward : rewards) {
} if (reward.reward_obj_id != null) {
} switch (reward.type) {
} case activateMapObjectGroup:
} case deactivateMapObjectGroup:
if (rewards != null) { case spawnAll:
for (Reward reward : rewards) { case removeSpawnArea:
if (reward.reward_obj_id != null) { case deactivateSpawnArea:
switch (reward.type) { case changeMapFilter:
case activateMapObjectGroup: case mapchange:
case deactivateMapObjectGroup: reward.map = reward.map_name != null ? proj.getMap(reward.map_name) : null;
case spawnAll: break;
case removeSpawnArea: case actorCondition:
case deactivateSpawnArea: case actorConditionImmunity:
case changeMapFilter: reward.reward_obj = proj.getActorCondition(reward.reward_obj_id);
reward.map = reward.map_name != null ? proj.getMap(reward.map_name) : null; break;
break; case alignmentChange:
case actorCondition: case alignmentSet:
case actorConditionImmunity: //Nothing to do (yet ?).
reward.reward_obj = proj.getActorCondition(reward.reward_obj_id); break;
break; case createTimer:
case alignmentChange: //Nothing to do.
case alignmentSet: break;
//Nothing to do (yet ?). case dropList:
break; reward.reward_obj = proj.getDroplist(reward.reward_obj_id);
case createTimer: break;
//Nothing to do. case giveItem:
break; reward.reward_obj = proj.getItem(reward.reward_obj_id);
case dropList: break;
reward.reward_obj = proj.getDroplist(reward.reward_obj_id); case questProgress:
break; case removeQuestProgress:
case giveItem: reward.reward_obj = proj.getQuest(reward.reward_obj_id);
reward.reward_obj = proj.getItem(reward.reward_obj_id); if (reward.reward_obj != null && reward.reward_value != null) {
break; QuestStage stage = ((Quest)reward.reward_obj).getStage(reward.reward_value);
case questProgress: if (stage != null) {
case removeQuestProgress: stage.addBacklink(this);
reward.reward_obj = proj.getQuest(reward.reward_obj_id); }
if (reward.reward_obj != null && reward.reward_value != null) { }
QuestStage stage = ((Quest)reward.reward_obj).getStage(reward.reward_value); break;
if (stage != null) { case skillIncrease:
stage.addBacklink(this); //Nothing to do (yet ?).
} break;
} }
break; if (reward.reward_obj != null) reward.reward_obj.addBacklink(this);
case skillIncrease: if (reward.map != null) reward.map.addBacklink(this);
//Nothing to do (yet ?). }
break; }
} }
if (reward.reward_obj != null) reward.reward_obj.addBacklink(this);
if (reward.map != null) reward.map.addBacklink(this); this.state = State.linked;
} }
}
}
this.state = State.linked; @Override
} public Image getIcon() {
return DefaultIcons.getDialogueIcon();
}
@Override
public Image getIcon() { public Image getImage() {
return DefaultIcons.getDialogueIcon(); return DefaultIcons.getDialogueImage();
} }
@Override
public Image getImage() { public GameDataElement clone() {
return DefaultIcons.getDialogueImage(); Dialogue clone = new Dialogue();
} clone.jsonFile = this.jsonFile;
clone.state = this.state;
@Override clone.id = this.id;
public GameDataElement clone() { clone.message = this.message;
Dialogue clone = new Dialogue(); clone.switch_to_npc_id = this.switch_to_npc_id;
clone.jsonFile = this.jsonFile; clone.switch_to_npc = this.switch_to_npc;
clone.state = this.state; if (clone.switch_to_npc != null) {
clone.id = this.id; clone.switch_to_npc.addBacklink(clone);
clone.message = this.message; }
clone.switch_to_npc_id = this.switch_to_npc_id; if (this.rewards != null) {
clone.switch_to_npc = this.switch_to_npc; clone.rewards = new ArrayList<Dialogue.Reward>();
if (clone.switch_to_npc != null) { for (Reward r : this.rewards) {
clone.switch_to_npc.addBacklink(clone); Reward rclone = new Reward();
} rclone.type = r.type;
if (this.rewards != null) { rclone.reward_obj_id = r.reward_obj_id;
clone.rewards = new ArrayList<Dialogue.Reward>(); rclone.reward_value = r.reward_value;
for (Reward r : this.rewards) { rclone.reward_obj = r.reward_obj;
Reward rclone = new Reward(); if (rclone.reward_obj != null) {
rclone.type = r.type; rclone.reward_obj.addBacklink(clone);
rclone.reward_obj_id = r.reward_obj_id; }
rclone.reward_value = r.reward_value; rclone.map = r.map;
rclone.reward_obj = r.reward_obj; rclone.map_name = r.map_name;
if (rclone.reward_obj != null) { if (rclone.map != null) {
rclone.reward_obj.addBacklink(clone); rclone.map.addBacklink(clone);
} }
rclone.map = r.map; clone.rewards.add(rclone);
rclone.map_name = r.map_name; }
if (rclone.map != null) { }
rclone.map.addBacklink(clone); if (this.replies != null) {
} clone.replies = new ArrayList<Dialogue.Reply>();
clone.rewards.add(rclone); for (Reply r : this.replies) {
} Reply rclone = new Reply();
} rclone.text = r.text;
if (this.replies != null) { rclone.next_phrase_id = r.next_phrase_id;
clone.replies = new ArrayList<Dialogue.Reply>(); rclone.next_phrase = r.next_phrase;
for (Reply r : this.replies) { if (rclone.next_phrase != null) {
Reply rclone = new Reply(); rclone.next_phrase.addBacklink(clone);
rclone.text = r.text; }
rclone.next_phrase_id = r.next_phrase_id; if (r.requirements != null) {
rclone.next_phrase = r.next_phrase; rclone.requirements = new ArrayList<Requirement>();
if (rclone.next_phrase != null) { for (Requirement req : r.requirements) {
rclone.next_phrase.addBacklink(clone); //Special clone method, as Requirement is a special GDE, hidden from the project tree.
} rclone.requirements.add((Requirement) req.clone(clone));
if (r.requirements != null) { }
rclone.requirements = new ArrayList<Requirement>(); }
for (Requirement req : r.requirements) { clone.replies.add(rclone);
//Special clone method, as Requirement is a special GDE, hidden from the project tree. }
rclone.requirements.add((Requirement) req.clone(clone)); }
} return clone;
} }
clone.replies.add(rclone);
} @Override
} public void elementChanged(GameDataElement oldOne, GameDataElement newOne) {
return clone; if (switch_to_npc == oldOne) {
} oldOne.removeBacklink(this);
switch_to_npc = (NPC) newOne;
@Override if (newOne != null) newOne.addBacklink(this);
public void elementChanged(GameDataElement oldOne, GameDataElement newOne) { } else {
if (switch_to_npc == oldOne) { if (replies != null) {
oldOne.removeBacklink(this); for (Reply r : replies) {
switch_to_npc = (NPC) newOne; if (r.next_phrase == oldOne) {
if (newOne != null) newOne.addBacklink(this); oldOne.removeBacklink(this);
} else { r.next_phrase = (Dialogue) newOne;
if (replies != null) { if (newOne != null) newOne.addBacklink(this);
for (Reply r : replies) { }
if (r.next_phrase == oldOne) { if (r.requirements != null) {
oldOne.removeBacklink(this); for (Requirement req : r.requirements) {
r.next_phrase = (Dialogue) newOne; req.elementChanged(oldOne, newOne);
if (newOne != null) newOne.addBacklink(this); }
} }
if (r.requirements != null) { }
for (Requirement req : r.requirements) { }
req.elementChanged(oldOne, newOne); if (rewards != null) {
} for (Reward r : rewards) {
} if (r.reward_obj == oldOne) {
} oldOne.removeBacklink(this);
} r.reward_obj = newOne;
if (rewards != null) { if (newOne != null) newOne.addBacklink(this);
for (Reward r : rewards) { }
if (r.reward_obj == oldOne) { if (oldOne instanceof QuestStage) {
oldOne.removeBacklink(this); if (r.reward_obj != null && r.reward_obj.equals(oldOne.parent) && r.reward_value != null && r.reward_value.equals(((QuestStage) oldOne).progress)) {
r.reward_obj = newOne; oldOne.removeBacklink((GameDataElement) this);
if (newOne != null) newOne.addBacklink(this); if (newOne != null) newOne.addBacklink((GameDataElement) this);
} }
if (oldOne instanceof QuestStage) { }
if (r.reward_obj != null && r.reward_obj.equals(oldOne.parent) && r.reward_value != null && r.reward_value.equals(((QuestStage) oldOne).progress)) { }
oldOne.removeBacklink((GameDataElement) this); }
if (newOne != null) newOne.addBacklink((GameDataElement) this); }
} }
}
} @SuppressWarnings({ "rawtypes", "unchecked" })
} @Override
} public Map toJson() {
} Map dialogueJson = new LinkedHashMap();
dialogueJson.put("id", this.id);
@SuppressWarnings({ "rawtypes", "unchecked" }) if (this.message != null) dialogueJson.put("message", this.message);
@Override if (this.switch_to_npc != null) {
public Map toJson() { dialogueJson.put("switchToNPC", this.switch_to_npc.id);
Map dialogueJson = new LinkedHashMap(); } else if (this.switch_to_npc_id != null) {
dialogueJson.put("id", this.id); dialogueJson.put("switchToNPC", this.switch_to_npc_id);
if (this.message != null) dialogueJson.put("message", this.message); }
if (this.switch_to_npc != null) { if (this.replies != null) {
dialogueJson.put("switchToNPC", this.switch_to_npc.id); List repliesJson = new ArrayList();
} else if (this.switch_to_npc_id != null) { dialogueJson.put("replies", repliesJson);
dialogueJson.put("switchToNPC", this.switch_to_npc_id); for (Reply reply : this.replies){
} Map replyJson = new LinkedHashMap();
if (this.replies != null) { repliesJson.add(replyJson);
List repliesJson = new ArrayList(); if (reply.text != null) replyJson.put("text", reply.text);
dialogueJson.put("replies", repliesJson); if (reply.next_phrase != null) {
for (Reply reply : this.replies){ replyJson.put("nextPhraseID", reply.next_phrase.id);
Map replyJson = new LinkedHashMap(); } else if (reply.next_phrase_id != null) {
repliesJson.add(replyJson); replyJson.put("nextPhraseID", reply.next_phrase_id);
if (reply.text != null) replyJson.put("text", reply.text); }
if (reply.next_phrase != null) { if (reply.requirements != null) {
replyJson.put("nextPhraseID", reply.next_phrase.id); List requirementsJson = new ArrayList();
} else if (reply.next_phrase_id != null) { replyJson.put("requires", requirementsJson);
replyJson.put("nextPhraseID", reply.next_phrase_id); for (Requirement requirement : reply.requirements) {
} Map requirementJson = new LinkedHashMap();
if (reply.requirements != null) { requirementsJson.add(requirementJson);
List requirementsJson = new ArrayList(); if (requirement.type != null) requirementJson.put("requireType", requirement.type.toString());
replyJson.put("requires", requirementsJson); if (requirement.required_obj != null) {
for (Requirement requirement : reply.requirements) { requirementJson.put("requireID", requirement.required_obj.id);
Map requirementJson = new LinkedHashMap(); } else if (requirement.required_obj_id != null) {
requirementsJson.add(requirementJson); requirementJson.put("requireID", requirement.required_obj_id);
if (requirement.type != null) requirementJson.put("requireType", requirement.type.toString()); }
if (requirement.required_obj != null) { if (requirement.required_value != null) {
requirementJson.put("requireID", requirement.required_obj.id); requirementJson.put("value", requirement.required_value);
} else if (requirement.required_obj_id != null) { }
requirementJson.put("requireID", requirement.required_obj_id); if (requirement.negated != null) requirementJson.put("negate", requirement.negated);
} }
if (requirement.required_value != null) { }
requirementJson.put("value", requirement.required_value); }
} }
if (requirement.negated != null) requirementJson.put("negate", requirement.negated); if (this.rewards != null) {
} List rewardsJson = new ArrayList();
} dialogueJson.put("rewards", rewardsJson);
} for (Reward reward : this.rewards) {
} Map rewardJson = new LinkedHashMap();
if (this.rewards != null) { rewardsJson.add(rewardJson);
List rewardsJson = new ArrayList(); if (reward.type != null) rewardJson.put("rewardType", reward.type.toString());
dialogueJson.put("rewards", rewardsJson); if (reward.reward_obj != null) {
for (Reward reward : this.rewards) { rewardJson.put("rewardID", reward.reward_obj.id);
Map rewardJson = new LinkedHashMap(); } else if (reward.reward_obj_id != null) {
rewardsJson.add(rewardJson); rewardJson.put("rewardID", reward.reward_obj_id);
if (reward.type != null) rewardJson.put("rewardType", reward.type.toString()); }
if (reward.reward_obj != null) { if (reward.reward_value != null) rewardJson.put("value", reward.reward_value);
rewardJson.put("rewardID", reward.reward_obj.id); if (reward.map != null) {
} else if (reward.reward_obj_id != null) { rewardJson.put("mapName", reward.map.id);
rewardJson.put("rewardID", reward.reward_obj_id); } else if (reward.map_name != null) rewardJson.put("mapName", reward.map_name);
} }
if (reward.reward_value != null) rewardJson.put("value", reward.reward_value); }
if (reward.map != null) { return dialogueJson;
rewardJson.put("mapName", reward.map.id); }
} else if (reward.map_name != null) rewardJson.put("mapName", reward.map_name);
} @Override
} public String getProjectFilename() {
return dialogueJson; return "conversationlist_"+getProject().name+".json";
} }
@Override }
public String getProjectFilename() {
return "conversationlist_"+getProject().name+".json";
}
}

View File

@@ -1,240 +1,235 @@
package com.gpl.rpg.atcontentstudio.model.gamedata; package com.gpl.rpg.atcontentstudio.model.gamedata;
import java.awt.Image; import java.awt.Image;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.FileReader; import java.io.FileReader;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.json.simple.parser.JSONParser; import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException; import org.json.simple.parser.ParseException;
import com.gpl.rpg.atcontentstudio.Notification; import com.gpl.rpg.atcontentstudio.Notification;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.GameSource; import com.gpl.rpg.atcontentstudio.model.GameSource;
import com.gpl.rpg.atcontentstudio.model.Project; import com.gpl.rpg.atcontentstudio.model.Project;
import com.gpl.rpg.atcontentstudio.ui.DefaultIcons; import com.gpl.rpg.atcontentstudio.ui.DefaultIcons;
public class Droplist extends JSONElement { public class Droplist extends JSONElement {
private static final long serialVersionUID = -2903944916807382571L; private static final long serialVersionUID = -2903944916807382571L;
//Available from init state //Available from init state
//public String id = null; inherited. //public String id = null; inherited.
//Available from parsed state; //Available from parsed state;
public List<DroppedItem> dropped_items = null; public List<DroppedItem> dropped_items = null;
//Available from linked state; //Available from linked state;
//None //None
public static class DroppedItem { public static class DroppedItem {
//Available from parsed state; //Available from parsed state;
public String item_id = null; public String item_id = null;
public Double chance = null; public String chance = null;
public Integer quantity_min = null; public Integer quantity_min = null;
public Integer quantity_max = null; public Integer quantity_max = null;
//Available from linked state; //Available from linked state;
public Item item = null; public Item item = null;
} }
@Override @Override
public String getDesc() { public String getDesc() {
return (needsSaving() ? "*" : "")+id; return (needsSaving() ? "*" : "")+id;
} }
public static String getStaticDesc() { public static String getStaticDesc() {
return "Droplists"; return "Droplists";
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static void fromJson(File jsonFile, GameDataCategory<Droplist> category) { public static void fromJson(File jsonFile, GameDataCategory<Droplist> category) {
JSONParser parser = new JSONParser(); JSONParser parser = new JSONParser();
FileReader reader = null; FileReader reader = null;
try { try {
reader = new FileReader(jsonFile); reader = new FileReader(jsonFile);
List droplists = (List) parser.parse(reader); List droplists = (List) parser.parse(reader);
for (Object obj : droplists) { for (Object obj : droplists) {
Map droplistJson = (Map)obj; Map droplistJson = (Map)obj;
Droplist droplist = fromJson(droplistJson); Droplist droplist = fromJson(droplistJson);
droplist.jsonFile = jsonFile; droplist.jsonFile = jsonFile;
droplist.parent = category; droplist.parent = category;
if (droplist.getDataType() == GameSource.Type.created || droplist.getDataType() == GameSource.Type.altered) { if (droplist.getDataType() == GameSource.Type.created || droplist.getDataType() == GameSource.Type.altered) {
droplist.writable = true; droplist.writable = true;
} }
category.add(droplist); category.add(droplist);
} }
} catch (FileNotFoundException e) { } catch (FileNotFoundException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} catch (IOException e) { } catch (IOException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} catch (ParseException e) { } catch (ParseException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} finally { } finally {
if (reader != null) if (reader != null)
try { try {
reader.close(); reader.close();
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
} }
} }
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static Droplist fromJson(String jsonString) throws ParseException { public static Droplist fromJson(String jsonString) throws ParseException {
Map droplistJson = (Map) new JSONParser().parse(jsonString); Map droplistJson = (Map) new JSONParser().parse(jsonString);
Droplist droplist = fromJson(droplistJson); Droplist droplist = fromJson(droplistJson);
droplist.parse(droplistJson); droplist.parse(droplistJson);
return droplist; return droplist;
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static Droplist fromJson(Map droplistJson) { public static Droplist fromJson(Map droplistJson) {
Droplist droplist = new Droplist(); Droplist droplist = new Droplist();
droplist.id = (String) droplistJson.get("id"); droplist.id = (String) droplistJson.get("id");
return droplist; return droplist;
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
@Override @Override
public void parse(Map droplistJson) { public void parse(Map droplistJson) {
List droppedItemsJson = (List) droplistJson.get("items"); List droppedItemsJson = (List) droplistJson.get("items");
if (droppedItemsJson != null && !droppedItemsJson.isEmpty()) { if (droppedItemsJson != null && !droppedItemsJson.isEmpty()) {
this.dropped_items = new ArrayList<DroppedItem>(); this.dropped_items = new ArrayList<DroppedItem>();
for (Object droppedItemJsonObj : droppedItemsJson) { for (Object droppedItemJsonObj : droppedItemsJson) {
Map droppedItemJson = (Map)droppedItemJsonObj; Map droppedItemJson = (Map)droppedItemJsonObj;
DroppedItem droppedItem = new DroppedItem(); DroppedItem droppedItem = new DroppedItem();
droppedItem.item_id = (String) droppedItemJson.get("itemID"); droppedItem.item_id = (String) droppedItemJson.get("itemID");
if (droppedItemJson.get("chance") != null) droppedItem.chance = JSONElement.parseChance(droppedItemJson.get("chance").toString()); //if (droppedItemJson.get("chance") != null) droppedItem.chance = JSONElement.parseChance(droppedItemJson.get("chance").toString());
Map droppedItemQtyJson = (Map) droppedItemJson.get("quantity"); droppedItem.chance = (String) droppedItemJson.get("chance");
if (droppedItemQtyJson != null) { Map droppedItemQtyJson = (Map) droppedItemJson.get("quantity");
droppedItem.quantity_min = JSONElement.getInteger((Number) droppedItemQtyJson.get("min")); if (droppedItemQtyJson != null) {
droppedItem.quantity_max = JSONElement.getInteger((Number) droppedItemQtyJson.get("max")); droppedItem.quantity_min = JSONElement.getInteger((Number) droppedItemQtyJson.get("min"));
} droppedItem.quantity_max = JSONElement.getInteger((Number) droppedItemQtyJson.get("max"));
this.dropped_items.add(droppedItem); }
} this.dropped_items.add(droppedItem);
} }
this.state = State.parsed; }
} this.state = State.parsed;
}
@Override
public void link() { @Override
if (this.state == State.created || this.state == State.modified || this.state == State.saved) { public void link() {
//This type of state is unrelated to parsing/linking. if (shouldSkipParseOrLink()) {
return; return;
} }
if (this.state == State.init) { ensureParseIfNeeded();
//Not parsed yet. Project proj = getProject();
this.parse(); if (proj == null) {
} else if (this.state == State.linked) { Notification.addError("Error linking droplist "+id+". No parent project found.");
//Already linked. return;
return; }
} if (dropped_items != null) {
Project proj = getProject(); for (DroppedItem droppedItem : dropped_items) {
if (proj == null) { if (droppedItem.item_id != null) droppedItem.item = proj.getItem(droppedItem.item_id);
Notification.addError("Error linking droplist "+id+". No parent project found."); if (droppedItem.item != null) droppedItem.item.addBacklink(this);
return; }
} }
if (dropped_items != null) { this.state = State.linked;
for (DroppedItem droppedItem : dropped_items) { }
if (droppedItem.item_id != null) droppedItem.item = proj.getItem(droppedItem.item_id);
if (droppedItem.item != null) droppedItem.item.addBacklink(this);
}
} public static Image getImage() {
this.state = State.linked; return DefaultIcons.getDroplistImage();
} }
@Override
public Image getIcon() {
public static Image getImage() { return DefaultIcons.getDroplistIcon();
return DefaultIcons.getDroplistImage(); }
}
@Override
@Override public GameDataElement clone() {
public Image getIcon() { Droplist clone = new Droplist();
return DefaultIcons.getDroplistIcon(); clone.jsonFile = this.jsonFile;
} clone.state = this.state;
clone.id = this.id;
@Override if (this.dropped_items != null) {
public GameDataElement clone() { clone.dropped_items = new ArrayList<Droplist.DroppedItem>();
Droplist clone = new Droplist(); for (DroppedItem di : this.dropped_items) {
clone.jsonFile = this.jsonFile; DroppedItem diclone = new DroppedItem();
clone.state = this.state; diclone.chance = di.chance;
clone.id = this.id; diclone.item_id = di.item_id;
if (this.dropped_items != null) { diclone.quantity_min = di.quantity_min;
clone.dropped_items = new ArrayList<Droplist.DroppedItem>(); diclone.quantity_max = di.quantity_max;
for (DroppedItem di : this.dropped_items) { diclone.item = di.item;
DroppedItem diclone = new DroppedItem(); if (diclone.item != null) {
diclone.chance = di.chance; diclone.item.addBacklink(clone);
diclone.item_id = di.item_id; }
diclone.quantity_min = di.quantity_min; clone.dropped_items.add(diclone);
diclone.quantity_max = di.quantity_max; }
diclone.item = di.item; }
if (diclone.item != null) { return clone;
diclone.item.addBacklink(clone); }
}
clone.dropped_items.add(diclone); @Override
} public void elementChanged(GameDataElement oldOne, GameDataElement newOne) {
} if (dropped_items != null) {
return clone; for (DroppedItem di : dropped_items) {
} if (di.item == oldOne) {
oldOne.removeBacklink(this);
@Override di.item = (Item) newOne;
public void elementChanged(GameDataElement oldOne, GameDataElement newOne) { if (newOne != null) newOne.addBacklink(this);
if (dropped_items != null) { }
for (DroppedItem di : dropped_items) { }
if (di.item == oldOne) { }
oldOne.removeBacklink(this); }
di.item = (Item) newOne;
if (newOne != null) newOne.addBacklink(this); @SuppressWarnings({ "rawtypes", "unchecked" })
} @Override
} public Map toJson() {
} Map droplistJson = new LinkedHashMap();
} droplistJson.put("id", this.id);
if (this.dropped_items != null) {
@SuppressWarnings({ "rawtypes", "unchecked" }) List droppedItemsJson = new ArrayList();
@Override droplistJson.put("items", droppedItemsJson);
public Map toJson() { for (DroppedItem droppedItem : this.dropped_items) {
Map droplistJson = new LinkedHashMap(); Map droppedItemJson = new LinkedHashMap();
droplistJson.put("id", this.id); droppedItemsJson.add(droppedItemJson);
if (this.dropped_items != null) { if (droppedItem.item != null) {
List droppedItemsJson = new ArrayList(); droppedItemJson.put("itemID", droppedItem.item.id);
droplistJson.put("items", droppedItemsJson); } else if (droppedItem.item_id != null) {
for (DroppedItem droppedItem : this.dropped_items) { droppedItemJson.put("itemID", droppedItem.item_id);
Map droppedItemJson = new LinkedHashMap(); }
droppedItemsJson.add(droppedItemJson); //if (droppedItem.chance != null) droppedItemJson.put("chance", JSONElement.printJsonChance(droppedItem.chance));
if (droppedItem.item != null) { if (droppedItem.chance != null) droppedItemJson.put("chance", droppedItem.chance);
droppedItemJson.put("itemID", droppedItem.item.id); if (droppedItem.quantity_min != null || droppedItem.quantity_max != null) {
} else if (droppedItem.item_id != null) { Map quantityJson = new LinkedHashMap();
droppedItemJson.put("itemID", droppedItem.item_id); droppedItemJson.put("quantity", quantityJson);
} if (droppedItem.quantity_min != null) quantityJson.put("min", droppedItem.quantity_min);
if (droppedItem.chance != null) droppedItemJson.put("chance", JSONElement.printJsonChance(droppedItem.chance)); else quantityJson.put("min", 0);
if (droppedItem.quantity_min != null || droppedItem.quantity_max != null) { if (droppedItem.quantity_max != null) quantityJson.put("max", droppedItem.quantity_max);
Map quantityJson = new LinkedHashMap(); else quantityJson.put("max", 0);
droppedItemJson.put("quantity", quantityJson); }
if (droppedItem.quantity_min != null) quantityJson.put("min", droppedItem.quantity_min); }
else quantityJson.put("min", 0); }
if (droppedItem.quantity_max != null) quantityJson.put("max", droppedItem.quantity_max); return droplistJson;
else quantityJson.put("max", 0); }
}
}
} @Override
return droplistJson; public String getProjectFilename() {
} return "droplists_"+getProject().name+".json";
}
@Override }
public String getProjectFilename() {
return "droplists_"+getProject().name+".json";
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -1,329 +1,322 @@
package com.gpl.rpg.atcontentstudio.model.gamedata; package com.gpl.rpg.atcontentstudio.model.gamedata;
import java.awt.Image; import java.awt.Image;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.FileReader; import java.io.FileReader;
import java.io.IOException; import java.io.IOException;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import javax.imageio.ImageIO; import javax.imageio.ImageIO;
import org.json.simple.parser.JSONParser; import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException; import org.json.simple.parser.ParseException;
import com.gpl.rpg.atcontentstudio.Notification; import com.gpl.rpg.atcontentstudio.Notification;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.GameSource; import com.gpl.rpg.atcontentstudio.model.GameSource;
public class ItemCategory extends JSONElement { public class ItemCategory extends JSONElement {
private static final long serialVersionUID = -348864002519568300L; private static final long serialVersionUID = -348864002519568300L;
public static final String ICON_NO_SLOT_RES = "/com/gpl/rpg/atcontentstudio/img/equip_square.png"; public static final String ICON_NO_SLOT_RES = "/com/gpl/rpg/atcontentstudio/img/equip_square.png";
public static final String ICON_BODY_RES = "/com/gpl/rpg/atcontentstudio/img/equip_body.png"; public static final String ICON_BODY_RES = "/com/gpl/rpg/atcontentstudio/img/equip_body.png";
public static final String ICON_FEET_RES = "/com/gpl/rpg/atcontentstudio/img/equip_feet.png"; public static final String ICON_FEET_RES = "/com/gpl/rpg/atcontentstudio/img/equip_feet.png";
public static final String ICON_HAND_RES = "/com/gpl/rpg/atcontentstudio/img/equip_hand.png"; public static final String ICON_HAND_RES = "/com/gpl/rpg/atcontentstudio/img/equip_hand.png";
public static final String ICON_HEAD_RES = "/com/gpl/rpg/atcontentstudio/img/equip_head.png"; public static final String ICON_HEAD_RES = "/com/gpl/rpg/atcontentstudio/img/equip_head.png";
public static final String ICON_NECK_RES = "/com/gpl/rpg/atcontentstudio/img/equip_neck.png"; public static final String ICON_NECK_RES = "/com/gpl/rpg/atcontentstudio/img/equip_neck.png";
public static final String ICON_RING_RES = "/com/gpl/rpg/atcontentstudio/img/equip_ring.png"; public static final String ICON_RING_RES = "/com/gpl/rpg/atcontentstudio/img/equip_ring.png";
public static final String ICON_SHIELD_RES = "/com/gpl/rpg/atcontentstudio/img/equip_shield.png"; public static final String ICON_SHIELD_RES = "/com/gpl/rpg/atcontentstudio/img/equip_shield.png";
public static final String ICON_WEAPON_RES = "/com/gpl/rpg/atcontentstudio/img/equip_weapon.png"; public static final String ICON_WEAPON_RES = "/com/gpl/rpg/atcontentstudio/img/equip_weapon.png";
public static Image no_slot_image = null; public static Image no_slot_image = null;
public static Image no_slot_icon = null; public static Image no_slot_icon = null;
public static Image body_image = null; public static Image body_image = null;
public static Image body_icon = null; public static Image body_icon = null;
public static Image feet_image = null; public static Image feet_image = null;
public static Image feet_icon = null; public static Image feet_icon = null;
public static Image hand_image = null; public static Image hand_image = null;
public static Image hand_icon = null; public static Image hand_icon = null;
public static Image head_image = null; public static Image head_image = null;
public static Image head_icon = null; public static Image head_icon = null;
public static Image neck_image = null; public static Image neck_image = null;
public static Image neck_icon = null; public static Image neck_icon = null;
public static Image ring_image = null; public static Image ring_image = null;
public static Image ring_icon = null; public static Image ring_icon = null;
public static Image shield_image = null; public static Image shield_image = null;
public static Image shield_icon = null; public static Image shield_icon = null;
public static Image weapon_image = null; public static Image weapon_image = null;
public static Image weapon_icon = null; public static Image weapon_icon = null;
//Available from init state //Available from init state
//public String id = null; inherited. //public String id = null; inherited.
public String name = null; public String name = null;
public InventorySlot slot = null; public InventorySlot slot = null;
//Available from parsed state //Available from parsed state
public ActionType action_type = null; public ActionType action_type = null;
public Size size = null; public Size size = null;
//Available from linked state //Available from linked state
//None //None
public static enum ActionType { public static enum ActionType {
none, none,
use, use,
equip equip
} }
public static enum Size { public static enum Size {
none, none,
light, light,
std, std,
large large
} }
public static enum InventorySlot { public static enum InventorySlot {
weapon, weapon,
shield, shield,
head, head,
body, body,
hand, hand,
feet, feet,
neck, neck,
leftring, leftring,
rightring rightring
} }
@Override @Override
public String getDesc() { public String getDesc() {
return (needsSaving() ? "*" : "")+name+" ("+id+")"; return (needsSaving() ? "*" : "")+name+" ("+id+")";
} }
public static String getStaticDesc() { public static String getStaticDesc() {
return "Item categories"; return "Item categories";
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static void fromJson(File jsonFile, GameDataCategory<ItemCategory> category) { public static void fromJson(File jsonFile, GameDataCategory<ItemCategory> category) {
JSONParser parser = new JSONParser(); JSONParser parser = new JSONParser();
FileReader reader = null; FileReader reader = null;
try { try {
reader = new FileReader(jsonFile); reader = new FileReader(jsonFile);
List itemCategories = (List) parser.parse(reader); List itemCategories = (List) parser.parse(reader);
for (Object obj : itemCategories) { for (Object obj : itemCategories) {
Map itemCatJson = (Map)obj; Map itemCatJson = (Map)obj;
ItemCategory itemCat = fromJson(itemCatJson); ItemCategory itemCat = fromJson(itemCatJson);
itemCat.jsonFile = jsonFile; itemCat.jsonFile = jsonFile;
itemCat.parent = category; itemCat.parent = category;
if (itemCat.getDataType() == GameSource.Type.created || itemCat.getDataType() == GameSource.Type.altered) { if (itemCat.getDataType() == GameSource.Type.created || itemCat.getDataType() == GameSource.Type.altered) {
itemCat.writable = true; itemCat.writable = true;
} }
category.add(itemCat); category.add(itemCat);
} }
} catch (FileNotFoundException e) { } catch (FileNotFoundException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} catch (IOException e) { } catch (IOException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} catch (ParseException e) { } catch (ParseException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} finally { } finally {
if (reader != null) if (reader != null)
try { try {
reader.close(); reader.close();
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
} }
} }
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static ItemCategory fromJson(String jsonString) throws ParseException { public static ItemCategory fromJson(String jsonString) throws ParseException {
Map itemCatJson = (Map) new JSONParser().parse(jsonString); Map itemCatJson = (Map) new JSONParser().parse(jsonString);
ItemCategory item = fromJson(itemCatJson); ItemCategory item = fromJson(itemCatJson);
item.parse(itemCatJson); item.parse(itemCatJson);
return item; return item;
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static ItemCategory fromJson(Map itemCatJson) { public static ItemCategory fromJson(Map itemCatJson) {
ItemCategory itemCat = new ItemCategory(); ItemCategory itemCat = new ItemCategory();
itemCat.id = (String) itemCatJson.get("id"); itemCat.id = (String) itemCatJson.get("id");
itemCat.name = (String) itemCatJson.get("name"); itemCat.name = (String) itemCatJson.get("name");
if (itemCatJson.get("inventorySlot") != null) itemCat.slot = InventorySlot.valueOf((String) itemCatJson.get("inventorySlot")); if (itemCatJson.get("inventorySlot") != null) itemCat.slot = InventorySlot.valueOf((String) itemCatJson.get("inventorySlot"));
return itemCat; return itemCat;
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
@Override @Override
public void parse(Map itemCatJson) { public void parse(Map itemCatJson) {
if (itemCatJson.get("actionType") != null) action_type = ActionType.valueOf((String) itemCatJson.get("actionType")); if (itemCatJson.get("actionType") != null) action_type = ActionType.valueOf((String) itemCatJson.get("actionType"));
if (itemCatJson.get("size") != null) size = Size.valueOf((String) itemCatJson.get("size")); if (itemCatJson.get("size") != null) size = Size.valueOf((String) itemCatJson.get("size"));
this.state = State.parsed; this.state = State.parsed;
} }
@Override @Override
public void link() { public void link() {
if (this.state == State.created || this.state == State.modified || this.state == State.saved) { if (shouldSkipParseOrLink()) {
//This type of state is unrelated to parsing/linking. return;
return; }
} ensureParseIfNeeded();
if (this.state == State.init) {
//Not parsed yet. //Nothing to link to :D
this.parse(); this.state = State.linked;
} else if (this.state == State.linked) { }
//Already linked.
return; @Override
} public Image getIcon() {
return getIcon(this.slot);
//Nothing to link to :D }
this.state = State.linked;
} public Image getImage() {
return getImage(this.slot);
@Override }
public Image getIcon() {
return getIcon(this.slot); public static Image getImage(InventorySlot slot) {
} if (slot == null) {
return getImage(ICON_NO_SLOT_RES, no_slot_image, "no_slot_image");
public Image getImage() { }
return getImage(this.slot); switch (slot) {
} case body:
return getImage(ICON_BODY_RES, body_image, "body_image");
public static Image getImage(InventorySlot slot) { case feet:
if (slot == null) { return getImage(ICON_FEET_RES, feet_image, "feet_image");
return getImage(ICON_NO_SLOT_RES, no_slot_image, "no_slot_image"); case hand:
} return getImage(ICON_HAND_RES, hand_image, "hand_image");
switch (slot) { case head:
case body: return getImage(ICON_HEAD_RES, head_image, "head_image");
return getImage(ICON_BODY_RES, body_image, "body_image"); case leftring:
case feet: case rightring:
return getImage(ICON_FEET_RES, feet_image, "feet_image"); return getImage(ICON_RING_RES, ring_image, "ring_image");
case hand: case neck:
return getImage(ICON_HAND_RES, hand_image, "hand_image"); return getImage(ICON_NECK_RES, neck_image, "neck_image");
case head: case shield:
return getImage(ICON_HEAD_RES, head_image, "head_image"); return getImage(ICON_SHIELD_RES, shield_image, "shield_image");
case leftring: case weapon:
case rightring: return getImage(ICON_WEAPON_RES, weapon_image, "weapon_image");
return getImage(ICON_RING_RES, ring_image, "ring_image"); default:
case neck: return getImage(ICON_NO_SLOT_RES, no_slot_image, "no_slot_image");
return getImage(ICON_NECK_RES, neck_image, "neck_image"); }
case shield: }
return getImage(ICON_SHIELD_RES, shield_image, "shield_image");
case weapon: public static Image getIcon(InventorySlot slot) {
return getImage(ICON_WEAPON_RES, weapon_image, "weapon_image"); if (slot == null) {
default: return getIcon(ICON_NO_SLOT_RES, no_slot_image, no_slot_icon, "no_slot_image", "no_slot_icon");
return getImage(ICON_NO_SLOT_RES, no_slot_image, "no_slot_image"); }
} switch (slot) {
} case body:
return getIcon(ICON_BODY_RES, body_image, body_icon, "body_image", "body_icon");
public static Image getIcon(InventorySlot slot) { case feet:
if (slot == null) { return getIcon(ICON_FEET_RES, feet_image, feet_icon, "feet_image", "feet_icon");
return getIcon(ICON_NO_SLOT_RES, no_slot_image, no_slot_icon, "no_slot_image", "no_slot_icon"); case hand:
} return getIcon(ICON_HAND_RES, hand_image, hand_icon, "hand_image", "hand_icon");
switch (slot) { case head:
case body: return getIcon(ICON_HEAD_RES, head_image, head_icon, "head_image", "head_icon");
return getIcon(ICON_BODY_RES, body_image, body_icon, "body_image", "body_icon"); case leftring:
case feet: case rightring:
return getIcon(ICON_FEET_RES, feet_image, feet_icon, "feet_image", "feet_icon"); return getIcon(ICON_RING_RES, ring_image, ring_icon, "ring_image", "ring_icon");
case hand: case neck:
return getIcon(ICON_HAND_RES, hand_image, hand_icon, "hand_image", "hand_icon"); return getIcon(ICON_NECK_RES, neck_image, neck_icon, "neck_image", "neck_icon");
case head: case shield:
return getIcon(ICON_HEAD_RES, head_image, head_icon, "head_image", "head_icon"); return getIcon(ICON_SHIELD_RES, shield_image, shield_icon, "shield_image", "shield_icon");
case leftring: case weapon:
case rightring: return getIcon(ICON_WEAPON_RES, weapon_image, weapon_icon, "weapon_image", "weapon_icon");
return getIcon(ICON_RING_RES, ring_image, ring_icon, "ring_image", "ring_icon"); default:
case neck: return getIcon(ICON_NO_SLOT_RES, no_slot_image, no_slot_icon, "no_slot_image", "no_slot_icon");
return getIcon(ICON_NECK_RES, neck_image, neck_icon, "neck_image", "neck_icon"); }
case shield: }
return getIcon(ICON_SHIELD_RES, shield_image, shield_icon, "shield_image", "shield_icon");
case weapon: public static Image getImage(String res, Image img, String fieldName) {
return getIcon(ICON_WEAPON_RES, weapon_image, weapon_icon, "weapon_image", "weapon_icon"); if (img == null) {
default: try {
return getIcon(ICON_NO_SLOT_RES, no_slot_image, no_slot_icon, "no_slot_image", "no_slot_icon"); img = ImageIO.read(ItemCategory.class.getResourceAsStream(res));
} ItemCategory.class.getField(fieldName).set(null, img);
} } catch (IllegalArgumentException e) {
e.printStackTrace();
public static Image getImage(String res, Image img, String fieldName) { } catch (SecurityException e) {
if (img == null) { e.printStackTrace();
try { } catch (IllegalAccessException e) {
img = ImageIO.read(ItemCategory.class.getResourceAsStream(res)); e.printStackTrace();
ItemCategory.class.getField(fieldName).set(null, img); } catch (NoSuchFieldException e) {
} catch (IllegalArgumentException e) { e.printStackTrace();
e.printStackTrace(); } catch (IOException e) {
} catch (SecurityException e) { Notification.addError("Failed to load item category icon "+res);
e.printStackTrace(); e.printStackTrace();
} catch (IllegalAccessException e) { }
e.printStackTrace(); }
} catch (NoSuchFieldException e) { return img;
e.printStackTrace(); }
} catch (IOException e) {
Notification.addError("Failed to load item category icon "+res); public static Image getIcon(String res, Image img, Image icon, String imgFieldName, String iconFieldName) {
e.printStackTrace(); if (icon == null) {
} icon = getImage(res, img, imgFieldName).getScaledInstance(16, 16, Image.SCALE_SMOOTH);
} try {
return img; ItemCategory.class.getField(iconFieldName).set(null, icon);
} } catch (IllegalArgumentException e) {
e.printStackTrace();
public static Image getIcon(String res, Image img, Image icon, String imgFieldName, String iconFieldName) { } catch (SecurityException e) {
if (icon == null) { e.printStackTrace();
icon = getImage(res, img, imgFieldName).getScaledInstance(16, 16, Image.SCALE_SMOOTH); } catch (IllegalAccessException e) {
try { e.printStackTrace();
ItemCategory.class.getField(iconFieldName).set(null, icon); } catch (NoSuchFieldException e) {
} catch (IllegalArgumentException e) { e.printStackTrace();
e.printStackTrace(); }
} catch (SecurityException e) { }
e.printStackTrace(); return icon;
} catch (IllegalAccessException e) { }
e.printStackTrace();
} catch (NoSuchFieldException e) { @Override
e.printStackTrace(); public GameDataElement clone() {
} ItemCategory clone = new ItemCategory();
} clone.jsonFile = this.jsonFile;
return icon; clone.state = this.state;
} clone.id = this.id;
clone.name = this.name;
@Override clone.size = this.size;
public GameDataElement clone() { clone.slot = this.slot;
ItemCategory clone = new ItemCategory(); clone.action_type = this.action_type;
clone.jsonFile = this.jsonFile; return clone;
clone.state = this.state; }
clone.id = this.id;
clone.name = this.name; @Override
clone.size = this.size; public void elementChanged(GameDataElement oldOne, GameDataElement newOne) {
clone.slot = this.slot; // Nothing to link to.
clone.action_type = this.action_type; }
return clone;
} @SuppressWarnings({ "rawtypes", "unchecked" })
@Override
@Override public Map toJson() {
public void elementChanged(GameDataElement oldOne, GameDataElement newOne) { Map itemCatJson = new LinkedHashMap();
// Nothing to link to. itemCatJson.put("id", this.id);
} if (this.name != null) itemCatJson.put("name", this.name);
if (this.action_type != null) itemCatJson.put("actionType", this.action_type.toString());
@SuppressWarnings({ "rawtypes", "unchecked" }) if (this.size != null) itemCatJson.put("size", this.size.toString());
@Override if (this.slot != null) itemCatJson.put("inventorySlot", this.slot.toString());
public Map toJson() { return itemCatJson;
Map itemCatJson = new LinkedHashMap(); }
itemCatJson.put("id", this.id);
if (this.name != null) itemCatJson.put("name", this.name);
if (this.action_type != null) itemCatJson.put("actionType", this.action_type.toString()); @Override
if (this.size != null) itemCatJson.put("size", this.size.toString()); public String getProjectFilename() {
if (this.slot != null) itemCatJson.put("inventorySlot", this.slot.toString()); return "itemcategories_"+getProject().name+".json";
return itemCatJson; }
}
}
@Override
public String getProjectFilename() {
return "itemcategories_"+getProject().name+".json";
}
}

View File

@@ -1,170 +1,179 @@
package com.gpl.rpg.atcontentstudio.model.gamedata; package com.gpl.rpg.atcontentstudio.model.gamedata;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.FileReader; import java.io.FileReader;
import java.io.IOException; import java.io.IOException;
import java.io.StringWriter; import java.io.StringWriter;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.json.simple.JSONObject; import org.json.simple.JSONObject;
import org.json.simple.parser.JSONParser; import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException; import org.json.simple.parser.ParseException;
import com.gpl.rpg.atcontentstudio.Notification; import com.gpl.rpg.atcontentstudio.Notification;
import com.gpl.rpg.atcontentstudio.io.JsonPrettyWriter; import com.gpl.rpg.atcontentstudio.io.JsonPrettyWriter;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.SaveEvent; import com.gpl.rpg.atcontentstudio.model.SaveEvent;
public abstract class JSONElement extends GameDataElement { public abstract class JSONElement extends GameDataElement {
private static final long serialVersionUID = -8015398814080503982L; private static final long serialVersionUID = -8015398814080503982L;
//Available from state init. //Available from state init.
public File jsonFile; public File jsonFile;
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public void parse() { public void parse() {
if (this.state == State.created || this.state == State.modified || this.state == State.saved) { if (shouldSkipParseOrLink()) {
//This type of state is unrelated to parsing/linking. return;
return; }
} JSONParser parser = new JSONParser();
JSONParser parser = new JSONParser(); FileReader reader = null;
FileReader reader = null; try {
try { reader = new FileReader(jsonFile);
reader = new FileReader(jsonFile); List gameDataElements = (List) parser.parse(reader);
List gameDataElements = (List) parser.parse(reader); for (Object obj : gameDataElements) {
for (Object obj : gameDataElements) { Map jsonObj = (Map)obj;
Map jsonObj = (Map)obj; String id = (String) jsonObj.get("id");
String id = (String) jsonObj.get("id"); try {
if (id != null && id.equals(this.id )) { if (id != null && id.equals(this.id )) {
this.parse(jsonObj); this.parse(jsonObj);
this.state = State.parsed; this.state = State.parsed;
break; break;
} }
} }
} catch (FileNotFoundException e) { catch(Exception e){
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); System.out.println("Error in ID: " + id);
e.printStackTrace(); System.out.println(e.getMessage());
} catch (IOException e) { }
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); }
e.printStackTrace(); } catch (FileNotFoundException e) {
} catch (ParseException e) { Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); e.printStackTrace();
e.printStackTrace(); } catch (IOException e) {
} finally { Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
if (reader != null) e.printStackTrace();
try { } catch (ParseException e) {
reader.close(); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
} catch (IOException e) { e.printStackTrace();
e.printStackTrace(); } catch (IllegalArgumentException e) {
} System.out.println(id);
} Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace();
} } finally {
if (reader != null)
public abstract void parse(@SuppressWarnings("rawtypes") Map jsonObj); try {
reader.close();
@SuppressWarnings("rawtypes") } catch (IOException e) {
public abstract Map toJson(); e.printStackTrace();
public String toJsonString() { }
StringWriter writer = new JsonPrettyWriter(); }
try {
JSONObject.writeJSONString(this.toJson(), writer); }
} catch (IOException e) {
//Impossible with a StringWriter public abstract void parse(@SuppressWarnings("rawtypes") Map jsonObj);
}
return writer.toString(); @SuppressWarnings("rawtypes")
} public abstract Map toJson();
public String toJsonString() {
StringWriter writer = new JsonPrettyWriter();
@Override try {
public GameDataSet getDataSet() { JSONObject.writeJSONString(this.toJson(), writer);
if (parent == null) { } catch (IOException e) {
System.out.println("blerf."); //Impossible with a StringWriter
} }
return parent.getDataSet(); return writer.toString();
} }
public void save() {
if (this.getParent() instanceof GameDataCategory<?> && writable) { @Override
((GameDataCategory<?>)this.getParent()).save(this.jsonFile); public GameDataSet getDataSet() {
} if (parent == null) {
} System.out.println("blerf.");
}
/** return parent.getDataSet();
* Returns null if save occurred (no notable events). }
*/
public List<SaveEvent> attemptSave() { public void save() {
List<SaveEvent> events = ((GameDataCategory<?>)this.getParent()).attemptSave(true, this.jsonFile.getName()); if (this.getParent() instanceof GameDataCategory<?> && writable) {
if (events == null || events.isEmpty()) { ((GameDataCategory<?>)this.getParent()).save(this.jsonFile);
return null; }
} }
if (events.size() == 1 && events.get(0).type == SaveEvent.Type.alsoSave && events.get(0).target == this) {
save(); /**
return null; * Returns null if save occurred (no notable events).
} */
return events; public List<SaveEvent> attemptSave() {
} List<SaveEvent> events = ((GameDataCategory<?>)this.getParent()).attemptSave(true, this.jsonFile.getName());
if (events == null || events.isEmpty()) {
public static Integer getInteger(Number n) { return null;
return n == null ? null : n.intValue(); }
} if (events.size() == 1 && events.get(0).type == SaveEvent.Type.alsoSave && events.get(0).target == this) {
save();
public static Double getDouble(Number n) { return null;
return n == null ? null : n.doubleValue(); }
} return events;
}
public static Double parseChance(String s) {
if (s.equals("100")) return 100d; public static Integer getInteger(Number n) {
else if (s.equals("70")) return 70d; return n == null ? null : n.intValue();
else if (s.equals("30")) return 30d; }
else if (s.equals("25")) return 25d;
else if (s.equals("20")) return 20d; public static Double getDouble(Number n) {
else if (s.equals("10")) return 10d; return n == null ? null : n.doubleValue();
else if (s.equals("5")) return 5d; }
else if (s.equals("1")) return 1d;
else if (s.equals("1/1000")) return 0.1; public static Double parseChance(String s) {
else if (s.equals("1/10000")) return 0.01; if (s.equals("100")) return 100d;
else if (s.indexOf('/') >= 0) { else if (s.equals("70")) return 70d;
int c = s.indexOf('/'); else if (s.equals("30")) return 30d;
double a = 1; else if (s.equals("25")) return 25d;
try { else if (s.equals("20")) return 20d;
a = Integer.parseInt(s.substring(0, c)); else if (s.equals("10")) return 10d;
} catch (NumberFormatException nfe) {} else if (s.equals("5")) return 5d;
double b = 100; else if (s.equals("1")) return 1d;
try { else if (s.equals("1/1000")) return 0.1;
b = Integer.parseInt(s.substring(c+1)); else if (s.equals("1/10000")) return 0.01;
} catch (NumberFormatException nfe) {} else if (s.indexOf('/') >= 0) {
return a/b; int c = s.indexOf('/');
} double a = 1;
else { try {
double a = 10; a = Integer.parseInt(s.substring(0, c));
try { } catch (NumberFormatException nfe) {}
a = Double.parseDouble(s); double b = 100;
} catch (NumberFormatException nfe) {} try {
return a; b = Integer.parseInt(s.substring(c+1));
} } catch (NumberFormatException nfe) {}
} return a/b;
}
public static String printJsonChance(Double chance) { else {
if (chance.equals(100d)) return "100"; double a = 10;
else if (chance.equals(70d)) return "70"; try {
else if (chance.equals(30d)) return "30"; a = Double.parseDouble(s);
else if (chance.equals(25d)) return "25"; } catch (NumberFormatException nfe) {}
else if (chance.equals(20d)) return "20"; return a;
else if (chance.equals(10d)) return "10"; }
else if (chance.equals(5d)) return "5"; }
else if (chance.equals(1d)) return "1";
else if (chance.equals(0.1d)) return "1/1000"; public static String printJsonChance(Double chance) {
else if (chance.equals(0.01d)) return "1/10000"; if (chance.equals(100d)) return "100";
else { else if (chance.equals(70d)) return "70";
if (chance.intValue() == chance) return Integer.toString(chance.intValue()); else if (chance.equals(30d)) return "30";
//TODO Better handling of fractions. Chance description need a complete overhaul in AT. else if (chance.equals(25d)) return "25";
//This part does not output the input content of parseDouble(String s) in the case of fractions. else if (chance.equals(20d)) return "20";
return chance.toString(); else if (chance.equals(10d)) return "10";
} else if (chance.equals(5d)) return "5";
} else if (chance.equals(1d)) return "1";
else if (chance.equals(0.1d)) return "1/1000";
} else if (chance.equals(0.01d)) return "1/10000";
else {
if (chance.intValue() == chance) return Integer.toString(chance.intValue());
//TODO Better handling of fractions. Chance description need a complete overhaul in AT.
//This part does not output the input content of parseDouble(String s) in the case of fractions.
return chance.toString();
}
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -1,198 +1,191 @@
package com.gpl.rpg.atcontentstudio.model.gamedata; package com.gpl.rpg.atcontentstudio.model.gamedata;
import java.awt.Image; import java.awt.Image;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.FileReader; import java.io.FileReader;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.json.simple.parser.JSONParser; import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException; import org.json.simple.parser.ParseException;
import com.gpl.rpg.atcontentstudio.Notification; import com.gpl.rpg.atcontentstudio.Notification;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.GameSource; import com.gpl.rpg.atcontentstudio.model.GameSource;
import com.gpl.rpg.atcontentstudio.ui.DefaultIcons; import com.gpl.rpg.atcontentstudio.ui.DefaultIcons;
public class Quest extends JSONElement { public class Quest extends JSONElement {
private static final long serialVersionUID = 2004839647483250099L; private static final long serialVersionUID = 2004839647483250099L;
//Available from init state //Available from init state
//public String id = null; inherited. //public String id = null; inherited.
public String name = null; public String name = null;
//Available in parsed state //Available in parsed state
public Integer visible_in_log = null; public Integer visible_in_log = null;
public List<QuestStage> stages = null; public List<QuestStage> stages = null;
@Override @Override
public String getDesc() { public String getDesc() {
return (needsSaving() ? "*" : "")+name+" ("+id+")"; return (needsSaving() ? "*" : "")+name+" ("+id+")";
} }
public static String getStaticDesc() { public static String getStaticDesc() {
return "Quests"; return "Quests";
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static void fromJson(File jsonFile, GameDataCategory<Quest> category) { public static void fromJson(File jsonFile, GameDataCategory<Quest> category) {
JSONParser parser = new JSONParser(); JSONParser parser = new JSONParser();
FileReader reader = null; FileReader reader = null;
try { try {
reader = new FileReader(jsonFile); reader = new FileReader(jsonFile);
List quests = (List) parser.parse(reader); List quests = (List) parser.parse(reader);
for (Object obj : quests) { for (Object obj : quests) {
Map questJson = (Map)obj; Map questJson = (Map)obj;
Quest quest = fromJson(questJson); Quest quest = fromJson(questJson);
quest.jsonFile = jsonFile; quest.jsonFile = jsonFile;
quest.parent = category; quest.parent = category;
if (quest.getDataType() == GameSource.Type.created || quest.getDataType() == GameSource.Type.altered) { if (quest.getDataType() == GameSource.Type.created || quest.getDataType() == GameSource.Type.altered) {
quest.writable = true; quest.writable = true;
} }
category.add(quest); category.add(quest);
} }
} catch (FileNotFoundException e) { } catch (FileNotFoundException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} catch (IOException e) { } catch (IOException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} catch (ParseException e) { } catch (ParseException e) {
Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage()); Notification.addError("Error while parsing JSON file "+jsonFile.getAbsolutePath()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
} finally { } finally {
if (reader != null) if (reader != null)
try { try {
reader.close(); reader.close();
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
} }
} }
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static Quest fromJson(String jsonString) throws ParseException { public static Quest fromJson(String jsonString) throws ParseException {
Map questJson = (Map) new JSONParser().parse(jsonString); Map questJson = (Map) new JSONParser().parse(jsonString);
Quest quest = fromJson(questJson); Quest quest = fromJson(questJson);
quest.parse(questJson); quest.parse(questJson);
return quest; return quest;
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public static Quest fromJson(Map questJson) { public static Quest fromJson(Map questJson) {
Quest quest = new Quest(); Quest quest = new Quest();
quest.id = (String) questJson.get("id"); quest.id = (String) questJson.get("id");
quest.name = (String) questJson.get("name"); quest.name = (String) questJson.get("name");
//Quests have to be parsed to have their stages initialized. //Quests have to be parsed to have their stages initialized.
quest.parse(questJson); quest.parse(questJson);
return quest; return quest;
} }
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
@Override @Override
public void parse(Map questJson) { public void parse(Map questJson) {
this.visible_in_log = JSONElement.getInteger((Number) questJson.get("showInLog")); this.visible_in_log = JSONElement.getInteger((Number) questJson.get("showInLog"));
List questStagesJson = (List) questJson.get("stages"); List questStagesJson = (List) questJson.get("stages");
this.stages = new ArrayList<QuestStage>(); this.stages = new ArrayList<QuestStage>();
if (questStagesJson != null && !questStagesJson.isEmpty()) { if (questStagesJson != null && !questStagesJson.isEmpty()) {
for (Object questStageJsonObj : questStagesJson) { for (Object questStageJsonObj : questStagesJson) {
Map questStageJson = (Map)questStageJsonObj; Map questStageJson = (Map)questStageJsonObj;
QuestStage questStage = new QuestStage(this); QuestStage questStage = new QuestStage(this);
questStage.parse(questStageJson); questStage.parse(questStageJson);
this.stages.add(questStage); this.stages.add(questStage);
} }
} }
this.state = State.parsed; this.state = State.parsed;
} }
@Override @Override
public void link() { public void link() {
if (this.state == State.created || this.state == State.modified || this.state == State.saved) { if (shouldSkipParseOrLink()) {
//This type of state is unrelated to parsing/linking. return;
return; }
} ensureParseIfNeeded();
if (this.state == State.init) {
//Not parsed yet. for (QuestStage stage : stages) {
this.parse(); stage.link();
} else if (this.state == State.linked) { }
//Already linked. //Nothing to link to :D
return; this.state = State.linked;
} }
for (QuestStage stage : stages) { @Override
stage.link(); public Image getIcon() {
} return DefaultIcons.getQuestIcon();
//Nothing to link to :D }
this.state = State.linked;
} public Image getImage() {
return DefaultIcons.getQuestImage();
@Override }
public Image getIcon() {
return DefaultIcons.getQuestIcon(); @Override
} public GameDataElement clone() {
Quest clone = new Quest();
public Image getImage() { clone.jsonFile = this.jsonFile;
return DefaultIcons.getQuestImage(); clone.state = this.state;
} clone.id = this.id;
clone.name = this.name;
@Override clone.visible_in_log = this.visible_in_log;
public GameDataElement clone() { if (this.stages != null) {
Quest clone = new Quest(); clone.stages = new ArrayList<QuestStage>();
clone.jsonFile = this.jsonFile; for (QuestStage stage : this.stages){
clone.state = this.state; clone.stages.add((QuestStage) stage.clone(clone));
clone.id = this.id; }
clone.name = this.name; }
clone.visible_in_log = this.visible_in_log; return clone;
if (this.stages != null) { }
clone.stages = new ArrayList<QuestStage>();
for (QuestStage stage : this.stages){ @Override
clone.stages.add((QuestStage) stage.clone(clone)); public void elementChanged(GameDataElement oldOne, GameDataElement newOne) {
} //Nothing to link to.
} }
return clone;
} @SuppressWarnings({ "rawtypes", "unchecked" })
@Override
@Override public Map toJson() {
public void elementChanged(GameDataElement oldOne, GameDataElement newOne) { Map questJson = new LinkedHashMap();
//Nothing to link to. questJson.put("id", this.id);
} if (this.name != null) questJson.put("name", this.name);
if (this.visible_in_log != null) questJson.put("showInLog", this.visible_in_log);
@SuppressWarnings({ "rawtypes", "unchecked" }) if (this.stages != null) {
@Override List stagesJson = new ArrayList();
public Map toJson() { questJson.put("stages", stagesJson);
Map questJson = new LinkedHashMap(); for (QuestStage stage : this.stages) {
questJson.put("id", this.id); stagesJson.add(stage.toJson());
if (this.name != null) questJson.put("name", this.name); }
if (this.visible_in_log != null) questJson.put("showInLog", this.visible_in_log); }
if (this.stages != null) { return questJson;
List stagesJson = new ArrayList(); }
questJson.put("stages", stagesJson);
for (QuestStage stage : this.stages) {
stagesJson.add(stage.toJson()); @Override
} public String getProjectFilename() {
} return "questlist_"+getProject().name+".json";
return questJson; }
}
public QuestStage getStage(Integer stageId) {
for (QuestStage stage : stages) {
@Override if (stage.progress.equals(stageId)) {
public String getProjectFilename() { return stage;
return "questlist_"+getProject().name+".json"; }
} }
return null;
public QuestStage getStage(Integer stageId) { }
for (QuestStage stage : stages) {
if (stage.progress.equals(stageId)) { }
return stage;
}
}
return null;
}
}

View File

@@ -8,18 +8,18 @@ import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.ui.DefaultIcons; import com.gpl.rpg.atcontentstudio.ui.DefaultIcons;
public class QuestStage extends JSONElement { public class QuestStage extends JSONElement {
private static final long serialVersionUID = 8313645819951513431L; private static final long serialVersionUID = 8313645819951513431L;
public Integer progress = null; public Integer progress = null;
public String log_text = null; public String log_text = null;
public Integer exp_reward = null; public Integer exp_reward = null;
public Integer finishes_quest = null; public Integer finishes_quest = null;
public QuestStage(Quest parent){ public QuestStage(Quest parent){
this.parent = parent; this.parent = parent;
} }
public QuestStage clone(Quest cloneParent) { public QuestStage clone(Quest cloneParent) {
QuestStage clone = new QuestStage(cloneParent); QuestStage clone = new QuestStage(cloneParent);
clone.progress = progress != null ? new Integer(progress) : null; clone.progress = progress != null ? new Integer(progress) : null;
@@ -59,18 +59,11 @@ public class QuestStage extends JSONElement {
@Override @Override
public void link() { public void link() {
if (this.state == State.created || this.state == State.modified || this.state == State.saved) { if (shouldSkipParseOrLink()) {
//This type of state is unrelated to parsing/linking.
return; return;
} }
if (this.state == State.init) { ensureParseIfNeeded();
//Not parsed yet.
this.parse();
} else if (this.state == State.linked) {
//Already linked.
return;
}
//Nothing to link to :D //Nothing to link to :D
this.state = State.linked; this.state = State.linked;
} }
@@ -89,15 +82,15 @@ public class QuestStage extends JSONElement {
public GameDataElement clone() { public GameDataElement clone() {
return null; return null;
} }
@Override @Override
public Image getIcon() { public Image getIcon() {
return DefaultIcons.getQuestIcon(); return DefaultIcons.getQuestIcon();
} }
public Image getImage() { public Image getImage() {
return DefaultIcons.getQuestImage(); return DefaultIcons.getQuestImage();
} }
} }

View File

@@ -26,10 +26,13 @@ public class Requirement extends JSONElement {
countedItemTypes.add(RequirementType.inventoryRemove); countedItemTypes.add(RequirementType.inventoryRemove);
countedItemTypes.add(RequirementType.inventoryKeep); countedItemTypes.add(RequirementType.inventoryKeep);
countedItemTypes.add(RequirementType.usedItem); countedItemTypes.add(RequirementType.usedItem);
countedItemTypes.add(RequirementType.wear);
countedItemTypes.add(RequirementType.wearRemove);
COMPATIBLE_TYPES.put(RequirementType.inventoryRemove, countedItemTypes); COMPATIBLE_TYPES.put(RequirementType.inventoryRemove, countedItemTypes);
COMPATIBLE_TYPES.put(RequirementType.inventoryKeep, countedItemTypes); COMPATIBLE_TYPES.put(RequirementType.inventoryKeep, countedItemTypes);
COMPATIBLE_TYPES.put(RequirementType.usedItem, countedItemTypes); COMPATIBLE_TYPES.put(RequirementType.usedItem, countedItemTypes);
COMPATIBLE_TYPES.put(RequirementType.wear, countedItemTypes);
COMPATIBLE_TYPES.put(RequirementType.wearRemove, countedItemTypes);
} }
//Available from parsed state //Available from parsed state
@@ -54,7 +57,14 @@ public class Requirement extends JSONElement {
spentGold, spentGold,
consumedBonemeals, consumedBonemeals,
hasActorCondition, hasActorCondition,
factionScore factionScore,
random,
factionScoreEquals,
wearRemove,
date,
dateEquals,
time,
timeEquals
} }
public enum SkillID { public enum SkillID {
@@ -79,6 +89,7 @@ public class Requirement extends JSONElement {
,resistancePhysical // lowers chance to get negative active conditions by monsters (Physical Capacity like Minor fatigue) ,resistancePhysical // lowers chance to get negative active conditions by monsters (Physical Capacity like Minor fatigue)
,resistanceBlood // lowers chance to get negative active conditions by monsters (Blood Disorder like Weak Poison) ,resistanceBlood // lowers chance to get negative active conditions by monsters (Blood Disorder like Weak Poison)
,shadowBless ,shadowBless
,sporeImmunity
,crit1 // lowers atk ability ,crit1 // lowers atk ability
,crit2 // lowers def ability ,rejuvenation // Reduces magnitudes of conditions ,crit2 // lowers def ability ,rejuvenation // Reduces magnitudes of conditions
,rejuvenation // Reduces magnitudes of conditions ,rejuvenation // Reduces magnitudes of conditions
@@ -90,6 +101,7 @@ public class Requirement extends JSONElement {
,weaponProficiencyAxe ,weaponProficiencyAxe
,weaponProficiencyBlunt ,weaponProficiencyBlunt
,weaponProficiencyUnarmed ,weaponProficiencyUnarmed
,weaponProficiencyPole
,armorProficiencyShield ,armorProficiencyShield
,armorProficiencyUnarmored ,armorProficiencyUnarmored
,armorProficiencyLight ,armorProficiencyLight
@@ -104,9 +116,21 @@ public class Requirement extends JSONElement {
@Override @Override
public String getDesc() { public String getDesc() {
String obj_id = "";
if (required_obj_id != null)
{
obj_id = required_obj_id;
if (type != null && type == RequirementType.random){
obj_id = " Chance " + obj_id + (required_obj_id.contains("/") ? "" : "%");
}
else {
obj_id += ":";
}
}
return ((negated != null && negated) ? "NOT " : "") return ((negated != null && negated) ? "NOT " : "")
+(type == null ? "" : type.toString()+":") +(type == null ? "" : type.toString()+":")
+(required_obj_id == null ? "" : required_obj_id+":") +obj_id
+(required_value == null ? "" : required_value.toString()); +(required_value == null ? "" : required_value.toString());
} }
@@ -153,6 +177,7 @@ public class Requirement extends JSONElement {
case inventoryRemove: case inventoryRemove:
case usedItem: case usedItem:
case wear: case wear:
case wearRemove:
this.required_obj = proj.getItem(required_obj_id); this.required_obj = proj.getItem(required_obj_id);
break; break;
case killedMonster: case killedMonster:
@@ -173,6 +198,12 @@ public class Requirement extends JSONElement {
case spentGold: case spentGold:
case timerElapsed: case timerElapsed:
case factionScore: case factionScore:
case factionScoreEquals:
case random:
case date:
case dateEquals:
case time:
case timeEquals:
break; break;
} }
if (this.required_obj != null) this.required_obj.addBacklink((GameDataElement) this.parent); if (this.required_obj != null) this.required_obj.addBacklink((GameDataElement) this.parent);
@@ -225,6 +256,12 @@ public class Requirement extends JSONElement {
required_obj_id = null; required_obj_id = null;
required_value = null; required_value = null;
} }
if(destType==RequirementType.random)
{
required_obj_id = "50/100";
}
type = destType; type = destType;
} }

View File

@@ -71,6 +71,9 @@ public class ReplaceArea extends MapObject {
addReplacement(repl); addReplacement(repl);
return repl; return repl;
} }
public ReplaceArea.Replacement createReplacement(String source, String target) {
return new Replacement(source, target);
}
public void addReplacement(ReplaceArea.Replacement repl) { public void addReplacement(ReplaceArea.Replacement repl) {
if (replacements == null) replacements = new ArrayList<ReplaceArea.Replacement>(); if (replacements == null) replacements = new ArrayList<ReplaceArea.Replacement>();
@@ -95,7 +98,9 @@ public class ReplaceArea extends MapObject {
if (oldSchoolRequirement && Requirement.RequirementType.questProgress.equals(requirement.type) && (requirement.negated == null || !requirement.negated)) { if (oldSchoolRequirement && Requirement.RequirementType.questProgress.equals(requirement.type) && (requirement.negated == null || !requirement.negated)) {
tmxObject.setName(requirement.required_obj_id+":"+((requirement.required_value == null) ? "" : Integer.toString(requirement.required_value))); tmxObject.setName(requirement.required_obj_id+":"+((requirement.required_value == null) ? "" : Integer.toString(requirement.required_value)));
} else { } else {
tmxObject.getProperties().setProperty("requireType", requirement.type.toString()); if (requirement.type != null) {
tmxObject.getProperties().setProperty("requireType", requirement.type.toString());
}
if (requirement.required_obj != null) { if (requirement.required_obj != null) {
tmxObject.getProperties().setProperty("requireId", requirement.required_obj.id); tmxObject.getProperties().setProperty("requireId", requirement.required_obj.id);
} else if (requirement.required_obj_id != null) { } else if (requirement.required_obj_id != null) {

View File

@@ -11,7 +11,7 @@ import com.gpl.rpg.atcontentstudio.ui.DefaultIcons;
public class SpawnArea extends MapObject { public class SpawnArea extends MapObject {
public int quantity = 1; public int quantity = 1;
public int spawnchance = 10; public int respawnSpeed = 10;
public boolean active = true; public boolean active = true;
public boolean ignoreAreas = false; public boolean ignoreAreas = false;
public String spawngroup_id; public String spawngroup_id;
@@ -21,8 +21,8 @@ public class SpawnArea extends MapObject {
if (obj.getProperties().getProperty("quantity") != null) { if (obj.getProperties().getProperty("quantity") != null) {
this.quantity = Integer.parseInt(obj.getProperties().getProperty("quantity")); this.quantity = Integer.parseInt(obj.getProperties().getProperty("quantity"));
} }
if (obj.getProperties().getProperty("spawnchance") != null) { if (obj.getProperties().getProperty("respawnspeed") != null) {
this.spawnchance = Integer.parseInt(obj.getProperties().getProperty("spawnchance")); this.respawnSpeed = Integer.parseInt(obj.getProperties().getProperty("respawnspeed"));
} }
if (obj.getProperties().getProperty("active") != null) { if (obj.getProperties().getProperty("active") != null) {
this.active = Boolean.parseBoolean(obj.getProperties().getProperty("active")); this.active = Boolean.parseBoolean(obj.getProperties().getProperty("active"));
@@ -82,8 +82,8 @@ public class SpawnArea extends MapObject {
if (quantity != 1) { if (quantity != 1) {
tmxObject.getProperties().setProperty("quantity", Integer.toString(quantity)); tmxObject.getProperties().setProperty("quantity", Integer.toString(quantity));
} }
if (spawnchance != 10) { if (respawnSpeed != 10) {
tmxObject.getProperties().setProperty("spawnchance", Integer.toString(spawnchance)); tmxObject.getProperties().setProperty("respawnspeed", Integer.toString(respawnSpeed));
} }
if (!this.active) { if (!this.active) {
tmxObject.getProperties().setProperty("active", Boolean.toString(active)); tmxObject.getProperties().setProperty("active", Boolean.toString(active));
@@ -92,5 +92,4 @@ public class SpawnArea extends MapObject {
tmxObject.getProperties().setProperty("ignoreAreas", Boolean.toString(ignoreAreas)); tmxObject.getProperties().setProperty("ignoreAreas", Boolean.toString(ignoreAreas));
} }
} }
} }

View File

@@ -258,7 +258,7 @@ public class TMXMap extends GameDataElement {
if (getDataType() == GameSource.Type.source) { if (getDataType() == GameSource.Type.source) {
writer.writeMap(tmxMap, baos, tmxFile.getAbsolutePath()); writer.writeMap(tmxMap, baos, tmxFile.getAbsolutePath());
} else { } else {
writer.writeMap(tmxMap, baos, getProject().baseContent.gameMaps.mapFolder.getAbsolutePath()+File.separator+"placeholder.tmx"); writer.writeMap(tmxMap, baos, ((TMXMapSet)this.parent).mapFolder.getAbsolutePath()+File.separator+"placeholder.tmx");
} }
} catch (Exception e) { } catch (Exception e) {
Notification.addError("Error while converting map "+getDesc()+" to XML: "+e.getMessage()); Notification.addError("Error while converting map "+getDesc()+" to XML: "+e.getMessage());

View File

@@ -100,7 +100,7 @@ public class TMXMapSet implements ProjectTreeNode {
while(getProject().open) { while(getProject().open) {
try { try {
watchService = FileSystems.getDefault().newWatchService(); watchService = FileSystems.getDefault().newWatchService();
/*WatchKey watchKey = */folderPath.register(watchService, StandardWatchEventKinds.ENTRY_MODIFY); /*WatchKey watchKey = */folderPath.register(watchService, StandardWatchEventKinds.ENTRY_MODIFY, StandardWatchEventKinds.ENTRY_CREATE);
WatchKey wk; WatchKey wk;
validService: while(getProject().open) { validService: while(getProject().open) {
wk = watchService.poll(10, TimeUnit.SECONDS); wk = watchService.poll(10, TimeUnit.SECONDS);

View File

@@ -1,9 +1,12 @@
package com.gpl.rpg.atcontentstudio.model.tools.i18n; package com.gpl.rpg.atcontentstudio.model.tools.i18n;
import java.io.File; import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter; import java.io.FileWriter;
import java.io.IOException; import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.Writer; import java.io.Writer;
import java.nio.charset.StandardCharsets;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
@@ -17,7 +20,7 @@ public class PoPotWriter {
public static void writePoFile(Map<String, List<String>> stringsResources, Map<String, String> translations, File destination) { public static void writePoFile(Map<String, List<String>> stringsResources, Map<String, String> translations, File destination) {
try { try {
FileWriter fw = new FileWriter(destination); Writer fw = new OutputStreamWriter(new FileOutputStream(destination), StandardCharsets.UTF_8);
if (translations.get("") != null) { if (translations.get("") != null) {
fw.write(translations.get("")); fw.write(translations.get(""));
writeEndOfEntry(fw); writeEndOfEntry(fw);

View File

@@ -28,6 +28,7 @@ public class PotGenerator {
for (ActorCondition ac : gsrc.gameData.actorConditions) { for (ActorCondition ac : gsrc.gameData.actorConditions) {
pushString(stringsResources, resourcesStrings, ac.display_name, getPotContextComment(ac)); pushString(stringsResources, resourcesStrings, ac.display_name, getPotContextComment(ac));
pushString(stringsResources, resourcesStrings, ac.description, getPotContextComment(ac)+":description");
} }
for (Dialogue d : gsrc.gameData.dialogues ) { for (Dialogue d : gsrc.gameData.dialogues ) {

View File

@@ -26,7 +26,9 @@ public class AboutEditor extends Editor {
private static final long serialVersionUID = 6230549148222457139L; private static final long serialVersionUID = 6230549148222457139L;
public static final String WELCOME_STRING = public static final String WELCOME_STRING =
"<html><body>" + "<html><head>" +
"<meta http-equiv=\\\"Content-Type\\\" content=\\\"text/html; charset=UTF-8\\\" />" +
"</head><body>" +
"<table><tr valign=\"top\">" + "<table><tr valign=\"top\">" +
"<td><img src=\""+ATContentStudio.class.getResource("/com/gpl/rpg/atcontentstudio/img/atcs_border_banner.png")+"\"/></td>" + "<td><img src=\""+ATContentStudio.class.getResource("/com/gpl/rpg/atcontentstudio/img/atcs_border_banner.png")+"\"/></td>" +
"<td><font size=+1>Welcome to "+ATContentStudio.APP_NAME+" "+ATContentStudio.APP_VERSION+"</font><br/>" + "<td><font size=+1>Welcome to "+ATContentStudio.APP_NAME+" "+ATContentStudio.APP_VERSION+"</font><br/>" +
@@ -35,23 +37,24 @@ public class AboutEditor extends Editor {
"<b>Right click on the left area or use the \"File\" menu to create a project.</b><br/>" + "<b>Right click on the left area or use the \"File\" menu to create a project.</b><br/>" +
"<br/>" + "<br/>" +
"Play <a href=\"https://play.google.com/store/apps/details?id=com.gpl.rpg.AndorsTrail\">Andor's Trail</a> for free on your Android device.<br/>" + "Play <a href=\"https://play.google.com/store/apps/details?id=com.gpl.rpg.AndorsTrail\">Andor's Trail</a> for free on your Android device.<br/>" +
"Visit <a href=\"http://andorstrail.com/\">the official forum</a> to give or receive help.<br/>" + "Visit <a href=\"https://andorstrail.com/\">the official forum</a> to give or receive help.<br/>" +
"Open the project's <a href=\"https://github.com/Zukero/andors-trail/\">GitHub project page</a> to check out the game's source code.<br/>" + "Open the project's <a href=\"https://github.com/Zukero/andors-trail/\">GitHub project page</a> to check out the game's source code.<br/>" +
"<br/>" + "<br/>" +
"For content creation help, make sure to use the following resources:<br/>" + "For content creation help, make sure to use the following resources:<br/>" +
"<a href=\"http://andorstrail.com/viewtopic.php?f=6&t=4560\">The contribution guide on the forums</a><br/>" + "<a href=\"https://andorstrail.com/viewtopic.php?f=6&t=4560\">The contribution guide on the forums</a><br/>" +
"<a href=\"http://andorstrail.com/wiki/doku.php?id=andors_trail_wiki:developer_section\">The developer section of the Andor's Trail wiki</a><br/>" + "<a href=\"https://andorstrail.com/wiki/doku.php?id=andors_trail_wiki:developer_section\">The developer section of the Andor's Trail wiki</a><br/>" +
"<a href=\"https://docs.google.com/document/d/1BwWD1tLgPcmA2bwudrVnOc6f2dkPLFCjWdn7tXlIp5g\">The design outline document on Google Drive/Docs</a><br/>" + "<a href=\"https://docs.google.com/document/d/1BwWD1tLgPcmA2bwudrVnOc6f2dkPLFCjWdn7tXlIp5g\">The design outline document on Google Drive/Docs</a><br/>" +
"<br/>" + "<br/>" +
"<font size=+1>Credits:</font><br/>" + "<font size=+1>Credits:</font><br/>" +
"<br/>" + "<br/>" +
"Author: <a href=\"http://andorstrail.com/memberlist.php?mode=viewprofile&u=2875\">Zukero</a><br/>" + "Author: <a href=\"https://andorstrail.com/memberlist.php?mode=viewprofile&u=2875\">Zukero</a><br/>" +
"Licence: <a href=\"http://www.gnu.org/licenses/gpl-3.0.html\">GPL v3</a><br/>" + "Licence: <a href=\"http://www.gnu.org/licenses/gpl-3.0.html\">GPL v3</a><br/>" +
"Sources are included in this package and on <a href=\"https://github.com/Zukero/ATCS\">GitHub</a>.<br/>" + "Sources are included in this package and on <a href=\"https://github.com/Zukero/ATCS\">GitHub</a>.<br/>" +
"<br/>" + "<br/>" +
"Contributors: <br/>" + "Contributors: <br/>" +
"Quentin Delvallet<br/>" + "Quentin Delvallet<br/>" +
"<EFBFBD>i<EFBFBD>kin<br/>" + "Žižkin<br/>" +
"Gonk<br/>" +
"<br/>" + "<br/>" +
"This project uses the following libraries:<br/>" + "This project uses the following libraries:<br/>" +
"<a href=\"http://code.google.com/p/json-simple/\">JSON.simple</a> by Yidong Fang & Chris Nokleberg.<br/>" + "<a href=\"http://code.google.com/p/json-simple/\">JSON.simple</a> by Yidong Fang & Chris Nokleberg.<br/>" +
@@ -79,7 +82,7 @@ public class AboutEditor extends Editor {
"<a href=\"https://jsoup.org/\">jsoup</a> by Jonathan Hedley<br/>" + "<a href=\"https://jsoup.org/\">jsoup</a> by Jonathan Hedley<br/>" +
"License: <a href=\"https://jsoup.org/license\">MIT License</a><br/>" + "License: <a href=\"https://jsoup.org/license\">MIT License</a><br/>" +
"<br/>" + "<br/>" +
"A slightly modified version of <a href=\"https://launchpad.net/po-parser\">General PO Parser</a> by Bal<61>zs T<>th<br/>" + "A slightly modified version of <a href=\"https://launchpad.net/po-parser\">General PO Parser</a> by Bal<61>zs T<>th<br/>" +
"License: <a href=\"http://www.gnu.org/licenses/gpl-3.0.html\">GPL v3</a><br/>" + "License: <a href=\"http://www.gnu.org/licenses/gpl-3.0.html\">GPL v3</a><br/>" +
"<br/>" + "<br/>" +
"A slightly modified version of <a href=\"www.whoischarles.com\">Minify.java</a> by Charles Bihis<br/>" + "A slightly modified version of <a href=\"www.whoischarles.com\">Minify.java</a> by Charles Bihis<br/>" +

View File

@@ -260,6 +260,14 @@ public class DefaultIcons {
public static Image getTimerImage() { return getImage(TIMER_RES); } public static Image getTimerImage() { return getImage(TIMER_RES); }
public static Image getTimerIcon() { return getIcon(TIMER_RES); } public static Image getTimerIcon() { return getIcon(TIMER_RES); }
private static String DATE_RES = "/com/gpl/rpg/atcontentstudio/img/date.png";
public static Image getDateImage() { return getImage(DATE_RES); }
public static Image getDateIcon() { return getIcon(DATE_RES); }
private static String TIME_RES = "/com/gpl/rpg/atcontentstudio/img/date.png";
public static Image getTimeImage() { return getImage(TIME_RES); }
public static Image getTimeIcon() { return getIcon(TIME_RES); }
private static String ALIGNMENT_RES = "/com/gpl/rpg/atcontentstudio/img/alignment.png"; private static String ALIGNMENT_RES = "/com/gpl/rpg/atcontentstudio/img/alignment.png";
public static Image getAlignmentImage() { return getImage(ALIGNMENT_RES); } public static Image getAlignmentImage() { return getImage(ALIGNMENT_RES); }
public static Image getAlignmentIcon() { return getIcon(ALIGNMENT_RES); } public static Image getAlignmentIcon() { return getIcon(ALIGNMENT_RES); }
@@ -273,7 +281,7 @@ public class DefaultIcons {
public static Image getStatusOrangeIcon() { return getIcon(STATUS_ORANGE_RES); } public static Image getStatusOrangeIcon() { return getIcon(STATUS_ORANGE_RES); }
private static String STATUS_GREEN_RES = "/com/gpl/rpg/atcontentstudio/img/status_green.png"; private static String STATUS_GREEN_RES = "/com/gpl/rpg/atcontentstudio/img/status_green.png";
public static Image getStatusGreenImage() { return getImage(STATUS_GREEN_RES); } public static Image getStatusGreenImage() { return getImage(STATUS_GREEN_RES); }
public static Image getStatusGreenIcon() { return getIcon(STATUS_GREEN_RES); } public static Image getStatusGreenIcon() { return getIcon(STATUS_GREEN_RES); }
private static String STATUS_BLUE_RES = "/com/gpl/rpg/atcontentstudio/img/status_blue.png"; private static String STATUS_BLUE_RES = "/com/gpl/rpg/atcontentstudio/img/status_blue.png";

View File

@@ -348,6 +348,138 @@ public abstract class Editor extends JPanel implements ProjectElementListener {
return spinner; return spinner;
} }
private static final String percent = "%";
private static final String ratio = "x/y";
public static JComponent addChanceField(JPanel pane, String label, String initialValue, String defaultValue, boolean editable, final FieldUpdateListener listener) {
int defaultChance = 1;
int defaultMaxChance = 100;
if (defaultValue != null) {
if (defaultValue.contains("/")) {
int c = defaultValue.indexOf('/');
try { defaultChance = Integer.parseInt(defaultValue.substring(0, c)); } catch (NumberFormatException nfe) {};
try { defaultMaxChance = Integer.parseInt(defaultValue.substring(c+1)); } catch (NumberFormatException nfe) {};
} else {
try { defaultChance = Integer.parseInt(defaultValue); } catch (NumberFormatException nfe) {};
}
}
boolean currentFormIsRatio = true;
int chance = defaultChance;
int maxChance = defaultMaxChance;
if (initialValue != null) {
if (initialValue.contains("/")) {
int c = initialValue.indexOf('/');
try { chance = Integer.parseInt(initialValue.substring(0, c)); } catch (NumberFormatException nfe) {};
try { maxChance = Integer.parseInt(initialValue.substring(c+1)); } catch (NumberFormatException nfe) {};
} else {
try {
chance = Integer.parseInt(initialValue);
currentFormIsRatio = false;
} catch (NumberFormatException nfe) {};
}
}
final JPanel tfPane = new JPanel();
tfPane.setLayout(new JideBoxLayout(tfPane, JideBoxLayout.LINE_AXIS, 6));
JLabel tfLabel = new JLabel(label);
tfPane.add(tfLabel, JideBoxLayout.FIX);
final JComboBox<String> entryTypeBox = new JComboBox<String>(new String[] {percent, ratio});
if (currentFormIsRatio) {
entryTypeBox.setSelectedItem(ratio);
} else {
entryTypeBox.setSelectedItem(percent);
}
entryTypeBox.setEnabled(editable);
tfPane.add(entryTypeBox, JideBoxLayout.FIX);
/////////////////////////////////////////////////////////////////////////////////////////////////// make sure "chance" is between 1 and 100. If lower than 1 get 1. If higher than 100, get chance/maxChance * 100... Then do the same with defaultChance, in case no value exist.
final SpinnerNumberModel percentModel = new SpinnerNumberModel(initialValue != null ? ((chance > 1 ? chance : 1) < 100 ? chance : (chance * 100 / maxChance)) : ((defaultChance > 1 ? defaultChance : 1) < 100 ? defaultChance : (defaultChance * 100 / defaultMaxChance)) , 1, 100, 1);
final SpinnerNumberModel ratioChanceModel = new SpinnerNumberModel(initialValue != null ? chance : defaultChance, 1, Integer.MAX_VALUE, 1);
final JSpinner chanceSpinner = new JSpinner(currentFormIsRatio ? ratioChanceModel : percentModel);
if (!currentFormIsRatio) ((JSpinner.DefaultEditor)chanceSpinner.getEditor()).getTextField().setHorizontalAlignment(JTextField.LEFT);
chanceSpinner.setEnabled(editable);
((DefaultFormatter)((NumberEditor)chanceSpinner.getEditor()).getTextField().getFormatter()).setCommitsOnValidEdit(true);
tfPane.add(chanceSpinner, JideBoxLayout.FLEXIBLE);
final JLabel ratioLabel = new JLabel("/");
tfPane.add(ratioLabel, JideBoxLayout.FIX);
final JSpinner maxChanceSpinner = new JSpinner(new SpinnerNumberModel(initialValue != null ? maxChance : defaultMaxChance, 1, Integer.MAX_VALUE, 1));
((JSpinner.DefaultEditor)maxChanceSpinner.getEditor()).getTextField().setHorizontalAlignment(JTextField.LEFT);
maxChanceSpinner.setEnabled(editable);
((DefaultFormatter)((NumberEditor)maxChanceSpinner.getEditor()).getTextField().getFormatter()).setCommitsOnValidEdit(true);
tfPane.add(maxChanceSpinner, JideBoxLayout.FLEXIBLE);
if (!currentFormIsRatio) {
ratioLabel.setVisible(false);
maxChanceSpinner.setVisible(false);
tfPane.revalidate();
tfPane.repaint();
}
final JButton nullify = new JButton(new ImageIcon(DefaultIcons.getNullifyIcon()));
tfPane.add(nullify, JideBoxLayout.FIX);
nullify.setEnabled(editable);
pane.add(tfPane, JideBoxLayout.FIX);
entryTypeBox.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (entryTypeBox.getSelectedItem() == percent) {
int chance = ((Integer)chanceSpinner.getValue());
int maxChance = ((Integer)maxChanceSpinner.getValue());
chance *= 100;
chance /= maxChance;
chance = Math.max(0, Math.min(100, chance));
chanceSpinner.setModel(percentModel);
chanceSpinner.setValue(chance);
((JSpinner.DefaultEditor)chanceSpinner.getEditor()).getTextField().setHorizontalAlignment(JTextField.LEFT);
ratioLabel.setVisible(false);
maxChanceSpinner.setVisible(false);
tfPane.revalidate();
tfPane.repaint();
listener.valueChanged(chanceSpinner, chanceSpinner.getValue().toString());
} else if (entryTypeBox.getSelectedItem() == ratio) {
int chance = ((Integer)chanceSpinner.getValue());
chanceSpinner.setModel(ratioChanceModel);
chanceSpinner.setValue(chance);
maxChanceSpinner.setValue(100);
ratioLabel.setVisible(true);
maxChanceSpinner.setVisible(true);
tfPane.revalidate();
tfPane.repaint();
listener.valueChanged(chanceSpinner, chanceSpinner.getValue().toString() + "/" + maxChanceSpinner.getValue().toString());
}
}
});
chanceSpinner.addChangeListener(new ChangeListener() {
@Override
public void stateChanged(ChangeEvent e) {
if (entryTypeBox.getSelectedItem() == percent) {
listener.valueChanged(chanceSpinner, chanceSpinner.getValue().toString());
} else if (entryTypeBox.getSelectedItem() == ratio) {
listener.valueChanged(chanceSpinner, chanceSpinner.getValue().toString() + "/" + maxChanceSpinner.getValue().toString());
}
}
});
maxChanceSpinner.addChangeListener(new ChangeListener() {
@Override
public void stateChanged(ChangeEvent e) {
listener.valueChanged(chanceSpinner, chanceSpinner.getValue().toString() + "/" + maxChanceSpinner.getValue().toString());
}
});
nullify.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
chanceSpinner.setValue(1);
listener.valueChanged(chanceSpinner, null);
}
});
return chanceSpinner;
}
// public static JSpinner addDoubleField(JPanel pane, String label, Double initialValue, boolean editable) { // public static JSpinner addDoubleField(JPanel pane, String label, Double initialValue, boolean editable) {
// return addDoubleField(pane, label, initialValue, editable, nullListener); // return addDoubleField(pane, label, initialValue, editable, nullListener);
// } // }

View File

@@ -57,7 +57,7 @@ public class ExportProjectWizard extends JDialog {
radioGroup.add(asZip); radioGroup.add(asZip);
overSources = new JRadioButton("... into a game source folder"); overSources = new JRadioButton("... into a game source folder");
radioGroup.add(overSources); radioGroup.add(overSources);
asZip.setSelected(true); overSources.setSelected(true);
pane.add(asZip, JideBoxLayout.FIX); pane.add(asZip, JideBoxLayout.FIX);
pane.add(overSources, JideBoxLayout.FIX); pane.add(overSources, JideBoxLayout.FIX);

View File

@@ -30,6 +30,7 @@ public class ActorConditionEditor extends JSONElementEditor {
private JButton acIcon; private JButton acIcon;
private JTextField idField; private JTextField idField;
private JTextField nameField; private JTextField nameField;
private JTextField descriptionField;
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
private JComboBox categoryBox; private JComboBox categoryBox;
private IntegerBasedCheckBox positiveBox; private IntegerBasedCheckBox positiveBox;
@@ -81,6 +82,7 @@ public class ActorConditionEditor extends JSONElementEditor {
idField = addTextField(pane, "Internal ID: ", ac.id, ac.writable, listener); idField = addTextField(pane, "Internal ID: ", ac.id, ac.writable, listener);
nameField = addTranslatableTextField(pane, "Display name: ", ac.display_name, ac.writable, listener); nameField = addTranslatableTextField(pane, "Display name: ", ac.display_name, ac.writable, listener);
descriptionField = addTranslatableTextField(pane, "Description: ", ac.description, ac.writable, listener);
categoryBox = addEnumValueBox(pane, "Category: ", ActorCondition.ACCategory.values(), ac.category, ac.writable, listener); categoryBox = addEnumValueBox(pane, "Category: ", ActorCondition.ACCategory.values(), ac.category, ac.writable, listener);
positiveBox = addIntegerBasedCheckBox(pane, "Positive", ac.positive, ac.writable, listener); positiveBox = addIntegerBasedCheckBox(pane, "Positive", ac.positive, ac.writable, listener);
stackingBox = addIntegerBasedCheckBox(pane, "Stacking", ac.stacking, ac.writable, listener); stackingBox = addIntegerBasedCheckBox(pane, "Stacking", ac.stacking, ac.writable, listener);
@@ -172,6 +174,10 @@ public class ActorConditionEditor extends JSONElementEditor {
ActorConditionEditor.this.name = aCond.getDesc(); ActorConditionEditor.this.name = aCond.getDesc();
aCond.childrenChanged(new ArrayList<ProjectTreeNode>()); aCond.childrenChanged(new ArrayList<ProjectTreeNode>());
ATContentStudio.frame.editorChanged(ActorConditionEditor.this); ATContentStudio.frame.editorChanged(ActorConditionEditor.this);
}else if (source == descriptionField) {
aCond.description = (String) value;
aCond.childrenChanged(new ArrayList<ProjectTreeNode>());
ATContentStudio.frame.editorChanged(ActorConditionEditor.this);
} else if (source == acIcon) { } else if (source == acIcon) {
aCond.icon_id = (String) value; aCond.icon_id = (String) value;
aCond.childrenChanged(new ArrayList<ProjectTreeNode>()); aCond.childrenChanged(new ArrayList<ProjectTreeNode>());

View File

@@ -1,299 +1,205 @@
package com.gpl.rpg.atcontentstudio.ui.gamedataeditors; package com.gpl.rpg.atcontentstudio.ui.gamedataeditors;
import java.awt.Component; import java.awt.Component;
import java.awt.event.ActionEvent; import java.util.ArrayList;
import java.awt.event.ActionListener; import java.util.List;
import java.util.ArrayList;
import java.util.List; import javax.swing.DefaultListCellRenderer;
import java.util.concurrent.CopyOnWriteArrayList; import javax.swing.ImageIcon;
import javax.swing.JComponent;
import javax.swing.DefaultListCellRenderer; import javax.swing.JLabel;
import javax.swing.ImageIcon; import javax.swing.JList;
import javax.swing.JButton; import javax.swing.JPanel;
import javax.swing.JComponent; import javax.swing.JSpinner;
import javax.swing.JLabel; import javax.swing.JTextField;
import javax.swing.JList;
import javax.swing.JPanel; import com.gpl.rpg.atcontentstudio.ATContentStudio;
import javax.swing.JScrollPane; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import javax.swing.JSpinner; import com.gpl.rpg.atcontentstudio.model.Project;
import javax.swing.JTextField; import com.gpl.rpg.atcontentstudio.model.ProjectTreeNode;
import javax.swing.ListModel; import com.gpl.rpg.atcontentstudio.model.gamedata.Droplist;
import javax.swing.ListSelectionModel; import com.gpl.rpg.atcontentstudio.model.gamedata.Droplist.DroppedItem;
import javax.swing.event.ListDataEvent; import com.gpl.rpg.atcontentstudio.model.gamedata.Item;
import javax.swing.event.ListDataListener; import com.gpl.rpg.atcontentstudio.ui.CollapsiblePanel;
import javax.swing.event.ListSelectionEvent; import com.gpl.rpg.atcontentstudio.ui.FieldUpdateListener;
import javax.swing.event.ListSelectionListener; import com.gpl.rpg.atcontentstudio.ui.tools.CommonEditor;
import com.jidesoft.swing.JideBoxLayout;
import com.gpl.rpg.atcontentstudio.ATContentStudio;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; public class DroplistEditor extends JSONElementEditor {
import com.gpl.rpg.atcontentstudio.model.Project;
import com.gpl.rpg.atcontentstudio.model.ProjectTreeNode; private static final long serialVersionUID = 1139455254096811058L;
import com.gpl.rpg.atcontentstudio.model.gamedata.Droplist;
import com.gpl.rpg.atcontentstudio.model.gamedata.Droplist.DroppedItem; private static final String form_view_id = "Form";
import com.gpl.rpg.atcontentstudio.model.gamedata.Item; private static final String json_view_id = "JSON";
import com.gpl.rpg.atcontentstudio.ui.CollapsiblePanel;
import com.gpl.rpg.atcontentstudio.ui.DefaultIcons; private Droplist.DroppedItem selectedItem;
import com.gpl.rpg.atcontentstudio.ui.FieldUpdateListener;
import com.jidesoft.swing.JideBoxLayout; private JTextField idField;
private MyComboBox itemCombo;
public class DroplistEditor extends JSONElementEditor { private DroppedItemsListModel droppedItemsListModel;
private JSpinner qtyMinField;
private static final long serialVersionUID = 1139455254096811058L; private JSpinner qtyMaxField;
private JComponent chanceField;
private static final String form_view_id = "Form";
private static final String json_view_id = "JSON"; public DroplistEditor(Droplist droplist) {
super(droplist, droplist.getDesc(), droplist.getIcon());
private Droplist.DroppedItem selectedItem; addEditorTab(form_view_id, getFormView());
addEditorTab(json_view_id, getJSONView());
private JTextField idField; }
private MyComboBox itemCombo;
private DroppedItemsListModel droppedItemsListModel; @Override
private JSpinner qtyMinField; public void insertFormViewDataField(JPanel pane) {
private JSpinner qtyMaxField;
private JSpinner chanceField; final Droplist droplist = (Droplist)target;
final FieldUpdateListener listener = new DroplistFieldUpdater();
public DroplistEditor(Droplist droplist) {
super(droplist, droplist.getDesc(), droplist.getIcon()); createButtonPane(pane, droplist.getProject(), droplist, Droplist.class, Droplist.getImage(), null, listener);
addEditorTab(form_view_id, getFormView());
addEditorTab(json_view_id, getJSONView()); idField = addTextField(pane, "Droplist ID: ", droplist.id, droplist.writable, listener);
}
String title = "Items in this droplist: ";
@SuppressWarnings({ "rawtypes", "unchecked" }) DroppedItemsCellRenderer cellRenderer = new DroppedItemsCellRenderer();
@Override droppedItemsListModel = new DroppedItemsListModel(droplist);
public void insertFormViewDataField(JPanel pane) { final boolean moveUpDownEnabled = false;
final Droplist droplist = (Droplist)target; CollapsiblePanel itemsPane = CommonEditor.createListPanel(
final FieldUpdateListener listener = new DroplistFieldUpdater(); title,
cellRenderer,
createButtonPane(pane, droplist.getProject(), droplist, Droplist.class, Droplist.getImage(), null, listener); droppedItemsListModel,
droplist.writable,
idField = addTextField(pane, "Droplist ID: ", droplist.id, droplist.writable, listener); moveUpDownEnabled,
(e) -> selectedItem = e,
CollapsiblePanel itemsPane = new CollapsiblePanel("Items in this droplist: "); () -> selectedItem,
itemsPane.setLayout(new JideBoxLayout(itemsPane, JideBoxLayout.PAGE_AXIS)); this::updateDroppedItemsEditorPane,
droppedItemsListModel = new DroppedItemsListModel(droplist); listener,
final JList itemsList = new JList(droppedItemsListModel); Droplist.DroppedItem::new).panel;
itemsList.setCellRenderer(new DroppedItemsCellRenderer());
itemsList.setSelectionMode(ListSelectionModel.SINGLE_SELECTION); if (droplist.dropped_items == null || droplist.dropped_items.isEmpty()) {
itemsPane.add(new JScrollPane(itemsList), JideBoxLayout.FIX); itemsPane.collapse();
final JPanel droppedItemsEditorPane = new JPanel(); }
final JButton createDroppedItem = new JButton(new ImageIcon(DefaultIcons.getCreateIcon()));
final JButton deleteDroppedItem = new JButton(new ImageIcon(DefaultIcons.getNullifyIcon())); pane.add(itemsPane, JideBoxLayout.FIX);
deleteDroppedItem.setEnabled(false);
itemsList.addListSelectionListener(new ListSelectionListener() { }
@Override
public void valueChanged(ListSelectionEvent e) { public void updateDroppedItemsEditorPane(JPanel pane, DroppedItem di, FieldUpdateListener listener) {
selectedItem = (Droplist.DroppedItem) itemsList.getSelectedValue(); boolean writable = target.writable;
if (selectedItem == null) { Project proj = target.getProject();
deleteDroppedItem.setEnabled(false); pane.removeAll();
} else { if (itemCombo != null) {
deleteDroppedItem.setEnabled(true); removeElementListener(itemCombo);
} }
updateDroppedItemsEditorPane(droppedItemsEditorPane, selectedItem, listener); if (di != null) {
} itemCombo = addItemBox(pane, proj, "Item: ", di.item, writable, listener);
}); qtyMinField = addIntegerField(pane, "Quantity min: ", di.quantity_min, false, writable, listener);
if (droplist.writable) { qtyMaxField = addIntegerField(pane, "Quantity max: ", di.quantity_max, false, writable, listener);
JPanel listButtonsPane = new JPanel(); chanceField = addChanceField(pane, "Chance: ", di.chance, "100", writable, listener);//addDoubleField(pane, "Chance: ", di.chance, writable, listener);
listButtonsPane.setLayout(new JideBoxLayout(listButtonsPane, JideBoxLayout.LINE_AXIS, 6)); }
createDroppedItem.addActionListener(new ActionListener() { pane.revalidate();
@Override pane.repaint();
public void actionPerformed(ActionEvent e) { }
Droplist.DroppedItem tempItem = new Droplist.DroppedItem();
droppedItemsListModel.addItem(tempItem); public static class DroppedItemsListModel extends CommonEditor.AtListModel<Droplist.DroppedItem, Droplist> {
itemsList.setSelectedValue(tempItem, true);
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff. public DroppedItemsListModel(Droplist droplist) {
} super(droplist);
}); }
deleteDroppedItem.addActionListener(new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { protected List<Droplist.DroppedItem> getInner() {
if (selectedItem != null) { return source.dropped_items;
droppedItemsListModel.removeItem(selectedItem); }
selectedItem = null;
itemsList.clearSelection(); @Override
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff. protected void setInner(List<Droplist.DroppedItem> value) {
} source.dropped_items = value;
} }
}); }
listButtonsPane.add(createDroppedItem, JideBoxLayout.FIX); public static class DroppedItemsCellRenderer extends DefaultListCellRenderer {
listButtonsPane.add(deleteDroppedItem, JideBoxLayout.FIX); private static final long serialVersionUID = 7987880146189575234L;
listButtonsPane.add(new JPanel(), JideBoxLayout.VARY);
itemsPane.add(listButtonsPane, JideBoxLayout.FIX); @Override
} public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) {
droppedItemsEditorPane.setLayout(new JideBoxLayout(droppedItemsEditorPane, JideBoxLayout.PAGE_AXIS)); Component c = super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
itemsPane.add(droppedItemsEditorPane, JideBoxLayout.FIX); if (c instanceof JLabel) {
if (droplist.dropped_items == null || droplist.dropped_items.isEmpty()) { JLabel label = ((JLabel)c);
itemsPane.collapse(); Droplist.DroppedItem di = (Droplist.DroppedItem)value;
} if (di.item != null) {
label.setIcon(new ImageIcon(di.item.getIcon()));
pane.add(itemsPane, JideBoxLayout.FIX); label.setText(di.chance+(di.chance != null && di.chance.contains("/") ? "" : "%")+" to get "+di.quantity_min+"-"+di.quantity_max+" "+di.item.getDesc());
} else if (!isNull(di)) {
} label.setText(di.chance+(di.chance != null && di.chance.contains("/") ? "" : "%")+" to get "+di.quantity_min+"-"+di.quantity_max+" "+di.item_id);
} else {
public void updateDroppedItemsEditorPane(JPanel pane, DroppedItem di, FieldUpdateListener listener) { label.setText("New, undefined, dropped item.");
boolean writable = ((Droplist)target).writable; }
Project proj = ((Droplist)target).getProject(); }
pane.removeAll(); return c;
if (itemCombo != null) { }
removeElementListener(itemCombo);
} public boolean isNull(Droplist.DroppedItem item) {
if (di != null) { return ((item == null) || (
itemCombo = addItemBox(pane, proj, "Item: ", di.item, writable, listener); item.item == null &&
qtyMinField = addIntegerField(pane, "Quantity min: ", di.quantity_min, false, writable, listener); item.item_id == null &&
qtyMaxField = addIntegerField(pane, "Quantity max: ", di.quantity_max, false, writable, listener); item.quantity_min == null &&
chanceField = addDoubleField(pane, "Chance: ", di.chance, writable, listener); item.quantity_max == null &&
} item.chance == null
pane.revalidate(); ));
pane.repaint(); }
} }
public class DroppedItemsListModel implements ListModel<Droplist.DroppedItem> {
public class DroplistFieldUpdater implements FieldUpdateListener {
Droplist source; @Override
public void valueChanged(JComponent source, Object value) {
public DroppedItemsListModel(Droplist droplist) { Droplist droplist = ((Droplist)target);
this.source = droplist; if (source == idField) {
} //Events caused by cancel an ID edition. Dismiss.
if (skipNext) {
@Override skipNext = false;
public int getSize() { return;
if (source.dropped_items == null) return 0; }
return source.dropped_items.size(); if (target.id.equals(value)) return;
}
if (idChanging()) {
@Override droplist.id = (String) value;
public Droplist.DroppedItem getElementAt(int index) { DroplistEditor.this.name = droplist.getDesc();
if (source.dropped_items == null) return null; droplist.childrenChanged(new ArrayList<>());
return source.dropped_items.get(index); ATContentStudio.frame.editorChanged(DroplistEditor.this);
} } else {
cancelIdEdit(idField);
public void addItem(Droplist.DroppedItem item) { return;
if (source.dropped_items == null) { }
source.dropped_items = new ArrayList<Droplist.DroppedItem>(); } else if (source == itemCombo) {
} if (selectedItem.item != null) {
source.dropped_items.add(item); selectedItem.item.removeBacklink(droplist);
int index = source.dropped_items.indexOf(item); }
for (ListDataListener l : listeners) { selectedItem.item = (Item) value;
l.intervalAdded(new ListDataEvent(this, ListDataEvent.INTERVAL_ADDED, index, index)); if (selectedItem.item != null) {
} selectedItem.item_id = selectedItem.item.id;
} selectedItem.item.addBacklink(droplist);
} else {
public void removeItem(Droplist.DroppedItem item) { selectedItem.item_id = null;
int index = source.dropped_items.indexOf(item); }
source.dropped_items.remove(item); droppedItemsListModel.itemChanged(selectedItem);
if (source.dropped_items.isEmpty()) { } else if (source == qtyMinField) {
source.dropped_items = null; selectedItem.quantity_min = (Integer) value;
} droppedItemsListModel.itemChanged(selectedItem);
for (ListDataListener l : listeners) { } else if (source == qtyMaxField) {
l.intervalRemoved(new ListDataEvent(this, ListDataEvent.INTERVAL_REMOVED, index, index)); selectedItem.quantity_max = (Integer) value;
} droppedItemsListModel.itemChanged(selectedItem);
} } else if (source == chanceField) {
selectedItem.chance = (String) value;
public void itemChanged(Droplist.DroppedItem item) { droppedItemsListModel.itemChanged(selectedItem);
int index = source.dropped_items.indexOf(item); }
for (ListDataListener l : listeners) {
l.contentsChanged(new ListDataEvent(this, ListDataEvent.CONTENTS_CHANGED, index, index)); if (droplist.state != GameDataElement.State.modified) {
} droplist.state = GameDataElement.State.modified;
} DroplistEditor.this.name = droplist.getDesc();
droplist.childrenChanged(new ArrayList<>());
List<ListDataListener> listeners = new CopyOnWriteArrayList<ListDataListener>(); ATContentStudio.frame.editorChanged(DroplistEditor.this);
}
@Override updateJsonViewText(droplist.toJsonString());
public void addListDataListener(ListDataListener l) { }
listeners.add(l); }
} }
@Override
public void removeListDataListener(ListDataListener l) {
listeners.remove(l);
}
}
public static class DroppedItemsCellRenderer extends DefaultListCellRenderer {
private static final long serialVersionUID = 7987880146189575234L;
@Override
public Component getListCellRendererComponent(@SuppressWarnings("rawtypes") JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) {
Component c = super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if (c instanceof JLabel) {
JLabel label = ((JLabel)c);
Droplist.DroppedItem di = (Droplist.DroppedItem)value;
if (di.item != null) {
label.setIcon(new ImageIcon(di.item.getIcon()));
label.setText(di.chance+"% to get "+di.quantity_min+"-"+di.quantity_max+" "+di.item.getDesc());
} else if (!isNull(di)) {
label.setText(di.chance+"% to get "+di.quantity_min+"-"+di.quantity_max+" "+di.item_id);
} else {
label.setText("New, undefined, dropped item.");
}
}
return c;
}
public boolean isNull(Droplist.DroppedItem item) {
return ((item == null) || (
item.item == null &&
item.item_id == null &&
item.quantity_min == null &&
item.quantity_max == null &&
item.chance == null
));
}
}
public class DroplistFieldUpdater implements FieldUpdateListener {
@Override
public void valueChanged(JComponent source, Object value) {
Droplist droplist = ((Droplist)target);
if (source == idField) {
//Events caused by cancel an ID edition. Dismiss.
if (skipNext) {
skipNext = false;
return;
}
if (target.id.equals((String) value)) return;
if (idChanging()) {
droplist.id = (String) value;
DroplistEditor.this.name = droplist.getDesc();
droplist.childrenChanged(new ArrayList<ProjectTreeNode>());
ATContentStudio.frame.editorChanged(DroplistEditor.this);
} else {
cancelIdEdit(idField);
return;
}
} else if (source == itemCombo) {
if (selectedItem.item != null) {
selectedItem.item.removeBacklink(droplist);
}
selectedItem.item = (Item) value;
if (selectedItem.item != null) {
selectedItem.item_id = selectedItem.item.id;
selectedItem.item.addBacklink(droplist);
} else {
selectedItem.item_id = null;
}
droppedItemsListModel.itemChanged(selectedItem);
} else if (source == qtyMinField) {
selectedItem.quantity_min = (Integer) value;
droppedItemsListModel.itemChanged(selectedItem);
} else if (source == qtyMaxField) {
selectedItem.quantity_max = (Integer) value;
droppedItemsListModel.itemChanged(selectedItem);
} else if (source == chanceField) {
selectedItem.chance = (Double) value;
droppedItemsListModel.itemChanged(selectedItem);
}
if (droplist.state != GameDataElement.State.modified) {
droplist.state = GameDataElement.State.modified;
DroplistEditor.this.name = droplist.getDesc();
droplist.childrenChanged(new ArrayList<ProjectTreeNode>());
ATContentStudio.frame.editorChanged(DroplistEditor.this);
}
updateJsonViewText(droplist.toJsonString());
}
}
}

View File

@@ -1,29 +1,18 @@
package com.gpl.rpg.atcontentstudio.ui.gamedataeditors; package com.gpl.rpg.atcontentstudio.ui.gamedataeditors;
import java.awt.Component; import java.awt.Component;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.concurrent.CopyOnWriteArrayList;
import javax.swing.DefaultListCellRenderer; import javax.swing.DefaultListCellRenderer;
import javax.swing.ImageIcon; import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JComponent; import javax.swing.JComponent;
import javax.swing.JLabel; import javax.swing.JLabel;
import javax.swing.JList; import javax.swing.JList;
import javax.swing.JPanel; import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JSpinner; import javax.swing.JSpinner;
import javax.swing.JTextArea; import javax.swing.JTextArea;
import javax.swing.JTextField; import javax.swing.JTextField;
import javax.swing.ListModel;
import javax.swing.ListSelectionModel;
import javax.swing.event.ListDataEvent;
import javax.swing.event.ListDataListener;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import com.gpl.rpg.atcontentstudio.ATContentStudio; import com.gpl.rpg.atcontentstudio.ATContentStudio;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
@@ -31,9 +20,9 @@ import com.gpl.rpg.atcontentstudio.model.ProjectTreeNode;
import com.gpl.rpg.atcontentstudio.model.gamedata.Quest; import com.gpl.rpg.atcontentstudio.model.gamedata.Quest;
import com.gpl.rpg.atcontentstudio.model.gamedata.QuestStage; import com.gpl.rpg.atcontentstudio.model.gamedata.QuestStage;
import com.gpl.rpg.atcontentstudio.ui.CollapsiblePanel; import com.gpl.rpg.atcontentstudio.ui.CollapsiblePanel;
import com.gpl.rpg.atcontentstudio.ui.DefaultIcons;
import com.gpl.rpg.atcontentstudio.ui.FieldUpdateListener; import com.gpl.rpg.atcontentstudio.ui.FieldUpdateListener;
import com.gpl.rpg.atcontentstudio.ui.IntegerBasedCheckBox; import com.gpl.rpg.atcontentstudio.ui.IntegerBasedCheckBox;
import com.gpl.rpg.atcontentstudio.ui.tools.CommonEditor;
import com.jidesoft.swing.JideBoxLayout; import com.jidesoft.swing.JideBoxLayout;
public class QuestEditor extends JSONElementEditor { public class QuestEditor extends JSONElementEditor {
@@ -77,94 +66,26 @@ public class QuestEditor extends JSONElementEditor {
nameField = addTranslatableTextField(pane, "Quest Name: ", quest.name, quest.writable, listener); nameField = addTranslatableTextField(pane, "Quest Name: ", quest.name, quest.writable, listener);
visibleBox = addIntegerBasedCheckBox(pane, "Visible in quest log", quest.visible_in_log, quest.writable, listener); visibleBox = addIntegerBasedCheckBox(pane, "Visible in quest log", quest.visible_in_log, quest.writable, listener);
CollapsiblePanel stagesPane = new CollapsiblePanel("Quest stages: "); String title = "Quest stages: ";
stagesPane.setLayout(new JideBoxLayout(stagesPane, JideBoxLayout.PAGE_AXIS)); StagesCellRenderer cellRenderer = new StagesCellRenderer();
stagesListModel = new StagesListModel(quest); stagesListModel = new StagesListModel(quest);
stagesList = new JList<QuestStage>(stagesListModel); final boolean moveUpDownEnabled = true;
stagesList.setCellRenderer(new StagesCellRenderer());
stagesList.setSelectionMode(ListSelectionModel.SINGLE_SELECTION); CollapsiblePanel stagesPane = CommonEditor.createListPanel(
stagesPane.add(new JScrollPane(stagesList), JideBoxLayout.FIX); title,
final JPanel stagesEditorPane = new JPanel(); cellRenderer,
final JButton createStage = new JButton(new ImageIcon(DefaultIcons.getCreateIcon())); stagesListModel,
final JButton deleteStage = new JButton(new ImageIcon(DefaultIcons.getNullifyIcon())); quest.writable,
final JButton moveStageUp = new JButton(new ImageIcon(DefaultIcons.getArrowUpIcon())); moveUpDownEnabled,
final JButton moveStageDown = new JButton(new ImageIcon(DefaultIcons.getArrowDownIcon())); (e)->selectedStage=e,
deleteStage.setEnabled(false); ()->selectedStage,
moveStageUp.setEnabled(false); this::updateStageEditorPane,
moveStageDown.setEnabled(false); listener,
stagesList.addListSelectionListener(new ListSelectionListener() { ()->new QuestStage(quest)).panel;
@Override
public void valueChanged(ListSelectionEvent e) {
selectedStage = (QuestStage) stagesList.getSelectedValue();
if (selectedStage != null) {
deleteStage.setEnabled(true);
moveStageUp.setEnabled(stagesList.getSelectedIndex() > 0);
moveStageDown.setEnabled(stagesList.getSelectedIndex() < (stagesListModel.getSize() - 1));
} else {
deleteStage.setEnabled(false);
moveStageUp.setEnabled(false);
moveStageDown.setEnabled(false);
}
updateStageEditorPane(stagesEditorPane, selectedStage, listener);
}
});
if (quest.writable) {
JPanel listButtonsPane = new JPanel();
listButtonsPane.setLayout(new JideBoxLayout(listButtonsPane, JideBoxLayout.LINE_AXIS, 6));
createStage.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
QuestStage stage = new QuestStage(quest);
stagesListModel.addItem(stage);
stagesList.setSelectedValue(stage, true);
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff.
}
});
deleteStage.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (selectedStage != null) {
stagesListModel.removeItem(selectedStage);
selectedStage = null;
stagesList.clearSelection();
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff.
}
}
});
moveStageUp.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (selectedStage != null) {
stagesListModel.moveUp(selectedStage);
stagesList.setSelectedValue(selectedStage, true);
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff.
}
}
});
moveStageDown.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
if (selectedStage != null) {
stagesListModel.moveDown(selectedStage);
stagesList.setSelectedValue(selectedStage, true);
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff.
}
}
});
listButtonsPane.add(createStage, JideBoxLayout.FIX);
listButtonsPane.add(deleteStage, JideBoxLayout.FIX);
listButtonsPane.add(moveStageUp, JideBoxLayout.FIX);
listButtonsPane.add(moveStageDown, JideBoxLayout.FIX);
listButtonsPane.add(new JPanel(), JideBoxLayout.VARY);
stagesPane.add(listButtonsPane, JideBoxLayout.FIX);
}
if (quest.stages == null || quest.stages.isEmpty()) { if (quest.stages == null || quest.stages.isEmpty()) {
stagesPane.collapse(); stagesPane.collapse();
} }
stagesEditorPane.setLayout(new JideBoxLayout(stagesEditorPane, JideBoxLayout.PAGE_AXIS));
stagesPane.add(stagesEditorPane, JideBoxLayout.FIX);
pane.add(stagesPane, JideBoxLayout.FIX); pane.add(stagesPane, JideBoxLayout.FIX);
} }
@@ -184,88 +105,21 @@ public class QuestEditor extends JSONElementEditor {
pane.repaint(); pane.repaint();
} }
public static class StagesListModel implements ListModel<QuestStage> { public static class StagesListModel extends CommonEditor.AtListModel<QuestStage,Quest> {
Quest source;
public StagesListModel(Quest quest) { public StagesListModel(Quest quest) {
this.source = quest; super(quest);
}
@Override
public int getSize() {
if (source.stages == null) return 0;
return source.stages.size();
} }
@Override @Override
public QuestStage getElementAt(int index) { protected List<QuestStage> getInner() {
if (source.stages == null) return null; return source.stages;
return source.stages.get(index);
}
public void addItem(QuestStage item) {
if (source.stages == null) {
source.stages = new ArrayList<QuestStage>();
}
source.stages.add(item);
int index = source.stages.indexOf(item);
for (ListDataListener l : listeners) {
l.intervalAdded(new ListDataEvent(this, ListDataEvent.INTERVAL_ADDED, index, index));
}
}
public void removeItem(QuestStage item) {
int index = source.stages.indexOf(item);
source.stages.remove(item);
if (source.stages.isEmpty()) {
source.stages = null;
}
for (ListDataListener l : listeners) {
l.intervalRemoved(new ListDataEvent(this, ListDataEvent.INTERVAL_REMOVED, index, index));
}
}
public void itemChanged(QuestStage item) {
int index = source.stages.indexOf(item);
for (ListDataListener l : listeners) {
l.contentsChanged(new ListDataEvent(this, ListDataEvent.CONTENTS_CHANGED, index, index));
}
}
public void moveUp(QuestStage item) {
int index = source.stages.indexOf(item);
QuestStage exchanged = source.stages.get(index - 1);
source.stages.set(index, exchanged);
source.stages.set(index - 1, item);
for (ListDataListener l : listeners) {
l.contentsChanged(new ListDataEvent(this, ListDataEvent.CONTENTS_CHANGED, index - 1, index));
}
}
public void moveDown(QuestStage item) {
int index = source.stages.indexOf(item);
QuestStage exchanged = source.stages.get(index + 1);
source.stages.set(index, exchanged);
source.stages.set(index + 1, item);
for (ListDataListener l : listeners) {
l.contentsChanged(new ListDataEvent(this, ListDataEvent.CONTENTS_CHANGED, index, index + 1));
}
}
List<ListDataListener> listeners = new CopyOnWriteArrayList<ListDataListener>();
@Override
public void addListDataListener(ListDataListener l) {
listeners.add(l);
} }
@Override @Override
public void removeListDataListener(ListDataListener l) { protected void setInner(List<QuestStage> value) {
listeners.remove(l); source.stages = value;
} }
} }

View File

@@ -18,6 +18,7 @@ import javax.swing.JToolTip;
import javax.swing.SwingConstants; import javax.swing.SwingConstants;
import javax.swing.ToolTipManager; import javax.swing.ToolTipManager;
import com.gpl.rpg.atcontentstudio.ui.tools.CommonEditor;
import prefuse.Display; import prefuse.Display;
import prefuse.Visualization; import prefuse.Visualization;
import prefuse.action.ActionList; import prefuse.action.ActionList;
@@ -321,23 +322,7 @@ public class DialogueGraphView extends Display {
@Override @Override
protected String getText(VisualItem item) { protected String getText(VisualItem item) {
return wordWrap(super.getText(item), 40); return CommonEditor.wordWrap(super.getText(item), 40);
}
public String wordWrap(String in, int length) {
final String newline = "\n";
//:: Trim
while(in.length() > 0 && (in.charAt(0) == '\t' || in.charAt(0) == ' ')) in = in.substring(1);
//:: If Small Enough Already, Return Original
if(in.length() < length) return in;
//:: If Next length Contains Newline, Split There
if(in.substring(0, length).contains(newline)) return in.substring(0, in.indexOf(newline)).trim() + newline + wordWrap(in.substring(in.indexOf("\n") + 1), length);
//:: Otherwise, Split Along Nearest Previous Space/Tab/Dash
int spaceIndex = Math.max(Math.max( in.lastIndexOf(" ", length), in.lastIndexOf("\t", length)), in.lastIndexOf("-", length));
//:: If No Nearest Space, Split At length
if(spaceIndex == -1) spaceIndex = length;
//:: Split
return in.substring(0, spaceIndex).trim() + newline + wordWrap(in.substring(spaceIndex), length);
} }
} }

File diff suppressed because it is too large Load Diff

View File

@@ -521,16 +521,6 @@ public class WorldMapView extends JComponent implements Scrollable {
} }
worldmap.getProject().getMap(id).addBacklink(worldmap); worldmap.getProject().getMap(id).addBacklink(worldmap);
} }
List<String> toRemove = new ArrayList<String>();
for (String s : worldmap.labels.keySet()) {
if (!mapLocations.containsKey(s)) {
toRemove.add(s);
}
}
for (String s : toRemove) {
worldmap.labels.remove(s);
}
} }
} }

View File

@@ -1,43 +1,34 @@
package com.gpl.rpg.atcontentstudio.ui.sprites; package com.gpl.rpg.atcontentstudio.ui.sprites;
import java.awt.BorderLayout; import java.awt.*;
import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
import java.awt.Image;
import java.awt.Point;
import java.awt.event.ActionEvent; import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; import java.awt.event.ActionListener;
import java.awt.image.BufferedImage;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import javax.swing.*;
import javax.swing.ButtonGroup;
import javax.swing.ImageIcon;
import javax.swing.JDialog;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JToggleButton;
import javax.swing.ScrollPaneConstants;
import com.gpl.rpg.atcontentstudio.ATContentStudio; import com.gpl.rpg.atcontentstudio.ATContentStudio;
import com.gpl.rpg.atcontentstudio.model.Project; import com.gpl.rpg.atcontentstudio.model.Project;
import com.gpl.rpg.atcontentstudio.model.sprites.Spritesheet; import com.gpl.rpg.atcontentstudio.model.sprites.Spritesheet;
import com.gpl.rpg.atcontentstudio.model.sprites.Spritesheet.Category; import com.gpl.rpg.atcontentstudio.model.sprites.Spritesheet.Category;
import com.gpl.rpg.atcontentstudio.utils.SpriteUtils;
public class SpriteChooser extends JDialog { public class SpriteChooser extends JDialog {
private static final long serialVersionUID = -6018113265015159521L; private static final long serialVersionUID = -6018113265015159521L;
private static final int STD_WIDTH = 32; private static final int STD_WIDTH = 32;
private static final int STD_HEIGHT = 32; private static final int STD_HEIGHT = 32;
private static final int MAX_PER_ROW = 10; private static final int MAX_PER_ROW = 10;
public static Map<Project, Map<Spritesheet.Category, SpriteChooser>> cache = new LinkedHashMap<Project, Map<Spritesheet.Category,SpriteChooser>>(); public static Map<Project, Map<Spritesheet.Category, SpriteChooser>> cache = new LinkedHashMap<Project, Map<Spritesheet.Category, SpriteChooser>>();
public static Map<Project, Map<Spritesheet.Category, List<Spritesheet>>> cacheValidator = new LinkedHashMap<Project, Map<Category,List<Spritesheet>>>(); public static Map<Project, Map<Spritesheet.Category, List<Spritesheet>>> cacheValidator = new LinkedHashMap<Project, Map<Category, List<Spritesheet>>>();
public static SpriteChooser getChooser(Project proj, Spritesheet.Category category) { public static SpriteChooser getChooser(Project proj, Spritesheet.Category category) {
if (cache.get(proj) == null) { if (cache.get(proj) == null) {
cache.put(proj, new LinkedHashMap<Spritesheet.Category, SpriteChooser>()); cache.put(proj, new LinkedHashMap<Spritesheet.Category, SpriteChooser>());
@@ -46,13 +37,13 @@ public class SpriteChooser extends JDialog {
cache.get(proj).put(category, new SpriteChooser(proj, category)); cache.get(proj).put(category, new SpriteChooser(proj, category));
} else { } else {
List<Spritesheet> spritesheets = new ArrayList<Spritesheet>(); List<Spritesheet> spritesheets = new ArrayList<Spritesheet>();
for (int i=0; i<proj.getSpritesheetCount(); i++) { for (int i = 0; i < proj.getSpritesheetCount(); i++) {
Spritesheet sheet = proj.getSpritesheet(i); Spritesheet sheet = proj.getSpritesheet(i);
if (sheet.category == category) { if (sheet.category == category) {
spritesheets.add(sheet); spritesheets.add(sheet);
} }
} }
if ( !spritesheets.equals(cacheValidator.get(proj).get(category)) ) { if (!spritesheets.equals(cacheValidator.get(proj).get(category))) {
cache.get(proj).put(category, new SpriteChooser(proj, category)); cache.get(proj).put(category, new SpriteChooser(proj, category));
} }
} }
@@ -65,20 +56,20 @@ public class SpriteChooser extends JDialog {
wanted.pack(); wanted.pack();
return wanted; return wanted;
} }
private ButtonGroup group; private ButtonGroup group;
// private IconButton selectedOne = null; // private IconButton selectedOne = null;
// private JButton ok; // private JButton ok;
// private JButton cancel; // private JButton cancel;
public String selectedIconId = null; public String selectedIconId = null;
public SpriteChooser(Project proj, Category category) { public SpriteChooser(Project proj, Category category) {
super(ATContentStudio.frame); super(ATContentStudio.frame);
setTitle("Select a sprite"); setTitle("Select a sprite");
setModalityType(ModalityType.APPLICATION_MODAL); setModalityType(ModalityType.APPLICATION_MODAL);
List<Spritesheet> spritesheets = new ArrayList<Spritesheet>(); List<Spritesheet> spritesheets = new ArrayList<Spritesheet>();
for (int i=0; i<proj.getSpritesheetCount(); i++) { for (int i = 0; i < proj.getSpritesheetCount(); i++) {
Spritesheet sheet = proj.getSpritesheet(i); Spritesheet sheet = proj.getSpritesheet(i);
if (sheet.category == category) { if (sheet.category == category) {
spritesheets.add(sheet); spritesheets.add(sheet);
@@ -88,8 +79,8 @@ public class SpriteChooser extends JDialog {
cacheValidator.put(proj, new LinkedHashMap<Spritesheet.Category, List<Spritesheet>>()); cacheValidator.put(proj, new LinkedHashMap<Spritesheet.Category, List<Spritesheet>>());
} }
cacheValidator.get(proj).put(category, spritesheets); cacheValidator.get(proj).put(category, spritesheets);
JPanel pane = new JPanel(); JPanel pane = new JPanel();
pane.setLayout(new GridBagLayout()); pane.setLayout(new GridBagLayout());
GridBagConstraints c = new GridBagConstraints(); GridBagConstraints c = new GridBagConstraints();
@@ -101,16 +92,20 @@ public class SpriteChooser extends JDialog {
c.gridheight = 1; c.gridheight = 1;
c.anchor = GridBagConstraints.NORTHWEST; c.anchor = GridBagConstraints.NORTHWEST;
c.fill = GridBagConstraints.BOTH; c.fill = GridBagConstraints.BOTH;
List<Point> reservedSlots = new ArrayList<Point>(); List<Point> reservedSlots = new ArrayList<Point>();
Point nextFreeSlot = new Point(0, 0); Point nextFreeSlot = new Point(0, 0);
int i; int i;
Image img; BufferedImage img;
group = new ButtonGroup(); group = new ButtonGroup();
//For every sprite find a free space in panel:
for (Spritesheet sheet : spritesheets) { for (Spritesheet sheet : spritesheets) {
i = 0; i = -1;
while ((img = sheet.getImage(i)) != null) { while ((img = sheet.getImage(++i)) != null) {
if (SpriteUtils.checkIsImageEmpty(img)) {
continue;
}
IconButton button = new IconButton(img, sheet.id, i); IconButton button = new IconButton(img, sheet.id, i);
group.add(button); group.add(button);
if (sheet.spriteWidth == STD_WIDTH && sheet.spriteHeight == STD_HEIGHT) { if (sheet.spriteWidth == STD_WIDTH && sheet.spriteHeight == STD_HEIGHT) {
@@ -120,7 +115,7 @@ public class SpriteChooser extends JDialog {
c.gridx = 0; c.gridx = 0;
c.gridy++; c.gridy++;
} }
nextFreeSlot.setLocation(c.gridx, c.gridy); nextFreeSlot.setLocation(c.gridx, c.gridy);
} else { } else {
c.gridwidth = (sheet.spriteWidth / STD_WIDTH) + (sheet.spriteWidth % STD_WIDTH == 0 ? 0 : 1); c.gridwidth = (sheet.spriteWidth / STD_WIDTH) + (sheet.spriteWidth % STD_WIDTH == 0 ? 0 : 1);
c.gridheight = (sheet.spriteHeight / STD_HEIGHT) + (sheet.spriteHeight % STD_HEIGHT == 0 ? 0 : 1); c.gridheight = (sheet.spriteHeight / STD_HEIGHT) + (sheet.spriteHeight % STD_HEIGHT == 0 ? 0 : 1);
@@ -131,14 +126,20 @@ public class SpriteChooser extends JDialog {
for (int y = c.gridy; y < c.gridy + c.gridwidth; y++) { for (int y = c.gridy; y < c.gridy + c.gridwidth; y++) {
if (reservedSlots.contains(new Point(x, y))) { if (reservedSlots.contains(new Point(x, y))) {
slotOk = false; slotOk = false;
break;
} }
} }
if (!slotOk) {
break;
}
} }
if (slotOk && c.gridx + c.gridwidth > MAX_PER_ROW) { if (c.gridx + c.gridwidth > MAX_PER_ROW) {
c.gridx = 0; c.gridx = 0;
c.gridy++; c.gridy++;
slotOk = false; slotOk = false;
} } else if (!slotOk) {
c.gridx++;
}
} }
pane.add(button, c); pane.add(button, c);
for (int x = c.gridx; x < c.gridx + c.gridwidth; x++) { for (int x = c.gridx; x < c.gridx + c.gridwidth; x++) {
@@ -157,15 +158,14 @@ public class SpriteChooser extends JDialog {
c.gridx = 0; c.gridx = 0;
c.gridy++; c.gridy++;
} }
nextFreeSlot.setLocation(c.gridx, c.gridy); nextFreeSlot.setLocation(c.gridx, c.gridy);
} }
i++;
} }
} }
// ok = new JButton("Ok"); // ok = new JButton("Ok");
// cancel = new JButton("Cancel"); // cancel = new JButton("Cancel");
c.gridx = 0; c.gridx = 0;
boolean emptyLine = false; boolean emptyLine = false;
while (!emptyLine) { while (!emptyLine) {
@@ -178,7 +178,7 @@ public class SpriteChooser extends JDialog {
} }
} }
} }
// JPanel buttonPane = new JPanel(); // JPanel buttonPane = new JPanel();
// buttonPane.add(cancel, BorderLayout.WEST); // buttonPane.add(cancel, BorderLayout.WEST);
// buttonPane.add(ok, BorderLayout.EAST); // buttonPane.add(ok, BorderLayout.EAST);
@@ -190,7 +190,7 @@ public class SpriteChooser extends JDialog {
scroller.setHorizontalScrollBarPolicy(ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER); scroller.setHorizontalScrollBarPolicy(ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER);
wrapper.add(scroller, BorderLayout.CENTER); wrapper.add(scroller, BorderLayout.CENTER);
// wrapper.add(buttonPane, BorderLayout.SOUTH); // wrapper.add(buttonPane, BorderLayout.SOUTH);
// ok.addActionListener(new ActionListener() { // ok.addActionListener(new ActionListener() {
// @Override // @Override
// public void actionPerformed(ActionEvent e) { // public void actionPerformed(ActionEvent e) {
@@ -200,7 +200,7 @@ public class SpriteChooser extends JDialog {
// if (listener != null) listener.iconSelected(selectedIconId); // if (listener != null) listener.iconSelected(selectedIconId);
// } // }
// }); // });
// cancel.addActionListener(new ActionListener() { // cancel.addActionListener(new ActionListener() {
// @Override // @Override
// public void actionPerformed(ActionEvent e) { // public void actionPerformed(ActionEvent e) {
@@ -210,21 +210,21 @@ public class SpriteChooser extends JDialog {
// if (listener != null) listener.iconSelected(null); // if (listener != null) listener.iconSelected(null);
// } // }
// }); // });
setContentPane(wrapper); setContentPane(wrapper);
} }
private SpriteChooser.SelectionListener listener = null; private SpriteChooser.SelectionListener listener = null;
public void setSelectionListener(SpriteChooser.SelectionListener l) { public void setSelectionListener(SpriteChooser.SelectionListener l) {
listener = l; listener = l;
} }
public class IconButton extends JToggleButton { public class IconButton extends JToggleButton {
private static final long serialVersionUID = 7559407153561178455L; private static final long serialVersionUID = 7559407153561178455L;
public String sheetId; public String sheetId;
public int spriteIndex; public int spriteIndex;
@@ -232,12 +232,12 @@ public class SpriteChooser extends JDialog {
super(new ImageIcon(img)); super(new ImageIcon(img));
this.sheetId = sheetId; this.sheetId = sheetId;
this.spriteIndex = spriteIndex; this.spriteIndex = spriteIndex;
setToolTipText(sheetId+":"+spriteIndex); setToolTipText(sheetId + ":" + spriteIndex);
addActionListener(new ActionListener() { addActionListener(new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
if (IconButton.this.isSelected()) { if (IconButton.this.isSelected()) {
selectedIconId = IconButton.this.sheetId+":"+IconButton.this.spriteIndex; selectedIconId = IconButton.this.sheetId + ":" + IconButton.this.spriteIndex;
SpriteChooser.this.setVisible(false); SpriteChooser.this.setVisible(false);
SpriteChooser.this.dispose(); SpriteChooser.this.dispose();
if (listener != null) listener.iconSelected(selectedIconId); if (listener != null) listener.iconSelected(selectedIconId);
@@ -246,9 +246,9 @@ public class SpriteChooser extends JDialog {
}); });
} }
} }
public static interface SelectionListener { public static interface SelectionListener {
public void iconSelected(String selected); public void iconSelected(String selected);
} }
} }

View File

@@ -0,0 +1,282 @@
package com.gpl.rpg.atcontentstudio.ui.tools;
import com.gpl.rpg.atcontentstudio.ATContentStudio;
import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.gamedata.Common;
import com.gpl.rpg.atcontentstudio.ui.CollapsiblePanel;
import com.gpl.rpg.atcontentstudio.ui.DefaultIcons;
import com.gpl.rpg.atcontentstudio.ui.Editor;
import com.gpl.rpg.atcontentstudio.ui.FieldUpdateListener;
import com.gpl.rpg.atcontentstudio.utils.lambda.CallWithReturn;
import com.gpl.rpg.atcontentstudio.utils.lambda.CallWithSingleArg;
import com.gpl.rpg.atcontentstudio.utils.lambda.CallWithThreeArgs;
import com.jidesoft.swing.JideBoxLayout;
import javax.swing.*;
import javax.swing.event.ListDataEvent;
import javax.swing.event.ListDataListener;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CopyOnWriteArrayList;
public final class CommonEditor {
public static class PanelCreateResult<E>{
public CollapsiblePanel panel;
public JList<E> list;
}
public static <E, S> PanelCreateResult<E> createListPanel(String title,
ListCellRenderer<? super E> cellRenderer,
AtListModel<E, S> listModel,
boolean writable,
boolean moveUpDownEnabled,
CallWithSingleArg<E> selectedValueSetter,
CallWithReturn<E> selectedValueGetter,
CallWithThreeArgs<JPanel, E, FieldUpdateListener> updateRepliesEditorPane,
FieldUpdateListener listener,
CallWithReturn<E> createNew) {
CollapsiblePanel replies = new CollapsiblePanel(title);
replies.setLayout(new JideBoxLayout(replies, JideBoxLayout.PAGE_AXIS));
JList<E> repliesList = new JList<>(listModel);
repliesList.setCellRenderer(cellRenderer);
repliesList.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
replies.add(new JScrollPane(repliesList), JideBoxLayout.FIX);
final JPanel repliesEditorPane = new JPanel();
final JButton createReply = new JButton(new ImageIcon(DefaultIcons.getCreateIcon()));
final JButton deleteReply = new JButton(new ImageIcon(DefaultIcons.getNullifyIcon()));
final JButton moveReplyUp = new JButton(new ImageIcon(DefaultIcons.getArrowUpIcon()));
final JButton moveReplyDown = new JButton(new ImageIcon(DefaultIcons.getArrowDownIcon()));
deleteReply.setEnabled(false);
moveReplyUp.setEnabled(false);
moveReplyDown.setEnabled(false);
repliesList.addListSelectionListener(e -> {
E selectedReply = repliesList.getSelectedValue();
selectedValueSetter.call(selectedReply);
if (selectedReply != null) {
deleteReply.setEnabled(true);
if (moveUpDownEnabled) {
moveReplyUp.setEnabled(repliesList.getSelectedIndex() > 0);
moveReplyDown.setEnabled(repliesList.getSelectedIndex() < (listModel.getSize() - 1));
}
} else {
deleteReply.setEnabled(false);
if (moveUpDownEnabled) {
moveReplyUp.setEnabled(false);
moveReplyDown.setEnabled(false);
}
}
updateRepliesEditorPane.call(repliesEditorPane, selectedReply, listener);
});
repliesList.addMouseListener(new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
if (e.getClickCount() == 2) {
GameDataElement navObj = listModel.getNavigationElement( repliesList.getSelectedValue());
if (navObj != null) {
ATContentStudio.frame.openEditor(navObj);
ATContentStudio.frame.selectInTree(navObj);
}
}
}
});
repliesList.addKeyListener(new KeyAdapter() {
@Override
public void keyReleased(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ENTER) {
GameDataElement navObj = listModel.getNavigationElement( repliesList.getSelectedValue());
ATContentStudio.frame.openEditor(navObj);
ATContentStudio.frame.selectInTree(navObj);
}
}
});
if (writable) {
JPanel listButtonsPane = new JPanel();
listButtonsPane.setLayout(new JideBoxLayout(listButtonsPane, JideBoxLayout.LINE_AXIS, 6));
createReply.addActionListener(e -> {
E created = createNew.call();
listModel.addItem(created);
repliesList.setSelectedValue(created, true);
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff.
});
deleteReply.addActionListener(e -> {
E selected = selectedValueGetter.call();
if (selected != null) {
listModel.removeItem(selected);
selected = null;
selectedValueSetter.call(selected);
repliesList.clearSelection();
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff.
}
});
if (moveUpDownEnabled) {
moveReplyUp.addActionListener(e -> {
E selected = selectedValueGetter.call();
if (selected != null) {
listModel.moveUp(selected);
repliesList.setSelectedValue(selected, true);
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff.
}
});
moveReplyDown.addActionListener(e -> {
E selected = selectedValueGetter.call();
if (selected != null) {
listModel.moveDown(selected);
repliesList.setSelectedValue(selected, true);
listener.valueChanged(new JLabel(), null); //Item changed, but we took care of it, just do the usual notification and JSON update stuff.
}
});
}
listButtonsPane.add(createReply, JideBoxLayout.FIX);
listButtonsPane.add(deleteReply, JideBoxLayout.FIX);
if (moveUpDownEnabled) {
listButtonsPane.add(moveReplyUp, JideBoxLayout.FIX);
listButtonsPane.add(moveReplyDown, JideBoxLayout.FIX);
}
listButtonsPane.add(new JPanel(), JideBoxLayout.VARY);
replies.add(listButtonsPane, JideBoxLayout.FIX);
}
repliesEditorPane.setLayout(new JideBoxLayout(repliesEditorPane, JideBoxLayout.PAGE_AXIS));
replies.add(repliesEditorPane, JideBoxLayout.FIX);
PanelCreateResult<E> ePanelCreateResult = new PanelCreateResult<>();
ePanelCreateResult.panel =replies;
ePanelCreateResult.list = repliesList;
return ePanelCreateResult;
}
public static class CreateDeathEffectPanelResult {
public CollapsiblePanel panel;
public JSpinner HPMin;
public JSpinner HPMax;
public JSpinner APMin;
public JSpinner APMax;
}
public static CreateDeathEffectPanelResult createDeathEffectPanel(Common.DeathEffect hitEffect, boolean writable, FieldUpdateListener listener, String title){
CreateDeathEffectPanelResult result = new CreateDeathEffectPanelResult();
result.panel = new CollapsiblePanel(title);
result.panel.setLayout(new JideBoxLayout(result.panel, JideBoxLayout.PAGE_AXIS));
result.HPMin = Editor.addIntegerField(result.panel, "HP bonus min: ", hitEffect.hp_boost_min, true, writable, listener);
result.HPMax = Editor.addIntegerField(result.panel, "HP bonus max: ", hitEffect.hp_boost_max, true, writable, listener);
result.APMin = Editor.addIntegerField(result.panel, "AP bonus min: ", hitEffect.ap_boost_min, true, writable, listener);
result.APMax = Editor.addIntegerField(result.panel, "AP bonus max: ", hitEffect.ap_boost_max, true, writable, listener);
return result;
}
public static String wordWrap(String in, int length) {
if (in == null) return null;
final String newline = "\n";
//:: Trim
while (!in.isEmpty() && (in.charAt(0) == '\t' || in.charAt(0) == ' ')) in = in.substring(1);
//:: If Small Enough Already, Return Original
if (in.length() < length) return in;
//:: If Next length Contains Newline, Split There
if (in.substring(0, length).contains(newline))
return in.substring(0, in.indexOf(newline)).trim() + newline + wordWrap(in.substring(in.indexOf("\n") + 1), length);
//:: Otherwise, Split Along Nearest Previous Space/Tab/Dash
int spaceIndex = Math.max(Math.max(in.lastIndexOf(" ", length), in.lastIndexOf("\t", length)), in.lastIndexOf("-", length));
//:: If No Nearest Space, Split At length
if (spaceIndex == -1) spaceIndex = length;
//:: Split
return in.substring(0, spaceIndex).trim() + newline + wordWrap(in.substring(spaceIndex), length);
}
public abstract static class AtListModel<E, S> implements ListModel<E> {
protected S source;
protected abstract List<E> getInner();
protected abstract void setInner(List<E> value);
protected GameDataElement getNavigationElement(E element){
return null;
}
public AtListModel(S source) {
this.source = source;
}
@Override
public int getSize() {
if (getInner() == null) return 0;
return getInner().size();
}
@Override
public E getElementAt(int index) {
if (index < 0 || index >= getSize()) return null;
return getInner().get(index);
}
public void addItem(E item) {
if (getInner() == null) {
setInner(new ArrayList<>());
}
getInner().add(item);
int index = getInner().indexOf(item);
for (ListDataListener l : listeners) {
l.intervalAdded(new ListDataEvent(this, ListDataEvent.INTERVAL_ADDED, index, index));
}
}
public void removeItem(E item) {
int index = getInner().indexOf(item);
getInner().remove(item);
if (getInner().isEmpty()) {
setInner(null);
}
for (ListDataListener l : listeners) {
l.intervalRemoved(new ListDataEvent(this, ListDataEvent.INTERVAL_REMOVED, index, index));
}
}
public void itemChanged(E item) {
int index = getInner().indexOf(item);
for (ListDataListener l : listeners) {
l.contentsChanged(new ListDataEvent(this, ListDataEvent.CONTENTS_CHANGED, index, index));
}
}
public void moveUp(E item) {
int index = getInner().indexOf(item);
E exchanged = getInner().get(index - 1);
getInner().set(index, exchanged);
getInner().set(index - 1, item);
for (ListDataListener l : listeners) {
l.contentsChanged(new ListDataEvent(this, ListDataEvent.CONTENTS_CHANGED, index - 1, index));
}
}
public void moveDown(E item) {
int index = getInner().indexOf(item);
E exchanged = getInner().get(index + 1);
getInner().set(index, exchanged);
getInner().set(index + 1, item);
for (ListDataListener l : listeners) {
l.contentsChanged(new ListDataEvent(this, ListDataEvent.CONTENTS_CHANGED, index, index + 1));
}
}
List<ListDataListener> listeners = new CopyOnWriteArrayList<>();
@Override
public void addListDataListener(ListDataListener l) {
listeners.add(l);
}
@Override
public void removeListDataListener(ListDataListener l) {
listeners.remove(l);
}
}
}

View File

@@ -5,14 +5,7 @@ import java.util.List;
import com.gpl.rpg.atcontentstudio.model.GameDataElement; import com.gpl.rpg.atcontentstudio.model.GameDataElement;
import com.gpl.rpg.atcontentstudio.model.GameSource; import com.gpl.rpg.atcontentstudio.model.GameSource;
import com.gpl.rpg.atcontentstudio.model.gamedata.ActorCondition; import com.gpl.rpg.atcontentstudio.model.gamedata.*;
import com.gpl.rpg.atcontentstudio.model.gamedata.Dialogue;
import com.gpl.rpg.atcontentstudio.model.gamedata.Droplist;
import com.gpl.rpg.atcontentstudio.model.gamedata.Item;
import com.gpl.rpg.atcontentstudio.model.gamedata.ItemCategory;
import com.gpl.rpg.atcontentstudio.model.gamedata.NPC;
import com.gpl.rpg.atcontentstudio.model.gamedata.Quest;
import com.gpl.rpg.atcontentstudio.model.gamedata.Requirement;
import com.gpl.rpg.atcontentstudio.model.maps.ContainerArea; import com.gpl.rpg.atcontentstudio.model.maps.ContainerArea;
import com.gpl.rpg.atcontentstudio.model.maps.KeyArea; import com.gpl.rpg.atcontentstudio.model.maps.KeyArea;
import com.gpl.rpg.atcontentstudio.model.maps.MapChange; import com.gpl.rpg.atcontentstudio.model.maps.MapChange;
@@ -111,18 +104,18 @@ public class GDEVisitor {
visit(element.category, visited, includeSource); visit(element.category, visited, includeSource);
if (element.icon_id != null) visit(element.getProject().getSpritesheet(element.icon_id.split(":")[0]), visited, includeSource); if (element.icon_id != null) visit(element.getProject().getSpritesheet(element.icon_id.split(":")[0]), visited, includeSource);
if (element.equip_effect != null && element.equip_effect.conditions != null) { if (element.equip_effect != null && element.equip_effect.conditions != null) {
for (Item.ConditionEffect condEffect : element.equip_effect.conditions) { for (Common.ConditionEffect condEffect : element.equip_effect.conditions) {
visit(condEffect.condition, visited, includeSource); visit(condEffect.condition, visited, includeSource);
} }
} }
if (element.hit_effect != null) { if (element.hit_effect != null) {
if (element.hit_effect.conditions_source != null) { if (element.hit_effect.conditions_source != null) {
for (Item.ConditionEffect condEffect : element.hit_effect.conditions_source) { for (Common.ConditionEffect condEffect : element.hit_effect.conditions_source) {
visit(condEffect.condition, visited, includeSource); visit(condEffect.condition, visited, includeSource);
} }
} }
if (element.hit_effect.conditions_target != null) { if (element.hit_effect.conditions_target != null) {
for (Item.ConditionEffect condEffect : element.hit_effect.conditions_target) { for (Common.ConditionEffect condEffect : element.hit_effect.conditions_target) {
visit(condEffect.condition, visited, includeSource); visit(condEffect.condition, visited, includeSource);
} }
} }
@@ -144,12 +137,12 @@ public class GDEVisitor {
if (element.icon_id != null) visit(element.getProject().getSpritesheet(element.icon_id.split(":")[0]), visited, includeSource); if (element.icon_id != null) visit(element.getProject().getSpritesheet(element.icon_id.split(":")[0]), visited, includeSource);
if (element.hit_effect != null) { if (element.hit_effect != null) {
if (element.hit_effect.conditions_source != null) { if (element.hit_effect.conditions_source != null) {
for (NPC.TimedConditionEffect condEffect : element.hit_effect.conditions_source) { for (Common.TimedConditionEffect condEffect : element.hit_effect.conditions_source) {
visit(condEffect.condition, visited, includeSource); visit(condEffect.condition, visited, includeSource);
} }
} }
if (element.hit_effect.conditions_target != null) { if (element.hit_effect.conditions_target != null) {
for (NPC.TimedConditionEffect condEffect : element.hit_effect.conditions_target) { for (Common.TimedConditionEffect condEffect : element.hit_effect.conditions_target) {
visit(condEffect.condition, visited, includeSource); visit(condEffect.condition, visited, includeSource);
} }
} }

View File

@@ -37,7 +37,7 @@ public class ItemsTableView extends ElementTableView {
@Override @Override
public int getColumnCount() { public int getColumnCount() {
return 33; return 43;
} }
@Override @Override
@@ -62,20 +62,30 @@ public class ItemsTableView extends ElementTableView {
case 16: return "On kill - AP min"; case 16: return "On kill - AP min";
case 17: return "On kill - AP max"; case 17: return "On kill - AP max";
case 18: return "On kill - # conditions"; case 18: return "On kill - # conditions";
case 19: return "AD min"; case 19: return "On hit recv - HP min";
case 20: return "AD max"; case 20: return "On hit recv - HP max";
case 21: return "Max HP"; case 21: return "On hit recv - AP min";
case 22: return "Max AP"; case 22: return "On hit recv - AP max";
case 23: return "Attack cost"; case 23: return "On hit recv - # conditions";
case 24: return "AC"; case 24: return "On hit recv - Tgt HP min";
case 25: return "BC"; case 25: return "On hit recv - Tgt HP max";
case 26: return "DR"; case 26: return "On hit recv - Tgt AP min";
case 27: return "CS"; case 27: return "On hit recv - Tgt AP max";
case 28: return "CM"; case 28: return "AD min";
case 29: return "Move cost"; case 29: return "AD max";
case 30: return "Use cost"; case 30: return "Damage modifier %";
case 31: return "Reequip cost"; case 31: return "Max HP";
case 32: return "# conditions"; case 32: return "Max AP";
case 33: return "Attack cost";
case 34: return "AC";
case 35: return "BC";
case 36: return "DR";
case 37: return "CS";
case 38: return "CM";
case 39: return "Move cost";
case 40: return "Use cost";
case 41: return "Reequip cost";
case 42: return "# conditions";
} }
return null; return null;
} }
@@ -103,20 +113,30 @@ public class ItemsTableView extends ElementTableView {
case 16: return Integer.class;//"On kill - AP min"; case 16: return Integer.class;//"On kill - AP min";
case 17: return Integer.class;//"On kill - AP max"; case 17: return Integer.class;//"On kill - AP max";
case 18: return Integer.class;//"On kill - # conditions"; case 18: return Integer.class;//"On kill - # conditions";
case 19: return Integer.class;//"AD min"; case 19: return Integer.class;//"On hit recv - HP min";
case 20: return Integer.class;//"AD max"; case 20: return Integer.class;//"On hit recv - HP max";
case 21: return Integer.class;//"Max HP"; case 21: return Integer.class;//"On hit recv - AP min";
case 22: return Integer.class;//"Max AP"; case 22: return Integer.class;//"On hit recv - AP max";
case 23: return Integer.class;//"Attack cost"; case 23: return Integer.class;//"On hit recv - # conditions";
case 24: return Integer.class;//"AC"; case 24: return Integer.class;//"On hit recv - Tgt HP min";
case 25: return Integer.class;//"BC"; case 25: return Integer.class;//"On hit recv - Tgt HP max";
case 26: return Integer.class;//"DR"; case 26: return Integer.class;//"On hit recv - Tgt AP min";
case 27: return Integer.class;//"CS"; case 27: return Integer.class;//"On hit recv - Tgt AP max";
case 28: return Double.class;//"CM"; case 28: return Integer.class;//"AD min";
case 29: return Integer.class;//"Move cost"; case 29: return Integer.class;//"AD max";
case 30: return Integer.class;//"Use cost"; case 30: return Integer.class;//"Damage modifier";
case 31: return Integer.class;//"Reequip cost"; case 31: return Integer.class;//"Max HP";
case 32: return Integer.class;//"# conditions"; case 32: return Integer.class;//"Max AP";
case 33: return Integer.class;//"Attack cost";
case 34: return Integer.class;//"AC";
case 35: return Integer.class;//"BC";
case 36: return Integer.class;//"DR";
case 37: return Integer.class;//"CS";
case 38: return Double.class;//"CM";
case 39: return Integer.class;//"Move cost";
case 40: return Integer.class;//"Use cost";
case 41: return Integer.class;//"Reequip cost";
case 42: return Integer.class;//"# conditions";
} }
return null; return null;
} }
@@ -177,20 +197,30 @@ public class ItemsTableView extends ElementTableView {
case 16: return (!canUse && item.kill_effect != null) ? item.kill_effect.ap_boost_min : null;//"On kill - AP min"; case 16: return (!canUse && item.kill_effect != null) ? item.kill_effect.ap_boost_min : null;//"On kill - AP min";
case 17: return (!canUse && item.kill_effect != null) ? item.kill_effect.ap_boost_max : null;//"On kill - AP max"; case 17: return (!canUse && item.kill_effect != null) ? item.kill_effect.ap_boost_max : null;//"On kill - AP max";
case 18: return (!canUse && item.kill_effect != null && item.kill_effect.conditions_source != null) ? item.kill_effect.conditions_source.size() : null;//"On kill - # conditions"; case 18: return (!canUse && item.kill_effect != null && item.kill_effect.conditions_source != null) ? item.kill_effect.conditions_source.size() : null;//"On kill - # conditions";
case 19: return (canEquip && item.equip_effect != null) ? item.equip_effect.damage_boost_min : null;//"AD min"; case 19: return (!canUse && item.hit_received_effect != null) ? item.hit_received_effect.hp_boost_min : null;//"On hit recv - HP min";
case 20: return (canEquip && item.equip_effect != null) ? item.equip_effect.damage_boost_max : null;//"AD max"; case 20: return (!canUse && item.hit_received_effect != null) ? item.hit_received_effect.hp_boost_max : null;//"On hit recv - HP max";
case 21: return (canEquip && item.equip_effect != null) ? item.equip_effect.max_hp_boost : null;//"Max HP"; case 21: return (!canUse && item.hit_received_effect != null) ? item.hit_received_effect.ap_boost_min : null;//"On hit recv - AP min";
case 22: return (canEquip && item.equip_effect != null) ? item.equip_effect.max_ap_boost : null;//"Max AP"; case 22: return (!canUse && item.hit_received_effect != null) ? item.hit_received_effect.ap_boost_max : null;//"On hit recv - AP max";
case 23: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_attack_cost : null;//"Attack cost"; case 23: return (!canUse && item.hit_received_effect != null && item.hit_received_effect.conditions_source != null) ? item.hit_received_effect.conditions_source.size() : null;//"On hit recv - # conditions";
case 24: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_attack_chance : null;//"AC"; case 24: return (!canUse && item.hit_received_effect != null) ? item.hit_received_effect.hp_boost_min : null;//"On hit recv - Tgt HP min";
case 25: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_block_chance : null;//"BC"; case 25: return (!canUse && item.hit_received_effect != null) ? item.hit_received_effect.hp_boost_max : null;//"On hit recv - Tgt HP max";
case 26: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_damage_resistance : null;//"DR"; case 26: return (!canUse && item.hit_received_effect != null) ? item.hit_received_effect.ap_boost_min : null;//"On hit recv - Tgt AP min";
case 27: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_critical_skill : null;//"CS"; case 27: return (!canUse && item.hit_received_effect != null) ? item.hit_received_effect.ap_boost_max : null;//"On hit recv - Tgt AP max";
case 28: return (canEquip && item.equip_effect != null) ? item.equip_effect.critical_multiplier : null;//"CM"; case 28: return (canEquip && item.equip_effect != null) ? item.equip_effect.damage_boost_min : null;//"AD min";
case 29: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_move_cost : null;//"Move cost"; case 29: return (canEquip && item.equip_effect != null) ? item.equip_effect.damage_boost_max : null;//"AD max";
case 30: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_use_item_cost : null;//"Use cost"; case 30: return (canEquip && item.equip_effect != null) ? item.equip_effect.damage_modifier : null;//"Damage modifier";
case 31: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_reequip_cost : null;//"Reequip cost"; case 31: return (canEquip && item.equip_effect != null) ? item.equip_effect.max_hp_boost : null;//"Max HP";
case 32: return (canEquip && item.equip_effect != null && item.equip_effect.conditions != null) ? item.equip_effect.conditions.size() : null;//"# conditions"; case 32: return (canEquip && item.equip_effect != null) ? item.equip_effect.max_ap_boost : null;//"Max AP";
case 33: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_attack_cost : null;//"Attack cost";
case 34: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_attack_chance : null;//"AC";
case 35: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_block_chance : null;//"BC";
case 36: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_damage_resistance : null;//"DR";
case 37: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_critical_skill : null;//"CS";
case 38: return (canEquip && item.equip_effect != null) ? item.equip_effect.critical_multiplier : null;//"CM";
case 39: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_move_cost : null;//"Move cost";
case 40: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_use_item_cost : null;//"Use cost";
case 41: return (canEquip && item.equip_effect != null) ? item.equip_effect.increase_reequip_cost : null;//"Reequip cost";
case 42: return (canEquip && item.equip_effect != null && item.equip_effect.conditions != null) ? item.equip_effect.conditions.size() : null;//"# conditions";
} }
return null; return null;
} }

View File

@@ -27,6 +27,7 @@ import javax.swing.JTextArea;
import javax.swing.KeyStroke; import javax.swing.KeyStroke;
import javax.swing.plaf.basic.BasicInternalFrameUI; import javax.swing.plaf.basic.BasicInternalFrameUI;
import com.gpl.rpg.atcontentstudio.ui.tools.CommonEditor;
import prefuse.Display; import prefuse.Display;
import prefuse.Visualization; import prefuse.Visualization;
import prefuse.action.Action; import prefuse.action.Action;
@@ -415,25 +416,9 @@ public class WriterModeEditor extends Editor {
@Override @Override
protected String getText(VisualItem item) { protected String getText(VisualItem item) {
if (!item.getBoolean(IS_REPLY) && super.getText(item) == null) return "[Selector]"; if (!item.getBoolean(IS_REPLY) && super.getText(item) == null) return "[Selector]";
return wordWrap(super.getText(item), 40); return CommonEditor.wordWrap(super.getText(item), 40);
}
public String wordWrap(String in, int length) {
if (in == null) return null;
final String newline = "\n";
//:: Trim
while(in.length() > 0 && (in.charAt(0) == '\t' || in.charAt(0) == ' ')) in = in.substring(1);
//:: If Small Enough Already, Return Original
if(in.length() < length) return in;
//:: If Next length Contains Newline, Split There
if(in.substring(0, length).contains(newline)) return in.substring(0, in.indexOf(newline)).trim() + newline + wordWrap(in.substring(in.indexOf("\n") + 1), length);
//:: Otherwise, Split Along Nearest Previous Space/Tab/Dash
int spaceIndex = Math.max(Math.max( in.lastIndexOf(" ", length), in.lastIndexOf("\t", length)), in.lastIndexOf("-", length));
//:: If No Nearest Space, Split At length
if(spaceIndex == -1) spaceIndex = length;
//:: Split
return in.substring(0, spaceIndex).trim() + newline + wordWrap(in.substring(spaceIndex), length);
} }
} }
class NodeStrokeColorAction extends ColorAction { class NodeStrokeColorAction extends ColorAction {

View File

@@ -0,0 +1,34 @@
package com.gpl.rpg.atcontentstudio.utils;
import java.awt.image.BufferedImage;
import java.awt.image.WritableRaster;
public final class SpriteUtils {
/**
* Check if the image is empty (transparent )
*
* @param img The image to check
* @return true if the image is empty
*/
public static boolean checkIsImageEmpty(BufferedImage img) {
int width = img.getWidth(null);
int height = img.getHeight(null);
WritableRaster raster = img.getAlphaRaster();
if (raster == null) {
return false;
}
for (int x = 0; x < width; x++) {
for (int y = 0; y < height; y++) {
//get pixel alpha value
int alpha = raster.getSample(x, y, 0);
//if alpha is not 0 then the pixel is not transparent
if (alpha != 0) {
return false;
}
}
}
//no non-transparent pixel found
return true;
}
}

View File

@@ -0,0 +1,5 @@
package com.gpl.rpg.atcontentstudio.utils.lambda;
public interface CallWithReturn<T> {
T call();
}

View File

@@ -0,0 +1,7 @@
package com.gpl.rpg.atcontentstudio.utils.lambda;
public interface CallWithSingleArg<T> {
void call(T arg);
}

View File

@@ -0,0 +1,5 @@
package com.gpl.rpg.atcontentstudio.utils.lambda;
public interface CallWithThreeArgs<T1, T2, T3> {
void call(T1 arg1, T2 arg2, T3 arg3);
}

View File

@@ -0,0 +1,6 @@
package com.gpl.rpg.atcontentstudio.utils.lambda;
public interface CallWithTwoArgs<T1, T2> {
void call(T1 arg1, T2 arg2);
}

View File

@@ -12,6 +12,8 @@ import java.io.BufferedReader;
import java.io.File; import java.io.File;
import java.io.FileReader; import java.io.FileReader;
import java.io.IOException; import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.util.Vector; import java.util.Vector;
public class POParser public class POParser
@@ -60,11 +62,9 @@ public class POParser
POFile result = null; POFile result = null;
try try
{ {
FileReader fr = new FileReader(file); BufferedReader br = Files.newBufferedReader(file.toPath(), StandardCharsets.UTF_8);
BufferedReader br = new BufferedReader(fr);
result = parse(br); result = parse(br);
br.close(); br.close();
fr.close();
} }
catch (java.io.FileNotFoundException e) catch (java.io.FileNotFoundException e)
{ {