Skip to main content

将Arcaea游戏中铺面文件(x.aff)转换为json文件,亦可将json文件转换回铺面文件的实用库

Project description

Jsonaea script by Begloon.

简介

Jsonaea为可将Arcaea游戏中铺面文件(x.aff)转换为json文件 / 字典,亦可将json文件 / 字典转换回铺面文件的实用库。
其理论上可读取并转换aff文件中的任何语句(目前除注释外),并无损地将其互相转换。
此库使用Python编写。
此库还有一个Tools附加库,内含多种不必要但减少代码量的实用函数。

快速使用

在github本项目上直接下载后手动安装。
本页面 下载最新版本的两个打包中任意一个
然后在终端中输入命令:

pip install 下载的文件本地路径  

在py文件中导入库:

import jsonaea

使用load函数生成字典:

load(arcPath)

arcPath: Arcaea铺面文件导入路径
此函数将返回一个字典。


使用createJson函数生成json文件

createJson(dict,JsonPath)

dict:创建json文件的字典 JsonPath:创建json文件的路径 此函数不返回值,会创建一个json文件。


导出生成的json文件 / 字典为.aff文件:

output(arcJson,arcPath)

arcJson: 提供的json文件(字典)
arcPath: Arcaea铺面文件导出路径
此函数不返回值,会创建一个.aff文件。

示例

jsonaea库使用的具体示例,以下代码可将铺面中的arc全部转化为蛇:

import tkinter as tk
from tkinter import filedialog
from jsonaea import *

#生成铺面导入窗口
root = tk.Tk()
root.withdraw () 
arcPath = filedialog.askopenfilename () 

#导入铺面
arc = load(arcPath)
#设置Tools库全局变量
Tools.arcJson = arc
#检索所有黑线事件
searchedEvent = Tools.searchEventSubject({"type":"arc","IsSkyline": True})
#并将其全部转化为蛇
for se in searchedEvent:
    Tools.changeEvent(se,{"IsSkyline":False})
#导出铺面
output(arc,"./noSkyline.aff")
#导出处理完的Json文件
createJson(arc, "./this.json")
input("已完成")

json文件 / 字典格式

{
  "META":{},
  "Camera":[],
  "Scenecontrol":[],
  "TimingList":[
    {
      "tags":[],
      "notes":[],
      "timing":[],
    }
  ]
}
  • META字典:
    存储铺面文件头,如:

    "AudioOffset": 0,
    "TimingPointDensityFactor":2
    
  • Camera列表:
    存储铺面摄像头信息,如:

    "time": 0,
    "transverse": 0.0,
    "bottomzoom": 0.0,
    "linezoom": 0.0,
    "steadyangle": 0.0,
    "topzoom": 0.0,
    "angle": 0.0,
    "easing": "reset",
    "lastingtime": 1
    

    详见 ARCAEA中文维基 中对谱面格式的介绍
    多个字典以列表形式存储

  • Scenecontrol列表: 存储铺面Scenecontrol事件信息,如:

    "time": 0,
    "type": "arcahvdistort",
    "param": [
      1.25,
      0
    ]
    

    其中"param"项在没有参数时不会生成,详见 ARCAEA中文维基 中对谱面格式的介绍
    多个字典以列表形式存储

  • TimingList列表: 存储无timinggroup与timinggroup组的事件
    在该列表中无timinggroup的下标为0,timinggroup组的下标≥1(如果铺面中无timinggroup组,则该列表中只有下标为零的字典)
    多个字典以列表形式存储,字典中存有key为"tags","notes""timing"的三个列表
    当在该列表中下标为0的字典中(即无timinggroup的事件),"tags"中无参数。

    • tags 在aff文件timinggroup(){};中小括号中的标识,一般用于对timinggroup中的事件达成特殊效果(如noinput)
      字典格式如:

      "noinput",
      "anglex200"
      
    • notes
      note事件,分为tapholdarc三个类型,由key值"type"区分
      其中tap的字典格式如:

      "type": "tap",
      "time": 0,
      "track": 1
      

      其中track指轨道,目前无法读取track为小数的tap事件

      其中hold的字典格式如:

      "type": "hold",
      "startTime": 0,
      "endTime": 1000,
      "track": 3
      

      其中track指轨道,目前无法读取track为小数的hold事件

      其中arc的字典格式如:

      "type": "arc",
      "startTime": 0,
      "endTime": 1000,
      "startPos": [
        0.5,
        1.0
      ],
      "endPos": [
        1.0,
        1.0
      ],
      "arcType": "si",
      "color": "blue",
      "hitsound": "none",
      "IsSkyline": true
      

      其中"startPos""endPos"列表中下标为0的参数时坐标x,下标为1的为坐标y
      "arcType"是指该arc的滑动方式
      "hitsound"为该arc上arctap的打击音,如果有填以铺面的相对路径,如果没有填none
      "IsSkyline"为该arc是否为黑线,反之为蛇
      如果该arc上有arctap,那么将在下方添加键值对,如:

      "arctap": [
         200,
         600
      ]
      

      列表中存储着该arc上所有arctap的时间,其范围在startTime与endTime之间

    • timing 控制铺面的bpm(流速)与beat(小节线) 其格式如:

      "time": 0,
      "BPM": 191.0,
      "metreInfo": 4.0
      

      其中"metreInfo"是指表示每多少个四分拍为一小节,并出现一条小节线
      多个字典以列表形式存储

    对以上任何信息如有困惑,详见 ARCAEA中文维基 中对谱面格式的介绍。

特别声明

本项目只对Arcaea铺面文件进行解读,关于Arcaea铺面使用与更改的最终解释权归Arcaea版权方lowiro所有。
任何通过通过本项目对游戏内铺面的改写与本项目无关,一切责任归使用者所有。
本项目版权归程序编写者Begloon(321bug)所有。

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jsonaea-2025.5.10.tar.gz (9.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

Jsonaea-2025.5.10-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file jsonaea-2025.5.10.tar.gz.

File metadata

  • Download URL: jsonaea-2025.5.10.tar.gz
  • Upload date:
  • Size: 9.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.5

File hashes

Hashes for jsonaea-2025.5.10.tar.gz
Algorithm Hash digest
SHA256 0e243cc2fd932b27093116b1000bb46345332e0882a52ccdd0c746b724452630
MD5 a3bf8e3a1c635969570d9f919c6255e7
BLAKE2b-256 608ce84a655c5c896be33e86bc707d00fb3ca648e6ecc23c4ad4459ddacb6747

See more details on using hashes here.

File details

Details for the file Jsonaea-2025.5.10-py3-none-any.whl.

File metadata

  • Download URL: Jsonaea-2025.5.10-py3-none-any.whl
  • Upload date:
  • Size: 9.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.5

File hashes

Hashes for Jsonaea-2025.5.10-py3-none-any.whl
Algorithm Hash digest
SHA256 4398fe5985259b7e799177c6464cf6b8ff4ca78619b2d9f080816264cb194ed0
MD5 9d97fd4ee9d3bfe6e03128b44c517dd5
BLAKE2b-256 5f569867cf445bd0ef6fe7e88c159a65d9217edf432f9a7716ae23e1f05deb84

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page