tutorial:codec
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
tutorial:codec [2024/06/30 13:20] – solidblock | tutorial:codec [2024/06/30 14:16] (current) – solidblock | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== | + | ====== |
===== What is a codec ===== | ===== What is a codec ===== | ||
- | A **codec**, introduced in Java Edition 1.16, is a specification of conversion between any type of object (such as '' | + | A **codec**, introduced in Java Edition 1.16, is a specification of conversion between any type of object (such as '' |
- | For example, loot tables are written in json forms in data packs, and are loaded as '' | + | For example, loot tables are written in json forms in data packs, and are loaded as '' |
- | Codec was introduced in 1.16, but has mainly been increasingly widely used in Minecraft since 1.20. For example, '' | + | Codec was introduced in 1.16, but has mainly been increasingly widely used in Minecraft since 1.20. For example, '' |
===== Using a codec ===== | ===== Using a codec ===== | ||
Line 25: | Line 25: | ||
</ | </ | ||
- | As seen in the code, the result is not directly '' | + | As seen in the code, the result is not directly '' |
<code java> | <code java> | ||
- | // get the result when succeed | + | // get the result when succeeded |
final NbtList nbtList = new NbtList(); | final NbtList nbtList = new NbtList(); | ||
nbtList.add(NbtInt.of(1)); | nbtList.add(NbtInt.of(1)); | ||
Line 41: | Line 41: | ||
</ | </ | ||
- | There is a special type of '' | + | There is a special type of '' |
===== Writing a codec ===== | ===== Writing a codec ===== | ||
Line 57: | Line 57: | ||
* '' | * '' | ||
- | Besides, '' | + | Besides, '' |
* '' | * '' | ||
* '' | * '' | ||
Line 63: | Line 63: | ||
> **Tips:** You can learn more about how to write codecs by seeing how vanilla codecs are written. | > **Tips:** You can learn more about how to write codecs by seeing how vanilla codecs are written. | ||
+ | |||
==== Mapping existing codec ==== | ==== Mapping existing codec ==== | ||
Line 101: | Line 102: | ||
==== Record codec ==== | ==== Record codec ==== | ||
=== Required fields === | === Required fields === | ||
- | Most objects are complicated, | + | Most objects are complicated, |
<code java> | <code java> | ||
public record Student(String name, int id, Vec3d pos) { | public record Student(String name, int id, Vec3d pos) { | ||
Line 167: | Line 168: | ||
} | } | ||
</ | </ | ||
- | Writing like this may be simpler. You need to specify the method to convert fields to an objects at first ('' | + | Writing like this may be simpler. You need to specify the method to convert fields to an objects at first ('' |
==== Dispatching codec ==== | ==== Dispatching codec ==== | ||
Some objects may not be in fixed structures, but have variant types, each of which, is in a unique structure. Therefore, dispatching codecs are used. | Some objects may not be in fixed structures, but have variant types, each of which, is in a unique structure. Therefore, dispatching codecs are used. | ||
Line 243: | Line 244: | ||
===== Packet codec ===== | ===== Packet codec ===== | ||
- | A **packet codec**, different from codec, converts between objects and binery packets. It is sometimes similar to codec, and also used in many cases such as item components, but for complex objects, it uses //tuples// instead of //maps//. We can also use '' | + | A **packet codec**, different from codec, converts between objects and binery packets. It is sometimes similar to codec, and also used in many cases such as item components, but for complex objects, it uses //tuples// instead of //maps//. Packet codecs for primitive types are stored in '' |
<code java> | <code java> | ||
public record Student(String name, int id, Vec3d pos) { | public record Student(String name, int id, Vec3d pos) { | ||
Line 259: | Line 260: | ||
</ | </ | ||
+ | > **Note:** Besides '' |
tutorial/codec.1719753632.txt.gz · Last modified: 2024/06/30 13:20 by solidblock