최근 수정 시각 : 2024-04-17 19:28:55

마인크래프트/팩/데이터 팩

파일:상위 문서 아이콘.svg   상위 문서: 마인크래프트/팩

파일:마인크래프트 로고.svg
{{{#!wiki style="margin: -0px -10px -5px"
{{{#!folding [ 펼치기 · 접기 ]
{{{#!wiki style="margin: -6px -1px -11px"
<colbgcolor=darkgreen><colcolor=#fff> 기본 플레이
시스템세계 · 게임 모드 · 난이도 · 게임 규칙 · 엔딩 · 죽음 메시지 · 스플래시 · 명령어 · NBT
인게임아이템 · · 개체 · 날씨 · 차원 · 생물군계 · 구조물 · 마법 부여 · 상태 효과 · 조작법 · 피해 · 발전 과제
도움말튜토리얼 · (탐험 · 파밍 · 회로) · 브릿징 · PVP · 파쿠르 · 스피드런 · 건축
시리즈 및 매체
출시 에디션자바 에디션 (업데이트) · 베드락 에디션 (업데이트) · 포켓 에디션* · 콘솔 에디션* · 파이 에디션*
파생 게임Minecraft Dungeons* · Minecraft Legends* · Minecraft Education · Minecraft: Story Mode* · Minecraft Earth*
미디어OST · 관련 서적 · 레고 · 더 무비 · Minecraft Live · Minecraft Now · Minecraft Monthly
유저 콘텐츠
창작 요소2차 창작 · 망토 · · 모드 (개발 · · 모드팩) · 애드온 · (리소스 팩 · 데이터 팩) · 외부 프로그램 ·
멀티 콘텐츠멀티플레이 · 서버 · 플러그인 · Realms · EULA
개발개발 기초 · 모드 개발 · 플러그인 개발
기타
이야깃거리여담 · 커뮤니티 · 사건사고 · 문제점 · 용어 · 지원 언어 · 머나먼 땅 · 이미테이션 게임
관련 문서나무위키 마인크래프트 프로젝트 · 마인크래프트로 분류된 문서 · 마인크래프트의 하위 문서
* 표시는 서비스가 종료되었거나 개발이 중단되었다는 표시이다. }}}}}}}}}
<nopad> 본 위키는 공식 MINECRAFT 서비스가 아닙니다. 이용에 참고 바랍니다.

1. 개요2. 제작
2.1. pack.mcmeta2.2. functions 작성법
3. 기능
3.1. advancements / 발전 과제3.2. chat type / 대화3.3. dimension / 차원
3.3.1. dimension_type
3.4. functions / 함수
3.4.1. 매크로 기능
3.5. item modifier / 아이템 수정자3.6. loot_tables / 드롭 아이템3.7. predicates / 술어 3.8. recipes / 조합법3.9. structures / 구조물3.10. worldgen
3.10.1. biome / 생물 군계
4. 유저 표준5. 목록6. 변경 내역
6.1. 1.206.2. 1.196.3. 1.186.4. 1.176.5. 1.166.6. 1.156.7. 1.146.8. 1.13

1. 개요

데이터 팩은 마인크래프트의 데이터들을 바꿀 수 있는 시스템이다. 스냅샷 17w43a부터 추가되었다. 별도의 모드로더 필요 없이 발전 과제, 함수, 드롭 아이템, 구조물, 조합법, 태그를 바꾸거나 추가할 수 있다. 맵 폴더 안에다가 data라는 이름의 폴더를 또 추가하여 폴더 형식의 데이터 팩을 넣은 다음 /datapack 명령어로 활성화하면 된다.

2. 제작

데이터 팩 파일은 .minecraft/saves/(월드)/datapacks에다 파일을 만들어야 한다. 폴더 이름은 라틴 문자로 지어야 한다. 그리고 data 폴더 안에 또 namespace에 해당하는 폴더를 만들어야 한다. 만약에 main이라는 폴더를 만들었을 경우 functions로 예를 들자면 function main/함수 이름이다.

예를 들어,
world 라는 이름의 월드에 나만의 조합법을 만들어서 플레이하고 싶다면
.minecraft > saves > world > datapacks > (파일이름) > data > crafting > recipes > 원하는 조합법.json
이렇게 넣어야만 데이터 팩을 사용할 수 있다.

===# 폴더 구조 #===
  • (데이터 팩 이름)
    • pack.mcmeta
    • pack.png
    • data
      • (namespace)
        • advancements
          • (advancement).json
        • chat_type
          • (advancement).json
        • damage_type
          • (damage_type).json
        • datapacks
        • dimension
          • (dimension).json
        • dimension_type
          • (dimension type).json
        • functions
          • (function).mcfunction
        • loot_tables
          • (loot_table).json
        • recipes
          • (recipe).json
        • predicates
          • (predicate).json
        • structures
          • (structure).nbt
        • tags
          • banner_pattern
            • (tag).json
          • blocks
            • (tag).json
          • cat_variant
            • (tag).json
          • entity_types
            • (tag).json
          • damage_type
            • (tag).json
          • fluids
            • (tag).json
          • functions
            • (tag).json
          • items
            • (tag).json
        • worldgen
          • biome
            • (biome).json
          • configured_carver
            • (configured_carver).json
          • configured_feature
            • (configured_feature).json
          • configured_structure_feature
            • (configured_structure_feature).json
          • configured_surface_builde
            • (configured_surface_builder).json
          • processor_list
            • (processor_list).json
          • template_pool
            • (template_pool).json
        • item_modifiers(1.17 JE)
          • (item_modifiers).json(1.17 JE)

2.1. pack.mcmeta

데이터 팩 파일 안에는 pack.mcmeta라는 파일을 만들어 주면 된다. 이 파일은 JSON 형식으로 되어있는데, 리소스팩 제작 때 필수로 넣어야 하는 것이다. 이 과정에서 오류가 발생하면 데이터 팩을 불러오지 못한다. 파일 확장자명이 안 보인다면 윈도우 기준으로 파일 탐색기에서 위에 있는 보기를 눌러준 다음에 파일 확장명을 체크 표시해주면 된다. 이 과정을 정상적으로 끝마치면 다음 코드를 작성하면 된다.
#!syntax json
{
  "pack": {
    "pack_format": 1,
    "description": "namuwiki -- 여기는 나무위키를 지우고 자기가 원하는 글을 쓰면 데이터 팩의 설명이 된다."
  }
}
다중 버전을 지원하는 팩을 만드려면 다음과 같이 작성한다. 작성 예시는 1.20.2부터 1.20.4까지 버전을 지원할 경우이다.(이 기능은 1.20.2부터 추가되었다.)
#!syntax json
{
  "pack": {
    "pack_format": 26,
    "supported_formats":{
      "min_inclusive":18,
      "max_inclusive":26
    },
    "description": "데이터 팩의 설명"
  }
}
중요: pack_format 값은 데이터 팩을 적용할 마인크래프트 버전에 따라 다르게 설정해야 된다. 값은 다음과 같다.
26 1.20.3 ~ 1.20.4
18 1.20.2
15 1.20 ~ 1.20.1
12 1.19.4(23w06a)
10 1.19 ~ 1.19.3
9 1.18.2
8 1.18 ~ 1.18.1
7 1.17 ~ 1.17.1
6 1.16.2 ~ 1.16.5
5 1.15 ~ 1.16.1
4 1.13 ~ 1.14.4

2.2. functions 작성법

말 그대로 함수로 플레이어가 명령 목록을 적은 텍스트 파일을 저장하고 게임내에서 사용할 수 있게 해준다. 저장 확장자는 .mcfunction. UTF-8로 인코딩하여 사용하는 것이 여러 문제를 예방할 수 있다.[1]

기능을 사용하려면 먼저 텍스트 파일을 .minecraft/saves/(월드이름)/datapacks/(데이터팩 이름)/data/(네임 스페이스)/functions 내의 최상위 폴더에 배치해야 한다. 새로운 최상위 폴더의 이름은 내부 함수를 실행할 때 사용되는 네임 스페이스가 된다. 최상위 폴더 내의 하위 폴더에 기능을 배치 할 수도 있다. (데이터팩 이름) 폴더에 pack.mcmeta 파일이 있어야 한다.

예를 들어 custom:example/test라는 함수를 실행하면 data/custom/functions/example/test.mcfunction에서 데이터를 불러오게 된다. 만약 네임스페이스를 쓰지 않았다면 minecraft:라는 기본 설정된 네임 스페이스를 지정받게 된다. 하지만 나중에 기본 네임 스페이스를 추가하였을 때 의도하지 않은 동작을 방지하기 위해선 사용자 지정 네임 스페이스를 사용하는 것을 추천한다.

텍스트 파일로 이루어져 있는 함수는 수정하기 쉽고, 명령 블록에서 긴 명령어를 작성하는 것 보다 렉을 더 적게 유발한다.
/reload 명령어를 사용해서 함수 파일을 로딩하면 마인크래프트에 재접속 하지 않고 바뀐 함수를 적용할 수 있다.

/function 명령어를 성공적으로 입력했다면 함수 '<경로>'에 있는 명령어 <개수>개를 실행했습니다라고 출력된다. 내장된 함수는 위 메세지를 출력하지 않는다. 함수 내에서 명령의 성공적인 출력은 비교기로 측정 할 수 없다 (/ execute store 명령을 사용하여 동일한 효과를 얻을 수는 있다.)

명령 블록이 실행하는 모든 명령어는 권한 레벨2를 넘을 수 없다. 하지만 위와 다르게 보통의 멀티플레이 서버 구현 프로그렘에서는 server.properties의 function-permission-level에서 자유롭게 설정할 수 있다.

함수 구문을 작성하려면 아래의 functions 부분 참고.

3. 기능

3.1. advancements / 발전 과제

발전과제를 추가/변경하고 이름과 달성 조건, 경험치 획득 및 명령어 실행을 할 수 있다.

이 사이트에서 쉽게 생성할 수 있다.

3.2. chat type / 대화

대화 메시지를 변경한다. 또한 /say, /me, /msq, /teammsg 의 출력 형식도 변경이 가능하다.

대화 메시지를 '<이름> 내용'대신 '이름: 내용'으로 변경하기.
#!syntax json
파일 경로: .minecraft\saves\<맵 이름>\datapacks\<데이터 팩 이름>\data\minecraft\chat_type\chat.json
{
  "chat": {
    "parameters": [
      "sender",
      "content"
    ],
    "translation_key": "%s: %s"
  },
  "narration": {
    "parameters": [
      "sender",
      "content"
    ],
    "translation_key": "chat.type.text.narrate"
  }
}

3.3. dimension / 차원

1.16부터 생겼으며 data 폴더 안에 minecraft 폴더 안에 dimension , dimension_type 폴더 만들면 된다. 그 폴더 안에 영어 소문자 _ 로만 차원 이름을 적고 .json을 만들면 된다.

추가된 차원을 가고 싶다면 /execute in (폴더 이름):(차원 이름) run tp ~ ~ ~로 가면 된다. 추가된 차원에 엔티티를 소환하거나 블록을 설치하는 것 또한 execute in을 이용하면 된다.[2]

완전한 평지 엔드 버전
#!syntax json
{
      "generator": {
        "settings": {
          "structures": {
            "stronghold": {
              "distance": 32,
              "spread": 3,
              "count": 128
            },
            "structures": {}
          },
          "layers": [
            {
              "height": 1,
              "block": "minecraft:bedrock"
            },
            {
              "height": 3,
              "block": "minecraft:end_stone"
            }
          ],
          "biome": "minecraft:the_end"
        },
        "type": "minecraft:flat"
      },
      "type": {
    "ultrawarm": false,
    "natural": true,
    "coordinate_scale": 1.0,
    "piglin_safe": false,
    "respawn_anchor_works": false,
    "bed_works": false,
    "has_raids": true,
    "has_skylight": false,
    "has_ceiling": false,
    "ambient_light": 0.0,
    "fixed_time": 6000,
    "logical_height": 256,
    "infiniburn": "minecraft:infiniburn_end"
  }
}

3.3.1. dimension_type

차원 타입을 설정하는 곳 기본값은 차원마다 다르다.
설명 minecraft:overworld minecraft:the_nether minecraft:the_end
ambient_light빛의 양 0.0 0.1 0.0
bed_works플레이어가 침대에 누울 수 있는지 여부, false일 시 폭발 true false false
coordinate_scale각 월드 당 좌표 스케일. 네더에서 1블록 움직임은 오버월드에서 8블록 움직인 것과 같다. 1.0 8.0 1.0
effectsoverworld로 설정하면 구름, 태양, 별, 달이 생기며, the_nether로 설정하면 네더처럼 짙은 안개가 된다. the_end로 설정할 경우 엔드와 같이 어두운 하늘이 된다. 이외의 값을 설정한 경우 자동으로 "minecraft:overworld"로 설정된다. overworld the_nether the_end
fixed_time선택 사항 0에서 24000사이 정수이다. 오버월드 처럼 하루를 만들고 싶다면 이것을 제거하면 된다. (비어있음) 18000 6000
has_ceiling기반암 천장이 있는지 여부 false true false
has_raids습격을 일으킬 수 있는지 여부 true false true
has_skylight오버월드처럼 낮에 하늘에 광원이 있는지 여부 true false false
height이 차원의 총 높이. 16 ~ 4064 사이의 값. 384 256 256
infiniburn무한히 불을 태울 수 있는 블록 태그 #minecraft:infiniburn_overworld #minecraft:infiniburn_nether #minecraft:infiniburn_end
logical_height세계 생성 높이 제한, has_celling이 true면 해당 값의 y좌표에 기반암 천장이 생긴다. 384 128 256
min_yY좌표의 밑바닥을 정의한다. -2032 ~ 2032 사이의 값. -64 0 0
monster_spawn_block_light_limit??? 0 15 0
naturalfalse이면 나침반이 무작위로 회전, true이면 네더 차원문이 좀비화 피글린 생성한다. true false false
piglin_safe피글린이 좀비화 피글린으로 변하지 않는 여부. true이면 생존. false true false
respawn_anchor_works플레이어가 리스폰 정박기를 사용할 수 있을지 여부. false인 상태로 사용시 폭발 false true false
ultrawarm차원이 네더처럼 작동[3]하는지 여부. false true false

3.4. functions / 함수

.mcfunction 파일 내부에 유효한 마인크래프트 명령어를 슬래쉬(/)를 제외하고 작성하여야 한다. 함수 텍스트 파일 내부에서 줄 맨앞에 #을 붙여서 주석을 작성할 수 있다. 함수를 사용하면 명령 블록의 입력 한계값인 32,500보다 길게 쓸 수 있다. 단 2,000,000자보다 길게 쓸 수 없다.(1.20.5 예정) 내부에서 실행 가능한 명령의 총합은 /gamerule maxCommandChainLength의 값으로 결정되고 기본값은 65,536줄이다. 이 설정값을 초과하는 명령어는 무시된다.

함수는 모든 명령을 단일 틱으로 실행하고 다른 함수 내에서 호출 된 함수는 부모함수와 동일한 틱으로 명령을 실행한다. 함수는 다른 함수를 사용하거나 명령 블록 환경에서 사용된다.[4] 여기에는 명령 발신자, 위치, 회전 등이 포함된다.

함수 내에서 발생하는 명령어의 문맥을 변경해도 명령 순서에 관계없이 다음 반복까지 동일한 함수 내 (또는 하위 함수 내)의 다른 명령에서 사용하는 명령 환경에 영향을 미치지 않는다. 단 / execute 명령은 예외이며 하위 함수의 명령 환경을 업데이트 한다.
  • 사용 예시
execute as @a at @s run function foo:bar
foo:bar
{{{#!wiki style="margin:1em calc(2em + 25px) 1em 1em"
\#\#는 주석을 의미합니다.
teleport @s ~ ~5 ~
setblock ~ ~-1 ~ emerald_block
execute at @s run setblock ~ ~-1 ~ diamond_block}}}

위와 같은 명령어를 플레이어가 사용하면 플레이어는 y좌표가 5칸 위인 위치로 텔레포트 한다. 그리고 플레이어가 원래 밟고 있던 블록은 에매랄드 블록으로 바뀌며 텔레포트한 위치 바로 아래에 다이아몬드 블록이 생성된다. 이러한 특성은 대상 선택인자 매개변수의 영향을 받지 않는다.

@s라는 대상 지정 인자를 이용해서 엔티티가 함수를 사용하도록 할 수 있고, /execute as 로 연출자 엔티티를 수정하는 함수를 전 보다 잘 쓸 수 있는 가능성을 제시해 준다.[5] 이것은 더 간단한 과정으로 대상 선택 인자로 선택한 특정 엔티티를 사용하는 연출을 보다 높은 퀄리티로 구현할 수 있게 해주며 일반적으로 월드의 엔티티 숫자를 줄일 수 있다.

또한, /schedule function 명령어로 일정 시간 후에 Function파일을 작동시킬 수 있어 시간차를 두고 명령어를 사용하고 싶을 때도 유용하다. 명령 블록으로는 레드스톤 중계기나 떨어지는 블록 등을 이용해야 하나, schedule 명령어 덕분에 function을 쓴다면 굳이 명령 블록을 쓸 이유가 없어진다.

이외에 다양항 방법으로 함수를 활용할 수 있으며, 스크립트, 플러그인에서만 지원하던 함수 기능을 마인크래프트로 가져옴으로써 플러그인을 덜 쓰고도 동일한 효과를 낼 수 있게 되었다. 이는 마인크래프트 서버를 더 쾌적한 환경으로 운영할 수 있는 가능성을 제시해 주며, 전에는 시도해 보지 못했던 다양한 연출을 사용함으로써 새로운 미니게임의 탄생을 촉구할 수 있다.

give @s spawner{display:{Name:'{"text":"Speed Husk Spawner","color":"#0B9914","bold":true}'},BlockEntityTag:{SpawnCount:5,SpawnRange:7,Delay:60,MinSpawnDelay:300,MaxSpawnDelay:900,MaxNearbyEntities:10000,RequiredPlayerRange:14,SpawnData:{id:"minecraft:husk",Glowing:1b,CustomNameVisible:1b,Health:30f,CanBreakDoors:0b,Tags:["SpeedHusk"],CustomName:'{"text":"Speed Husk","color":"#0B9C06","bold":true}',ArmorItems:[{},{},{id:"minecraft:golden_chestplate",Count:1b,tag:{Enchantments:[{id:"minecraft:protection",lvl:1s}]}},{}],ActiveEffects:[{Id:1b,Amplifier:3b,Duration:19999980,ShowParticles:1b}],Attributes:[{Name:generic.max_health,Base:30}]},SpawnPotentials:[{Weight:1,Entity:{id:"minecraft:husk",Glowing:1b,CustomNameVisible:1b,Health:30f,CanBreakDoors:0b,Tags:["SpeedHusk"],CustomName:'{"text":"Speed Husk","color":"#0B9C06","bold":true}',ArmorItems:[{},{},{id:"minecraft:golden_chestplate",Count:1b,tag:{Enchantments:[{id:"minecraft:protection",lvl:1s}]}},{}],ActiveEffects:[{Id:1b,Amplifier:3b,Duration:19999980,ShowParticles:1b}],Attributes:[{Name:generic.max_health,Base:30}]}}]}} 1
이런 엄청난 길이의 코드를 파일에 저장하는 역할도 같이 할 수 있다. 따라서 서버 내 메모리 최척화와, 긴 명령어의 저장 등 다방면의 기능을 할 수 있기에, 코딩을 해야 한다면 명령 블록을 최소화하고, 함수를 사용하는 것이 좋다.

3.4.1. 매크로 기능

1.20.2(23w31a)부터 추가된 기능. 일명 매개변수를 넣는 기능이다.

function <실행 파일> <compound> 또는 function <실행 파일> with <data source> [경로]
  • 사용 예시
execute as @a at @s run function foo:bar {baz:"World!"}
foo:bar
{{{#!wiki style="margin:1em calc(2em + 25px) 1em 1em"
\#\#는 주석을 의미합니다.
$say Hello $(baz)}}}
위와 같은 명령어를 사용하면 $(baz)의 변수값은 World!가 되니 실행되는 명령어는 /say Hello World!가 된다.

3.5. item modifier / 아이템 수정자

1.17부터 추가된 기능. /Item modifier ... 명령어를 사용할 때 쓰인다.

더 많은 내용은 마인크래프트 영어 위키로 가면 된다.

시작 - <
Compound
>
function <
String
> - function의 ID 이다.
function의 다른 부분 (아래에)

limit_count
  • limit: 사용할 정확한 제한을 지정한다.

looting_enchant
  • count: 약탈 레벨당 추가 아이템 수를 지정한다. 숫자는 소수점 일 수 있으며 약탈 레벨을 곱한 후 반올림된다.
  • limit: 약탈 계산 후 스택에 있는 최대 아이템 수를 정한다. 값이 0이면 제한이 적용되지 않는다.

set_damage - 도구의 내구도를 수정한다.
  • damage: Number provider. 설정할 내구도 비율을 지정한다 (1.0은 손상되지 않음, 0.0은 내구도 없음).
  • add(JE 1.17) :선택 사항. 만약 true이면 현재 내구도에 비례하여 변경된다.

set_lore - 아이템에 설명을 추가한다.
  • lore

set_name - 아이템의 이름을 설정한다.
  • name
예시:
아이템 10개로 쌓기
#!syntax json
파일 경로: .minecraft\saves\<맵 이름>\datapacks\<데이터 팩 이름>\data\<namespace>\item_modifiers\<파일 이름>.json
[
  {
    "function": "limit_count",
    "limit": 10
  }
]
도구의 내구도가 절반으로 깎이며 이름이 NamuWiki인 아이템으로 변경
#!syntax json
[
  {
    "function": "set_damage",
    "damage": 0.5
  },
  {
    "function": "set_name",
    "name": "NamuWiki"
  }
]
아이템의 이름과 설명, 무기 피해량은 무한으로 설정한다.
#!syntax json
[
  {
    "function": "set_name",
    "name": "Sword of the Universe"
  },
  {
    "function": "set_lore",
    "lore": [
	{"text":"Oi you! Yes you."},
	{"text":"What are you looking at?"},
	{"text":"Yes this sword has ∞ damage."},
	{"text":"Kinda overkill? I'm lazy ok. (╯°□°)╯︵ ┻━┻"}
	]
  },
  {
    "function": "set_attributes",
    "modifiers": [{
	"attribute": "minecraft:generic.attack_damage",
	"name": "",
	"amount": 9e99,
	"operation": "addition",
	"slot": "mainhand"
	}]
  }
]

3.6. loot_tables / 드롭 아이템

몹과 블록의 드롭 아이템과 구조물의 상자에 있는 아이템을 바꿀 수 있다. 또한 이것과 loot 명령어를 활용한다면 give 명령어 보다 더 많은 것을 구현 할 수 있다. 단, 일부 블록(기반암, 엔드 차원문 틀 등)의 경우 아이템을 얻을 수 없도록 하드코딩 되어 있으므로 드롭 아이템을 추가하더라도 아이템이 드롭되지 않는다.

Loot Table를 생성하는 사이트가 있다. 엔드 도시에 있는 상자 프리셋
  • < >
    • type <
      > - 선택 사항. 상자 보상이면 "minecraft:chest", 개체이면 "minecraft:entity" 등으로 지정한다.
    • pools <
      > - Loot Table 목록.

  • rolls - < > - 최소 n번부터 최대 n번까지 다음 아이템을 굴린다.
    • min <
      > - 최소.
    • max <
      > - 최대.
  • bonus_rolls <
    > - 자신의 행운 수치에 따라 [math(bonus\_rolls\times Luck)]번 더 굴린다. 굴린 횟수가 소수점이라면 무조건 버린다.
  • bonus_rolls < > - 자신의 행운 수치를 곱하여 최소 min번부터 최대 max번까지 더 굴린다. 굴린 횟수가 소수점이라면 무조건 버린다.
  • conditions <
    > - 조건문.
  • functions <
    > -
  • entries <
    > - 여기에 넣을 아이템(들)을 정의한다.
    • < >
      • type <
        > - 타입을 지정한다. "minecraft:item"이면 아이템. minecraft:empty이면 없음 등으로 지정이 가능하다.
      • functions <
        >
      • conditions <
        >
      • name <
        >
      • children <
        >
      • expand - <
        >
      • weight <
        > - 비중. 생략하면 1로 지정된다.
      • quality <
        > - 자신의 행운 수치에 따라 비중을 더한다. 기본값은 0이다.

3.7. predicates / 술어

1.15부터 생겼으며 data 폴더에 있는 predicate 폴더에 만들면 된다.
주의사항! 여기있는 예시와 정보는 predicate의 극히 일부만 다루었다. 더욱 정확한 정보를 위해서는 영문위키를 찾아보는 것이 좋다.

시작 - <
Compound
>
condition <
String
> - condition의 ID 이다.
condition의 다른 부분 (아래에)

alternative
block_state_property
damage_source_properties - 데미지의 속성을 확인한다.
  • is_explosion <
    > - 폭발
  • is_projectile <
    > - 발사체
  • is_fire <
    > - 화염
  • is_lightning <
    > - 번개
  • is_magic <
    > - 마법
  • bypasses_magic <
    > - 배고픔에만 해당.
  • bypasses_invulnerability <
    > - 공허 피해에만 해당.
  • bypasses_armor <
    >
  • source_entity - < >
    • (모든 엔티티와 같다.)
  • direct_entity - < >
    • (모든 엔티티와 같다.)

entity_properties
  • entity <
    > - 조건을 확인할 엔티티를 지정한다.
    • predicate - < >
      • flags - < >
        • is_on_fire <
          > - 화염 여부 테스트.
        • is_sneaking <
          > - 웅크리기 여부 테스트.
        • is_sprinting <
          > - 달리기 여부 테스트.
        • is_swimming <
          > - 수영 여부 테스트.
        • is_baby <
          > - 아기 변형 여부 테스트.
    • (모든 엔티티와 같다.)

random_chance
  • chance <
    > - 성공확률를 정한다. 1이 100%이다. 0.5면 50%확률로 성공한다.

weather_check
  • raining <
    > - true이면 비가 올 때 성공한다.
  • thundering <
    > - true이면 천둥이 올 때 성공한다.

예시:
플레이어 웅크리기 감지
#!syntax json
파일 경로: .minecraft\saves\<맵 이름>\datapacks\<데이터 팩 이름>\data\<namespace>\predicates\<파일 이름>.json
  {
    "condition": "minecraft:entity_properties",
    "predicate": {
	"flags": {
		"is_sneaking": true
	}
    },
    "entity":"this"
}
50% 확률로 명령어 실행
#!syntax json
{
    "condition": "minecraft:random_chance",
    "chance": 0.5
}

3.8. recipes / 조합법

조합법을 바꿀 수 있다. 키에 아이템을 설정해 놓고 패턴에서 그 키로 조합하는 것이다. 다만 아쉽게도 NBT는 지원 안한다.
1.20.4 이하 버전에는 NBT를 적용시킬 때에는 얻을 수 없는 아이템을 주고 그 아이템을 삭제한 뒤에 NBT가 적용된 아이템을 주는 방식으로 제작하면 된다.[6][7]

예시를 들면 다이아몬드 곡괭이의 경우 ' '은 빈 공간, X는 다이아몬드, #은 막대기라고 했을 시 패턴에서
#!syntax json
{
  "type": "minecraft:crafting_shaped",
  "pattern": [
    "XXX",
    " # ",
    " # "
  ],
  "key": {
    "#": {
      "item": "minecraft:stick"
    },
    "X": {
      "item": "minecraft:diamond"
    }
  },
  "result": {
    "item": "minecraft:diamond_pickaxe"
  }
} 

라고 쓰면 다이아몬드 곡괭이의 조합법이 완성되는 것이다.

만약 나무 판자로 만드는 아이템같이[8] 다른 아이템으로도 조합이 가능하게 하고 싶다면 tag 파일을 따로 만들어 tag 파일을 tag 폴에 넣고 조합법에 집어넣을 수 있다.

원하는 조합법을 쉽게 만들 수 있는 외국 사이트가 있다. 사이트

3.9. structures / 구조물

자연 생성 구조물처럼 구조물 생성에 관여한다. 혹은 구조물 블록에 쓰이는 구조물이다.

3.10. worldgen

3.10.1. biome / 생물 군계

1.16.2부터 추가된 기능.

4. 유저 표준

데이터 팩에 포함된 태그나 명령어 등에 정해진 표준은 없지만, 유저들이 자체적으로 적당한 표준을 만들어 사용하고 있다.
사실 지키지 않아도 큰 문제는 없으나, 다른 데이터팩과의 충돌 방지나 호환을 위해 지키는 것이 좋다.

리소스팩 충돌 방지, 엔티티 및 태그 표준, 네임스페이스 표준 등 꽤 많은 양의 표준이 정해져 있다.

잘 읽어보면, Forge 모드 로더와의 연동도 고려하고 있는 것 같다

자세한 내용은 이 사이트를 참고하도록 하자.

5. 목록

파일:상세 내용 아이콘.svg   자세한 내용은 마인크래프트/팩/데이터 팩/목록 문서
번 문단을
부분을
참고하십시오.

6. 변경 내역

Breaking Changes은 [B]로 표시한다.

6.1. 1.20

  • 1.20.5
    • [B] 데이터 팩 버전은 이제 XX이다.
    • [B] 마인크래프트/NBT/아이템은 삭제되었으며, components로 처음부터 다시 작성되었다.
    • [B] 상태 효과의 127 이상의 점프 강화, 채굴 피로 등 음수 수치는 제거되었다.
    • [B] particle의 일부 입자의 변수 입력이 변경되었다. 변경 사항은 다음과 같다.
      • item minecraft:dirtitem{item:{id:"minecraft:dirt"}} 혹은 item{item: "minecraft:dirt"}}
      • dust 1.0 0.0 0.0 2.0dust{color:[1.0, 0.0, 0.0],scale:2.0}
      • dust_color_transition 1.0 0.0 0.0 0.5 0.0 1.0 0.5dust_color_transition{from_color: [1.0f, 0.0f, 0.0f], scale: 0.5f, to_color: [0.0f, 1.0f, 0.5f]}
      • 블록 입자(minecraft:block, minecraft:block_marker, minecraft:falling_dust, minecraft:dust_pillar)
        • block minecraft:redstone_lamp[lit=true]block{block_state:{Name:"minecraft:redstone_lamp",Properties:{lit: "true"}} }
        • block minecraft:diamond_blockblock{block_state:"minecraft:diamond_block"}
    • bypasses_wolf_armor 피해 속성이 추가되었다.
    • [B] recipes 결과 아이템 구문이 변경되었다. itemid, Countcount.
    • recipes 결과 아이템 구문이 새로 추가되었다. components 사용자 지정 구성(=NBT)을 정의할 수 있게 되었다.
    • [B] function의 최대 길이는 이제 한 줄당 2,000,000자로 제한된다.
    • 활, 쇠뇌는 발사체 무기로 분류되어 무한, 다중 발사, 관통 마법 부여를 영향 받을 수 있다.
    • 다음 속성이 추가/변경되었다.
      • player.block_interaction_range, player.entity_interaction_range - 플레이어의 블록/개체 상호작용 거리를 수정한다.
      • generic.scale - 몹의 크기를 수정한다.
      • generic.step_height - 몹의 계단 판정 높이를 수정한다.
      • [B] horse.jump_strength -> generic.jump_strength - 점프 강도는 이제 말이 아닌 모든 몹에게 적용된다.
      • generic.gravity - 중력을 조절한다.
      • generic.safe_fall_distance - 낙하 안전 거리를 수정한다.
      • generic.fall_damage_multiplier - 낙하 피해를 곱한다.
      • player.block_break_speed - 블록 파괴 속도를 수정한다.
    • [B] 속성의 계산 이름이 달라졌다.
      • additionadd_value
      • multiply_baseadd_multiplied_base
      • multiply_totaladd_multiplied_total
    • [B] sweepingsweeping_edge로 수정되었다.
    • 생성 지점 근처에 항상 로딩되는 청크(이하 스폰 청크)의 크기를 조정하는 게임 규칙이 추가되었다. spawnChunkRadius
  • 1.20.3
    • [B] 데이터 팩 버전은 이제 26이다.
    • [B] 잔디의 이름이 변경되었다. minecraft:grassminecraft:short_grass
    • [B] TNT NBT가 추가/변경되었다.
      • block_state 추가.
      • [B] Fusefuse
    • [B] Text Json에서 각각 false, true는 문자열로 지정이 안된다.
    • wither_skull 위더 해골의 NBT가 추가되었다. 파란색 위더 해골 여부를 결정한다. dangerous
    • 게임 규칙이 추가되었다. playersNetherPortalDefaultDelay, playersNetherPortalCreativeDelay, projectilesCanBreakBlocks
    • [B] 던진 삼지창의 필드명이 변경되었다. Tridentitem
    • scoreboard는 이제 이름 및 점수값에도 사용자 지정이 가능하다.
    • 피해 태그 추가: can_break_armor_stand
  • 1.20.2
    • [B] 데이터 팩 버전은 이제 18이다.
    • functions(함수)의 매크로 기능이 추가되었다.
    • functions(함수)의 개행 기능이 추가되었다. 줄의 끝에서 \ 넣는다면 다음 줄 명령어에 연결된다.

      • {{{say \
Hello, \
World!}}}
  • [B] Id[9] 데이터 형식이
    에서
    로 변경되었다. 속도의 ID는 1이였지만 지금은 minecraft:speed이다.
  • [B] 상태 효과 관련 NBT가 변경되었다.
  • 속성의 일부인 generic.max_absorption이 추가되었다. 최대 흡수 체력을 결정한다.
  • random 명령어가 추가되었다.
  • enderPearlsVanishOnDeath 게임 규칙이 추가되었다.
  • 1.20
    • [B] 데이터 팩 버전은 이제 15이다.
    • [B] 표지판의 NBT가 추가/변경되었다. 이전 표지판 NBT 보기
      • Text1, Text2, Text3, Text4가 제거되었다. 대신 front_text back_text가 추가되었다.
      • 밀랍칠한 표지판 여부를 확인하는 NBT인 is_waxed가 추가되었다.

6.2. 1.19

  • 1.19.4
    • [B] 데이터 팩 버전은 이제 12이다.
    • damage type(피해 속성)이 추가되었다.
    • ride, damage 명령어가 추가되었다.
    • effect 명령어에
    • [B] weather 명령어가 변경되었다. 숫자 뒤에 t, s, d가 추가되었으며, 생략 시 t로 설정한다. 기존으로 설정하고 싶다면 숫자 뒤에 s를 붙이면 된다. 예: 540s
    • clone 명령어는 이제 다른 차원에서도 복사/붙여넣기가 가능하다.
    • display 개체가 추가되었다.
  • 1.19
    • [B] 데이터 팩 버전은 이제 10이다.
    • [B] locatebiome 명령어가 삭제되었다. locate biome로 대체 가능
    • [B] placefeature 명령어가 삭제되었다. place feature로 대체 가능
    • [B] Id[10] 데이터 형식이
      에서
      로 변경되었다.

6.3. 1.18

6.4. 1.17

  • 1.17
    • [B] 데이터 팩 버전은 이제 7이다.
    • Item modifier(아이템 수정자)가 추가되었다.

6.5. 1.16

  • 1.16.2
    • [B] 데이터 팩 버전은 이제 6이다.
    • biome(생물 군계)이 추가되었다.
  • 1.16
    • [B] 속성의 이름이 변경되었다. 변경사항은 다음과 같다.
      • generic.armorToughnessgeneric.armor_toughness
      • generic.attackDamagegeneric.attack_damage
      • generic.attackKnockbackgeneric.attack_knockback
      • generic.attackSpeedgeneric.attack_speed
      • generic.flyingSpeedgeneric.flying_speed
      • generic.followRangegeneric.follow_range
      • generic.knockbackResistancegeneric.knockback_resistance
      • generic.maxHealthgeneric.max_health
      • generic.movementSpeedgeneric.movement_speed
      • horse.jumpStrengthhorse.jump_strength
      • zombie.spawnReinforcementszombie.spawn_reinforcements
    • attribute, locatebiome 명령어가 추가되었다.
    • dimension(차원)이 추가되었다.

6.6. 1.15

  • 1.15
    • [B] 데이터 팩 버전은 이제 5이다.
    • predicates(술어)가 추가되었다.

6.7. 1.14

6.8. 1.13

  • 1.13
    • 데이터 팩이 추가되었다. 추가 당시 버전은 4이다.

[1] 메모장이나 notepad++ 등으로 여는 것이 가능하다.[2] /execute in (폴더 이름):(차원 이름) run summon...
/execute in (폴더 이름):(차원 이름) run setblock(혹은 fill) ...
[3] 물이 증발하거나 스펀지가 증발함[4] 즉 함수가 사용하는 명령어는 명령 블록이 사용한 것과 같이 취급된다.[5] 예를 들어서 좀비에 옷을 입히고 대사를 넣어서 마치 NPC가 플레이어를 안내하는 연출을 한다고 가정하자 전에는 스코어보드 명령어와 매개변수를 복잡하게 활용하고 밑에 특정 블록을 넣어서 좀비가 이를 따라가게 하는 식으로 연출했어야 했다. 하지만 함수를 사용하면 이 과정을 간단히 할 수 있고 훨씬더 적은 명령어로 이 연출을 가능하게 해준다.[6] 위의 발전과제를 응용해 특정 조합법을 해금하면 function을 작동하게 하고, function 파일에 /recipe와 /advancements 명령어를 이용해 조합법과 발전과제를 철회하고 /clear 명령어로 조합으로 나온 얻을 수 없는 아이템 삭제 후, /give 명령어로 NBT가 붙은 아이템을 주면 된다. 만약 이렇게만 하면 조합으로 나온 얻을 수 없는 아이템을 클릭하지 않고 q를 눌러 버리면 아이템도 지급되고 얻을 수 없는 아이템도 남긴 하나, function 파일을 하나 더 만들어 /kill 명령어로 얻을 수 없는 아이템을 제거하는 명령어를 넣고, 기존 function 파일에 /schedule function 명령어를 넣어 아이템을 삭제하면 된다.[7] 서바이벌, 모험 모드에서 제작할 경우 두 모드에서 볼 일이 없는 스폰 알, 명령 블럭 등을 사용하고 리소스팩을 이용해 모습을 자연스럽게 바꾸면 괴리감이 적어진다.크리에이티브 모드는 혼란스러워진다.[8] 참나무 판자 뿐만 아닌 다른 나무의 판자로도 조합이 가능한 경우[9] 상태 효과 ID.[10] 상태 효과 ID.



파일:CC-white.svg 이 문서의 내용 중 전체 또는 일부는 문서의 r1604에서 가져왔습니다. 이전 역사 보러 가기
파일:CC-white.svg 이 문서의 내용 중 전체 또는 일부는 다른 문서에서 가져왔습니다.
[ 펼치기 · 접기 ]
문서의 r1604 (이전 역사)
문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)