答案 0 :(得分:1)
解决方案1:
转换为标准Java数组。由于Array实际上只是标准Java数组的包装器,因此我们不会丢失转换它的数据,Gson可以轻松地为我们处理标准数组的序列化和反序列化。
Array<Human> array = new Array<Human>();
array.add(new Human("Jack"));
array.add(new Human("Tom"));
array.add(new Human("Mel"));
array.add(new Human("Anne"));
Gdx.app.log("JSON", "To json");
for (Human human : array) {
Gdx.app.log("Human", human.name);
}
Gson gson = new Gson();
String json = gson.toJson(array.toArray(), Human[].class);
Array<Human> arrayFromJson = new Array<Human>(gson.fromJson(json, Human[].class));
Gdx.app.log("JSON", "From json");
for (Human human : arrayFromJson) {
Gdx.app.log("Human", human.name);
}
输出:
JSON: To json
Human: Jack
Human: Tom
Human: Mel
Human: Anne
JSON: From json
Human: Jack
Human: Tom
Human: Mel
Human: Anne
解决方案2:
如果在某种对象中有Array<Human>
,则需要手动将Java数组转换为LibGDX数组,这将有点混乱。
编写自己的序列化程序是解决此问题的方法,但使用泛型编写序列化程序很复杂,但可能。
最难的部分是解串器:
public class ArrayDeserializer<T> implements JsonDeserializer<Array<T>> {
Class<T[]> tClass;
public ArrayDeserializer(Class<T[]> tClass) {
this.tClass = tClass;
}
@Override
public Array<T> deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
T[] objects = context.deserialize(json, tClass);
return new Array<T>(objects);
}
}
Serializer非常愚蠢。
public class ArraySerializer implements JsonSerializer<Array> {
@Override
public JsonElement serialize(Array src, Type typeOfSrc, JsonSerializationContext context) {
return context.serialize(src.toArray(), src.toArray().getClass());
}
}
然后在代码中使用:
Type type = TypeToken.get(array.getClass()).getType(); //Array<Human>
...
gsonBuilder.registerTypeAdapter(type, new ArrayDeserializer<Human>(Human[].class));
gsonBuilder.registerTypeAdapter(type, new ArraySerializer());
然后构建新的Gson实例,该实例能够序列化libGDX的数组。