mirror of
https://github.com/LmeSzinc/AzurLaneAutoScript.git
synced 2025-01-08 12:07:36 +08:00
add: wararchive Dreamwaker's Butterfly & Mirror Involution
新增作战档案: 蝶海梦花&镜位螺旋
This commit is contained in:
parent
6a78be535b
commit
d29f93c1c1
BIN
assets/cn/war_archives/TEMPLATE_DREAMWAKERS_BUTTERFLY.png
Normal file
BIN
assets/cn/war_archives/TEMPLATE_DREAMWAKERS_BUTTERFLY.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 53 KiB |
BIN
assets/cn/war_archives/TEMPLATE_MIRROR_INVOLUTION.png
Normal file
BIN
assets/cn/war_archives/TEMPLATE_MIRROR_INVOLUTION.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 34 KiB |
@ -37,6 +37,8 @@ To add a new event, add a new row in here, and run `python -m module.config.conf
|
|||||||
| 20230420 | war archives 20220210 cn | Northern Overture | 北境序曲 | Northern Overture | 凍絶の北海 | 北境序曲 |
|
| 20230420 | war archives 20220210 cn | Northern Overture | 北境序曲 | Northern Overture | 凍絶の北海 | 北境序曲 |
|
||||||
| 20230511 | war archives 20220414 cn | Aurora Noctis | 永夜幻光 | Aurora Noctis | 極夜照らす幻光 | 永夜幻光 |
|
| 20230511 | war archives 20220414 cn | Aurora Noctis | 永夜幻光 | Aurora Noctis | 極夜照らす幻光 | 永夜幻光 |
|
||||||
| 20230831 | war archives 20201229 cn | Inverted Orthant | 负象限作战 | Inverted Orthant | 虚畳なりし限象 | - |
|
| 20230831 | war archives 20201229 cn | Inverted Orthant | 负象限作战 | Inverted Orthant | 虚畳なりし限象 | - |
|
||||||
|
| 20240118 | war archives 20200917 cn | Dreamwaker's Butterfly | 蝶海梦花 | Dreamwaker's Butterfly | 刹那觀る胡蝶の夢 | - |
|
||||||
|
| 20240118 | war archives 20210527 cn | Mirror Involution | 镜位螺旋 | Mirror Involution | 照らす螺旋の鏡海 | - |
|
||||||
| 20200227 | event 20200227 cn | Northern Overture | 北境序曲 | Northern Overture | 凍絶の北海 | - |
|
| 20200227 | event 20200227 cn | Northern Overture | 北境序曲 | Northern Overture | 凍絶の北海 | - |
|
||||||
| 20200312 | event 20200312 cn | The Solomon Ranger | 复刻斯图尔特的硝烟 | The Solomon Ranger Rerun | 南洋に靡く硝煙(復刻) | - |
|
| 20200312 | event 20200312 cn | The Solomon Ranger | 复刻斯图尔特的硝烟 | The Solomon Ranger Rerun | 南洋に靡く硝煙(復刻) | - |
|
||||||
| 20200326 | event 20200326 cn | Microlayer Medley | 微层混合 | Microlayer Medley | 闇靄払う銀翼 | - |
|
| 20200326 | event 20200326 cn | Microlayer Medley | 微层混合 | Microlayer Medley | 闇靄払う銀翼 | - |
|
||||||
|
129
campaign/war_archives_20200917_cn/campaign_base.py
Normal file
129
campaign/war_archives_20200917_cn/campaign_base.py
Normal file
@ -0,0 +1,129 @@
|
|||||||
|
from module.base.button import Button
|
||||||
|
from module.base.utils import *
|
||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase as CampaignBase_
|
||||||
|
from module.exception import CampaignNameError
|
||||||
|
from module.logger import logger
|
||||||
|
|
||||||
|
# Here manually type coordinates, because the ball appears in event Dreamwaker's Butterfly only.
|
||||||
|
BALL = Button(area=(571, 283, 696, 387), color=(), button=(597, 274, 671, 343))
|
||||||
|
|
||||||
|
|
||||||
|
class CampaignBase(CampaignBase_):
|
||||||
|
STAGE_INCREASE = [
|
||||||
|
'TS1 > T1 > T2 > T3 > T4 > TS2 > T5 > T6',
|
||||||
|
'HTS1 > HT1 > HT2 > HT3',
|
||||||
|
'HT4 > HTS2 > HT5 > HT6',
|
||||||
|
]
|
||||||
|
|
||||||
|
def campaign_set_chapter(self, name, mode='normal'):
|
||||||
|
"""
|
||||||
|
Args:
|
||||||
|
name (str): Campaign name, such as '7-2', 'd3', 'sp3'.
|
||||||
|
mode (str): 'normal' or 'hard'.
|
||||||
|
"""
|
||||||
|
chapter, stage = self._campaign_separate_name(name)
|
||||||
|
name = chapter + stage
|
||||||
|
|
||||||
|
if chapter.isdigit():
|
||||||
|
self.ui_goto_campaign()
|
||||||
|
self.campaign_ensure_mode('normal')
|
||||||
|
self.campaign_ensure_chapter(index=chapter)
|
||||||
|
if mode == 'hard':
|
||||||
|
self.campaign_ensure_mode('hard')
|
||||||
|
|
||||||
|
elif chapter in 'abcd' or chapter == 'ex_sp':
|
||||||
|
self.ui_goto_event()
|
||||||
|
if chapter in 'ab':
|
||||||
|
self.campaign_ensure_mode('normal')
|
||||||
|
elif chapter in 'cd':
|
||||||
|
self.campaign_ensure_mode('hard')
|
||||||
|
elif chapter == 'ex_sp':
|
||||||
|
self.campaign_ensure_mode('ex')
|
||||||
|
self.campaign_ensure_chapter(index=chapter)
|
||||||
|
|
||||||
|
elif chapter == 'sp':
|
||||||
|
self.ui_goto_sp()
|
||||||
|
self.campaign_ensure_chapter(index=chapter)
|
||||||
|
|
||||||
|
elif chapter in ['t', 'ts', 'ht', 'hts']:
|
||||||
|
self.ui_goto_event()
|
||||||
|
# Campaign ball
|
||||||
|
if stage in ['1', '6']:
|
||||||
|
self._campaign_ball_set('blue')
|
||||||
|
else:
|
||||||
|
self._campaign_ball_set('red')
|
||||||
|
# Campaign mode
|
||||||
|
if chapter in ['t', 'ts']:
|
||||||
|
self.campaign_ensure_mode('normal')
|
||||||
|
if chapter in ['ht', 'hts']:
|
||||||
|
self.campaign_ensure_mode('hard')
|
||||||
|
if chapter == 'ex_sp':
|
||||||
|
self.campaign_ensure_mode('ex')
|
||||||
|
# Get stage
|
||||||
|
self.campaign_ensure_chapter(index=1)
|
||||||
|
else:
|
||||||
|
logger.warning(f'Unknown campaign chapter: {name}')
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _campaign_get_chapter_index(name):
|
||||||
|
"""
|
||||||
|
Args:
|
||||||
|
name (str, int):
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
int
|
||||||
|
"""
|
||||||
|
if isinstance(name, int):
|
||||||
|
return name
|
||||||
|
else:
|
||||||
|
if name.isdigit():
|
||||||
|
return int(name)
|
||||||
|
elif name in ['a', 'c', 'sp', 'ex_sp', 'ts', 't', 'ht', 'hts']:
|
||||||
|
return 1
|
||||||
|
elif name in ['b', 'd', 'ex_ex']:
|
||||||
|
return 2
|
||||||
|
else:
|
||||||
|
raise CampaignNameError
|
||||||
|
|
||||||
|
def _campaign_ball_get(self):
|
||||||
|
"""
|
||||||
|
Returns:
|
||||||
|
str: 'blue' or 'red'.
|
||||||
|
"""
|
||||||
|
color = get_color(self.device.image, BALL.area)
|
||||||
|
# Blue: (93, 127, 182), Red: (186, 116, 124)
|
||||||
|
index = np.argmax(color)
|
||||||
|
if index == 0:
|
||||||
|
return 'red'
|
||||||
|
elif index == 2:
|
||||||
|
return 'blue'
|
||||||
|
else:
|
||||||
|
logger.warning(f'Unknown campaign ball color: {color}')
|
||||||
|
return 'unknown'
|
||||||
|
|
||||||
|
def _campaign_ball_set(self, status):
|
||||||
|
"""
|
||||||
|
Args:
|
||||||
|
status (str): 'blue' or 'red'.
|
||||||
|
"""
|
||||||
|
skip_first_screenshot = True
|
||||||
|
while 1:
|
||||||
|
if skip_first_screenshot:
|
||||||
|
skip_first_screenshot = False
|
||||||
|
else:
|
||||||
|
self.device.screenshot()
|
||||||
|
|
||||||
|
current = self._campaign_ball_get()
|
||||||
|
logger.attr('Campaign_ball', current)
|
||||||
|
|
||||||
|
if current == status:
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
if self.is_in_stage():
|
||||||
|
self.device.click(BALL)
|
||||||
|
self.device.sleep(3)
|
||||||
|
# wait until is_in_stage
|
||||||
|
while 1:
|
||||||
|
self.device.screenshot()
|
||||||
|
if self.is_in_stage():
|
||||||
|
break
|
89
campaign/war_archives_20200917_cn/ht1.py
Normal file
89
campaign/war_archives_20200917_cn/ht1.py
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('HT1')
|
||||||
|
MAP.shape = 'K7'
|
||||||
|
# MAP.camera_data = ['D2', 'D5', 'H2', 'H5']
|
||||||
|
MAP.camera_data = ['D3', 'D5', 'H3', 'H5']
|
||||||
|
MAP.camera_data_spawn_point = ['H5', 'D5']
|
||||||
|
MAP.map_data = """
|
||||||
|
-- -- ++ -- -- MB -- -- ++ -- --
|
||||||
|
-- ++ ++ ++ Me -- Me ++ ++ ++ --
|
||||||
|
++ Me -- ++ ++ -- ++ ++ -- Me ++
|
||||||
|
ME -- ME ++ ++ -- ++ ++ ME -- ME
|
||||||
|
-- -- -- ME MS -- MS ME -- -- --
|
||||||
|
ME -- MS -- -- __ -- -- MS -- ME
|
||||||
|
++ Me -- -- SP -- SP -- -- Me ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, K1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, K2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, K3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, K4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, K5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, K6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, K7, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CL', 'SS']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
STAGE_ENTRANCE = ['blue']
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (150, 255 - 17),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 17, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 17)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
MAP_WALK_USE_CURRENT_FLEET = True
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.fleet_2_protect():
|
||||||
|
return True
|
||||||
|
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
84
campaign/war_archives_20200917_cn/ht2.py
Normal file
84
campaign/war_archives_20200917_cn/ht2.py
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .ht1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('HT2')
|
||||||
|
MAP.shape = 'H7'
|
||||||
|
# MAP.camera_data = ['D2', 'D5', 'E2', 'E5']
|
||||||
|
MAP.camera_data = ['D3', 'D5', 'E3', 'E5']
|
||||||
|
MAP.camera_data_spawn_point = ['E5']
|
||||||
|
MAP.portal_data = [('E5', 'E1'), ('E1', 'E5')]
|
||||||
|
MAP.map_data = """
|
||||||
|
-- ++ -- ME -- ME ++ ++
|
||||||
|
ME -- Me __ -- -- MB ++
|
||||||
|
-- -- -- -- ME -- ++ ME
|
||||||
|
++ ME ++ ++ ++ ++ MS --
|
||||||
|
-- ++ Me Me -- Me -- ME
|
||||||
|
MS -- -- -- -- -- -- ++
|
||||||
|
-- ME ++ ++ SP SP -- MS
|
||||||
|
"""
|
||||||
|
MAP.map_data_loop = """
|
||||||
|
-- ++ -- ME -- ME ++ ++
|
||||||
|
ME -- Me __ -- -- MB ++
|
||||||
|
-- -- -- -- ME -- ++ ME
|
||||||
|
++ ME ++ -- -- -- MS --
|
||||||
|
-- ++ Me Me -- Me -- ME
|
||||||
|
MS -- -- -- -- -- -- ++
|
||||||
|
-- ME ++ ++ SP SP -- MS
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 10 20 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CL', 'CAred']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = False
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
MAP_HAS_PORTAL = True
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.fleet_2_protect():
|
||||||
|
return True
|
||||||
|
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
94
campaign/war_archives_20200917_cn/ht3.py
Normal file
94
campaign/war_archives_20200917_cn/ht3.py
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .ht1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('HT3')
|
||||||
|
MAP.shape = 'I9'
|
||||||
|
# MAP.camera_data = ['D2', 'D6', 'D7', 'F2', 'F6', 'F7']
|
||||||
|
# MAP.camera_data_spawn_point = ['D7', 'D6']
|
||||||
|
MAP.camera_data = ['D3', 'D5', 'D7', 'F3', 'F5', 'F7']
|
||||||
|
MAP.camera_data_spawn_point = ['D5']
|
||||||
|
MAP.portal_data = [('I2', 'A1'), ('A1', 'I2'), ('I9', 'H1'), ('H1', 'I9')]
|
||||||
|
MAP.map_data = """
|
||||||
|
-- -- -- ++ ME -- ME -- ++
|
||||||
|
-- -- MB ++ -- -- -- -- --
|
||||||
|
++ ++ ++ ++ -- ++ ++ -- ME
|
||||||
|
-- MS -- Me -- Me ++ -- --
|
||||||
|
ME -- ++ -- __ -- -- -- ME
|
||||||
|
-- -- SP -- -- Me ++ ++ ++
|
||||||
|
Me -- -- SP ++ -- ++ MB --
|
||||||
|
-- MS -- -- -- MS ++ -- --
|
||||||
|
++ -- Me -- ME -- ++ -- --
|
||||||
|
"""
|
||||||
|
MAP.map_data_loop = """
|
||||||
|
-- -- -- -- ME -- ME -- ++
|
||||||
|
-- -- MB -- -- -- -- -- --
|
||||||
|
++ ++ ++ -- -- ++ ++ -- ME
|
||||||
|
-- MS -- Me -- Me ++ -- --
|
||||||
|
ME -- ++ -- __ -- -- -- ME
|
||||||
|
-- -- SP -- -- Me -- -- --
|
||||||
|
Me -- -- SP ++ -- ++ MB --
|
||||||
|
-- MS -- -- -- MS ++ -- --
|
||||||
|
++ -- Me -- ME -- ++ -- --
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1},
|
||||||
|
{'battle': 5, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CL', 'CAred']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
MAP_HAS_PORTAL = True
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.fleet_2_protect():
|
||||||
|
return True
|
||||||
|
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
111
campaign/war_archives_20200917_cn/ht4.py
Normal file
111
campaign/war_archives_20200917_cn/ht4.py
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .ht1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('HT4')
|
||||||
|
MAP.shape = 'K9'
|
||||||
|
MAP.camera_data = ['D2', 'D5', 'D7', 'H2', 'H5', 'H7']
|
||||||
|
MAP.camera_data_spawn_point = ['D2', 'D7']
|
||||||
|
MAP.portal_data = [('I5', 'C5'), ('C5', 'I5'), ('E5', 'E3'), ('E3', 'E5'), ('G5', 'G7'), ('G7', 'G5')]
|
||||||
|
MAP.map_data = """
|
||||||
|
Me -- -- ++ Me -- ME -- ME ++ ++
|
||||||
|
-- MS -- ++ -- SP -- __ -- MS --
|
||||||
|
-- -- Me ++ -- -- -- ME -- -- --
|
||||||
|
ME -- ++ ++ ++ ++ ++ ++ ++ -- ME
|
||||||
|
-- -- -- ++ -- MB -- ++ -- -- --
|
||||||
|
ME -- ++ ++ ++ ++ ++ ++ ++ -- ME
|
||||||
|
-- -- -- ME -- -- -- ++ Me -- --
|
||||||
|
-- MS -- __ -- SP -- ++ -- MS --
|
||||||
|
++ ++ ME -- ME -- Me ++ -- -- Me
|
||||||
|
"""
|
||||||
|
MAP.map_data_loop = """
|
||||||
|
Me -- -- ++ Me -- ME -- ME ++ ++
|
||||||
|
-- MS -- -- -- SP -- __ -- MS --
|
||||||
|
-- -- Me ++ -- -- -- ME -- -- --
|
||||||
|
ME -- ++ ++ -- ++ -- ++ ++ -- ME
|
||||||
|
-- -- -- ++ -- MB -- ++ -- -- --
|
||||||
|
ME -- ++ ++ -- ++ -- ++ ++ -- ME
|
||||||
|
-- -- -- ME -- -- -- ++ Me -- --
|
||||||
|
-- MS -- __ -- SP -- -- -- MS --
|
||||||
|
++ ++ ME -- ME -- Me ++ -- -- Me
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 10 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, K1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, K2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, K3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, K4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, K5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, K6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, K7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, K8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, J9, K9, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['BB', 'SS']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
MAP_HAS_PORTAL = True
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.82
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.88
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.config.MAP_HAS_MOVABLE_ENEMY:
|
||||||
|
self.fleet_2_push_forward()
|
||||||
|
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.map_is_clear_mode:
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_2(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.map_is_clear_mode:
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
105
campaign/war_archives_20200917_cn/ht5.py
Normal file
105
campaign/war_archives_20200917_cn/ht5.py
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .ht1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('HT5')
|
||||||
|
MAP.shape = 'I9'
|
||||||
|
# MAP.camera_data = ['D2', 'D6', 'D7', 'F2', 'F6', 'F7']
|
||||||
|
# MAP.camera_data_spawn_point = ['F7', 'D2']
|
||||||
|
MAP.camera_data = ['D3', 'D5', 'D7', 'F3', 'F5', 'F7']
|
||||||
|
MAP.camera_data_spawn_point = ['F7', 'D3']
|
||||||
|
MAP.portal_data = [('D3', 'F3'), ('G4', 'G6'), ('F7', 'D7'), ('C6', 'C4')]
|
||||||
|
MAP.map_data = """
|
||||||
|
++ -- -- -- ++ -- MB -- ++
|
||||||
|
-- ME -- ME ++ MS -- MS --
|
||||||
|
Me -- SP -- ++ -- __ -- --
|
||||||
|
-- ME -- Me ++ Me -- ME --
|
||||||
|
++ ++ ++ ++ -- ++ ++ ++ ++
|
||||||
|
-- ME -- Me ++ Me -- ME --
|
||||||
|
-- -- __ -- ++ -- SP -- Me
|
||||||
|
-- MS -- MS ++ ME -- ME --
|
||||||
|
++ -- MB -- ++ -- -- -- ++
|
||||||
|
"""
|
||||||
|
MAP.map_data_loop = """
|
||||||
|
++ -- -- -- ++ -- MB -- ++
|
||||||
|
-- ME -- ME ++ MS -- MS --
|
||||||
|
Me -- SP -- -- -- __ -- --
|
||||||
|
-- ME -- Me ++ Me -- ME --
|
||||||
|
++ ++ -- ++ -- ++ -- ++ ++
|
||||||
|
-- ME -- Me ++ Me -- ME --
|
||||||
|
-- -- __ -- -- -- SP -- Me
|
||||||
|
-- MS -- MS ++ ME -- ME --
|
||||||
|
++ -- MB -- ++ -- -- -- ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1},
|
||||||
|
{'battle': 6, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['BB', 'CV']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
MAP_HAS_PORTAL = True
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.map_is_clear_mode:
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_6(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
109
campaign/war_archives_20200917_cn/ht6.py
Normal file
109
campaign/war_archives_20200917_cn/ht6.py
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .ht1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('HT6')
|
||||||
|
MAP.shape = 'K10'
|
||||||
|
# MAP.camera_data = ['D2', 'D6', 'D8', 'H2', 'H6', 'H8']
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'G2', 'G6']
|
||||||
|
MAP.camera_data_spawn_point = ['D6', 'G6']
|
||||||
|
MAP.map_data = """
|
||||||
|
-- -- -- ME -- Me -- ME -- -- --
|
||||||
|
-- ++ ++ -- MS -- MS -- ++ ++ --
|
||||||
|
-- ++ ME -- -- __ -- -- ME ++ --
|
||||||
|
Me -- -- ++ ++ -- ++ ++ -- -- Me
|
||||||
|
++ ME -- ++ MS -- MS ++ -- ME ++
|
||||||
|
++ ME -- -- -- MB -- -- -- ME ++
|
||||||
|
-- -- ++ Me -- -- -- Me ++ -- --
|
||||||
|
-- ++ ++ ++ SP -- SP ++ ++ ++ --
|
||||||
|
++ -- -- ++ ++ -- ++ ++ -- -- ++
|
||||||
|
-- -- -- ++ ++ -- ++ ++ -- -- --
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1},
|
||||||
|
{'battle': 6, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, K1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, K2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, K3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, K4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, K5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, K6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, K7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, K8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, J9, K9, \
|
||||||
|
A10, B10, C10, D10, E10, F10, G10, H10, I10, J10, K10, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['BB', 'CV', 'SS']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.446
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.495
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.fleet_2_protect():
|
||||||
|
return True
|
||||||
|
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_2(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_6(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
86
campaign/war_archives_20200917_cn/hts1.py
Normal file
86
campaign/war_archives_20200917_cn/hts1.py
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('HTS1')
|
||||||
|
MAP.shape = 'H6'
|
||||||
|
MAP.camera_data = ['D2', 'D4', 'E2', 'E4']
|
||||||
|
MAP.camera_data_spawn_point = ['E4']
|
||||||
|
MAP.map_data = """
|
||||||
|
MB -- ++ ++ ++ ++ -- --
|
||||||
|
-- ME -- -- -- ++ ++ ++
|
||||||
|
++ -- -- -- Me -- -- ++
|
||||||
|
++ ++ ++ ++ -- -- ME --
|
||||||
|
-- -- -- -- ++ ++ -- SP
|
||||||
|
-- ++ -- -- -- ++ SP --
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
# {'battle': 2, 'siren': 1},
|
||||||
|
{'battle': 2, 'enemy': 1},
|
||||||
|
{'battle': 3, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
# MAP_SIREN_TEMPLATE = ['srzl2']
|
||||||
|
# MOVABLE_ENEMY_TURN = (0,)
|
||||||
|
# MAP_HAS_SIREN = True
|
||||||
|
# MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = False
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
STAR_REQUIRE_1 = 0
|
||||||
|
STAR_REQUIRE_2 = 0
|
||||||
|
STAR_REQUIRE_3 = 0
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
STAGE_ENTRANCE = ['blue']
|
||||||
|
FLEET_2 = 0
|
||||||
|
MAP_IS_ONE_TIME_STAGE = True
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (150, 255 - 17),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 17, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 17)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_3(self):
|
||||||
|
return self.clear_boss()
|
82
campaign/war_archives_20200917_cn/hts2.py
Normal file
82
campaign/war_archives_20200917_cn/hts2.py
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
from module.exception import CampaignEnd
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .hts1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('HTS2')
|
||||||
|
MAP.shape = 'H8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'E2', 'E6']
|
||||||
|
MAP.camera_data_spawn_point = ['D6']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ MM -- -- -- -- -- --
|
||||||
|
++ ++ ++ ++ -- -- -- ++
|
||||||
|
-- -- -- -- -- ++ -- ++
|
||||||
|
-- -- -- ++ ++ ++ -- ++
|
||||||
|
-- ++ -- -- ++ -- -- --
|
||||||
|
-- -- ++ -- -- ++ -- ++
|
||||||
|
-- -- SP ++ MM ++ -- ++
|
||||||
|
MM -- -- ++ ++ ++ -- ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_HAS_MAP_STORY = False
|
||||||
|
MAP_HAS_FLEET_STEP = False
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
STAR_REQUIRE_1 = 0
|
||||||
|
STAR_REQUIRE_2 = 0
|
||||||
|
STAR_REQUIRE_3 = 0
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (150, 255 - 17),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 17, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 17)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
self.goto(A8, expected='story')
|
||||||
|
self.goto(E7, expected='story')
|
||||||
|
self.goto(B1, expected='story')
|
||||||
|
self.goto(G8, expected='story')
|
||||||
|
|
||||||
|
raise CampaignEnd()
|
86
campaign/war_archives_20200917_cn/t1.py
Normal file
86
campaign/war_archives_20200917_cn/t1.py
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('T1')
|
||||||
|
MAP.shape = 'K7'
|
||||||
|
# MAP.camera_data = ['D2', 'D5', 'H2', 'H5']
|
||||||
|
MAP.camera_data = ['D3', 'D5', 'H3', 'H5']
|
||||||
|
MAP.camera_data_spawn_point = ['H5', 'D5']
|
||||||
|
MAP.map_data = """
|
||||||
|
-- -- ++ -- -- MB -- -- ++ -- --
|
||||||
|
-- ++ ++ ++ Me -- Me ++ ++ ++ --
|
||||||
|
++ Me -- ++ ++ -- ++ ++ -- Me ++
|
||||||
|
ME -- ME ++ ++ -- ++ ++ ME -- ME
|
||||||
|
-- -- -- ME MS -- MS ME -- -- --
|
||||||
|
ME -- MS -- -- __ -- -- MS -- ME
|
||||||
|
++ Me -- -- SP -- SP -- -- Me ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 1},
|
||||||
|
{'battle': 3, 'enemy': 1, 'boss': 1},
|
||||||
|
{'battle': 4, 'enemy': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, K1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, K2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, K3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, K4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, K5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, K6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, K7, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['DD', 'SS']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
STAGE_ENTRANCE = ['blue']
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (150, 255 - 17),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 17, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 17)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
MAP_WALK_USE_CURRENT_FLEET = True
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_3(self):
|
||||||
|
return self.clear_boss()
|
96
campaign/war_archives_20200917_cn/t2.py
Normal file
96
campaign/war_archives_20200917_cn/t2.py
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .t1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('T2')
|
||||||
|
MAP.shape = 'H7'
|
||||||
|
# MAP.camera_data = ['D2', 'D5', 'E2', 'E5']
|
||||||
|
MAP.camera_data = ['D3', 'D5', 'E3', 'E5']
|
||||||
|
MAP.camera_data_spawn_point = ['E5']
|
||||||
|
MAP.portal_data = [('E5', 'E1'), ('E1', 'E5')]
|
||||||
|
MAP.map_data = """
|
||||||
|
-- ++ -- ME -- ME ++ ++
|
||||||
|
ME -- Me __ -- -- MB ++
|
||||||
|
-- -- -- -- ME -- ++ ME
|
||||||
|
++ ME ++ ++ ++ ++ MS --
|
||||||
|
-- ++ Me Me -- Me -- ME
|
||||||
|
MS -- -- -- -- -- -- ++
|
||||||
|
-- ME ++ ++ SP SP -- MS
|
||||||
|
"""
|
||||||
|
MAP.map_data_loop = """
|
||||||
|
-- ++ -- ME -- ME ++ ++
|
||||||
|
ME -- Me __ -- -- MB ++
|
||||||
|
-- -- -- -- ME -- ++ ME
|
||||||
|
++ ME ++ -- -- -- MS --
|
||||||
|
-- ++ Me Me -- Me -- ME
|
||||||
|
MS -- -- -- -- -- -- ++
|
||||||
|
-- ME ++ ++ SP SP -- MS
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 1},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CL']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = False
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
MAP_HAS_PORTAL = True
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (80, 255 - 33),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 33, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 33)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
105
campaign/war_archives_20200917_cn/t3.py
Normal file
105
campaign/war_archives_20200917_cn/t3.py
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .t1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('T3')
|
||||||
|
MAP.shape = 'I9'
|
||||||
|
# MAP.camera_data = ['D2', 'D6', 'D7', 'F2', 'F6', 'F7']
|
||||||
|
# MAP.camera_data_spawn_point = ['D7', 'D6']
|
||||||
|
MAP.camera_data = ['D3', 'D5', 'D7', 'F3', 'F5', 'F7']
|
||||||
|
MAP.camera_data_spawn_point = ['D5']
|
||||||
|
MAP.portal_data = [('I2', 'A1'), ('A1', 'I2'), ('I9', 'H1'), ('H1', 'I9')]
|
||||||
|
MAP.map_data = """
|
||||||
|
-- -- -- ++ ME -- ME -- ++
|
||||||
|
-- -- MB ++ -- -- -- -- --
|
||||||
|
++ ++ ++ ++ -- ++ ++ -- ME
|
||||||
|
-- MS -- Me -- Me ++ -- --
|
||||||
|
ME -- ++ -- __ -- -- -- ME
|
||||||
|
-- -- SP -- -- Me ++ ++ ++
|
||||||
|
Me -- -- SP ++ -- ++ MB --
|
||||||
|
-- MS -- -- -- MS ++ -- --
|
||||||
|
++ -- Me -- ME -- ++ -- --
|
||||||
|
"""
|
||||||
|
MAP.map_data_loop = """
|
||||||
|
-- -- -- -- ME -- ME -- ++
|
||||||
|
-- -- MB -- -- -- -- -- --
|
||||||
|
++ ++ ++ -- -- ++ ++ -- ME
|
||||||
|
-- MS -- Me -- Me ++ -- --
|
||||||
|
ME -- ++ -- __ -- -- -- ME
|
||||||
|
-- -- SP -- -- Me -- -- --
|
||||||
|
Me -- -- SP ++ -- ++ MB --
|
||||||
|
-- MS -- -- -- MS ++ -- --
|
||||||
|
++ -- Me -- ME -- ++ -- --
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 1},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CAred']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
MAP_HAS_PORTAL = True
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (80, 255 - 33),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 33, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 33)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
109
campaign/war_archives_20200917_cn/t4.py
Normal file
109
campaign/war_archives_20200917_cn/t4.py
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .t1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('T4')
|
||||||
|
MAP.shape = 'K9'
|
||||||
|
MAP.camera_data = ['D2', 'D5', 'D7', 'H2', 'H5', 'H7']
|
||||||
|
MAP.camera_data_spawn_point = ['D2', 'D7']
|
||||||
|
MAP.portal_data = [('I5', 'C5'), ('C5', 'I5'), ('E5', 'E3'), ('E3', 'E5'), ('G5', 'G7'), ('G7', 'G5')]
|
||||||
|
MAP.map_data = """
|
||||||
|
Me -- -- ++ Me -- ME -- ME ++ ++
|
||||||
|
-- MS -- ++ -- SP -- __ -- MS --
|
||||||
|
-- -- Me ++ -- -- -- ME -- -- --
|
||||||
|
ME -- ++ ++ ++ ++ ++ ++ ++ -- ME
|
||||||
|
-- -- -- ++ -- MB -- ++ -- -- --
|
||||||
|
ME -- ++ ++ ++ ++ ++ ++ ++ -- ME
|
||||||
|
-- -- -- ME -- -- -- ++ Me -- --
|
||||||
|
-- MS -- __ -- SP -- ++ -- MS --
|
||||||
|
++ ++ ME -- ME -- Me ++ -- -- Me
|
||||||
|
"""
|
||||||
|
MAP.map_data_loop = """
|
||||||
|
Me -- -- ++ Me -- ME -- ME ++ ++
|
||||||
|
-- MS -- -- -- SP -- __ -- MS --
|
||||||
|
-- -- Me ++ -- -- -- ME -- -- --
|
||||||
|
ME -- ++ ++ -- ++ -- ++ ++ -- ME
|
||||||
|
-- -- -- ++ -- MB -- ++ -- -- --
|
||||||
|
ME -- ++ ++ -- ++ -- ++ ++ -- ME
|
||||||
|
-- -- -- ME -- -- -- ++ Me -- --
|
||||||
|
-- MS -- __ -- SP -- -- -- MS --
|
||||||
|
++ ++ ME -- ME -- Me ++ -- -- Me
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 10 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2, 'boss': 1},
|
||||||
|
{'battle': 5, 'enemy': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, K1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, K2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, K3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, K4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, K5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, K6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, K7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, K8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, J9, K9, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CL', 'SS']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
MAP_HAS_PORTAL = True
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (80, 255 - 33),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 33, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 33)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.82
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.88
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.config.MAP_HAS_MOVABLE_ENEMY:
|
||||||
|
self.fleet_2_push_forward()
|
||||||
|
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
106
campaign/war_archives_20200917_cn/t5.py
Normal file
106
campaign/war_archives_20200917_cn/t5.py
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .t1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('T5')
|
||||||
|
MAP.shape = 'I9'
|
||||||
|
# MAP.camera_data = ['D2', 'D6', 'D7', 'F2', 'F6', 'F7']
|
||||||
|
# MAP.camera_data_spawn_point = ['F7', 'D2']
|
||||||
|
MAP.camera_data = ['D3', 'D5', 'D7', 'F3', 'F5', 'F7']
|
||||||
|
MAP.camera_data_spawn_point = ['F7', 'D3']
|
||||||
|
MAP.portal_data = [('D3', 'F3'), ('G4', 'G6'), ('F7', 'D7'), ('C6', 'C4')]
|
||||||
|
MAP.map_data = """
|
||||||
|
++ -- -- -- ++ -- MB -- ++
|
||||||
|
-- ME -- ME ++ MS -- MS --
|
||||||
|
Me -- SP -- ++ -- __ -- --
|
||||||
|
-- ME -- Me ++ Me -- ME --
|
||||||
|
++ ++ ++ ++ -- ++ ++ ++ ++
|
||||||
|
-- ME -- Me ++ Me -- ME --
|
||||||
|
-- -- __ -- ++ -- SP -- Me
|
||||||
|
-- MS -- MS ++ ME -- ME --
|
||||||
|
++ -- MB -- ++ -- -- -- ++
|
||||||
|
"""
|
||||||
|
MAP.map_data_loop = """
|
||||||
|
++ -- -- -- ++ -- MB -- ++
|
||||||
|
-- ME -- ME ++ MS -- MS --
|
||||||
|
Me -- SP -- -- -- __ -- --
|
||||||
|
-- ME -- Me ++ Me -- ME --
|
||||||
|
++ ++ -- ++ -- ++ -- ++ ++
|
||||||
|
-- ME -- Me ++ Me -- ME --
|
||||||
|
-- -- __ -- -- -- SP -- Me
|
||||||
|
-- MS -- MS ++ ME -- ME --
|
||||||
|
++ -- MB -- ++ -- -- -- ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CL', 'CAred']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
MAP_HAS_PORTAL = True
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (80, 255 - 33),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 33, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 33)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
101
campaign/war_archives_20200917_cn/t6.py
Normal file
101
campaign/war_archives_20200917_cn/t6.py
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .t1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('T6')
|
||||||
|
MAP.shape = 'K10'
|
||||||
|
# MAP.camera_data = ['D2', 'D6', 'D8', 'H2', 'H6', 'H8']
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'G2', 'G6']
|
||||||
|
MAP.camera_data_spawn_point = ['D6', 'G6']
|
||||||
|
MAP.map_data = """
|
||||||
|
-- -- -- ME -- Me -- ME -- -- --
|
||||||
|
-- ++ ++ -- MS -- MS -- ++ ++ --
|
||||||
|
-- ++ ME -- -- __ -- -- ME ++ --
|
||||||
|
Me -- -- ++ ++ -- ++ ++ -- -- Me
|
||||||
|
++ ME -- ++ MS -- MS ++ -- ME ++
|
||||||
|
++ ME -- -- -- MB -- -- -- ME ++
|
||||||
|
-- -- ++ Me -- -- -- Me ++ -- --
|
||||||
|
-- ++ ++ ++ SP -- SP ++ ++ ++ --
|
||||||
|
++ -- -- ++ ++ -- ++ ++ -- -- ++
|
||||||
|
-- -- -- ++ ++ -- ++ ++ -- -- --
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, K1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, K2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, K3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, K4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, K5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, K6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, K7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, K8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, J9, K9, \
|
||||||
|
A10, B10, C10, D10, E10, F10, G10, H10, I10, J10, K10, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CA', 'SS']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (150, 255 - 17),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 17, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 17)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.446
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.495
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
83
campaign/war_archives_20200917_cn/ts1.py
Normal file
83
campaign/war_archives_20200917_cn/ts1.py
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('TS1')
|
||||||
|
MAP.shape = 'H6'
|
||||||
|
MAP.camera_data = ['D2', 'D4', 'E2', 'E4']
|
||||||
|
MAP.camera_data_spawn_point = ['E4']
|
||||||
|
MAP.map_data = """
|
||||||
|
MB -- ++ ++ ++ ++ -- --
|
||||||
|
-- ME -- -- -- ++ ++ ++
|
||||||
|
++ -- -- -- Me -- -- ++
|
||||||
|
++ ++ ++ ++ -- -- ME --
|
||||||
|
-- -- -- -- ++ ++ -- SP
|
||||||
|
-- ++ -- -- -- ++ SP --
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
# {'battle': 2, 'siren': 1},
|
||||||
|
{'battle': 2, 'enemy': 1},
|
||||||
|
{'battle': 3, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
# MAP_SIREN_TEMPLATE = ['srzl2']
|
||||||
|
# MOVABLE_ENEMY_TURN = (0,)
|
||||||
|
# MAP_HAS_SIREN = True
|
||||||
|
# MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = False
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
STAR_REQUIRE_1 = 0
|
||||||
|
STAR_REQUIRE_2 = 0
|
||||||
|
STAR_REQUIRE_3 = 0
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
STAGE_ENTRANCE = ['blue']
|
||||||
|
FLEET_2 = 0
|
||||||
|
MAP_IS_ONE_TIME_STAGE = True
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (150, 255 - 17),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 17, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 17)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_3(self):
|
||||||
|
return self.clear_boss()
|
82
campaign/war_archives_20200917_cn/ts2.py
Normal file
82
campaign/war_archives_20200917_cn/ts2.py
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
from module.exception import CampaignEnd
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .campaign_base import CampaignBase
|
||||||
|
from .ts1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('TS2')
|
||||||
|
MAP.shape = 'H8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'E2', 'E6']
|
||||||
|
MAP.camera_data_spawn_point = ['D6']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ MM -- -- -- -- -- --
|
||||||
|
++ ++ ++ ++ -- -- -- ++
|
||||||
|
-- -- -- -- -- ++ -- ++
|
||||||
|
-- -- -- ++ ++ ++ -- ++
|
||||||
|
-- ++ -- -- ++ -- -- --
|
||||||
|
-- -- ++ -- -- ++ -- ++
|
||||||
|
-- -- SP ++ MM ++ -- ++
|
||||||
|
MM -- -- ++ ++ ++ -- ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_HAS_MAP_STORY = False
|
||||||
|
MAP_HAS_FLEET_STEP = False
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
STAR_REQUIRE_1 = 0
|
||||||
|
STAR_REQUIRE_2 = 0
|
||||||
|
STAR_REQUIRE_3 = 0
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
INTERNAL_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (150, 255 - 17),
|
||||||
|
'width': (0.9, 10),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 35,
|
||||||
|
}
|
||||||
|
EDGE_LINES_FIND_PEAKS_PARAMETERS = {
|
||||||
|
'height': (255 - 17, 255),
|
||||||
|
'prominence': 10,
|
||||||
|
'distance': 50,
|
||||||
|
'wlen': 1000
|
||||||
|
}
|
||||||
|
HOMO_EDGE_COLOR_RANGE = (0, 17)
|
||||||
|
MAP_ENSURE_EDGE_INSIGHT_CORNER = 'bottom'
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
self.goto(A8, expected='story')
|
||||||
|
self.goto(E7, expected='story')
|
||||||
|
self.goto(B1, expected='story')
|
||||||
|
self.goto(G8, expected='story')
|
||||||
|
|
||||||
|
raise CampaignEnd()
|
70
campaign/war_archives_20210527_cn/a1.py
Normal file
70
campaign/war_archives_20210527_cn/a1.py
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
MAP = CampaignMap('A1')
|
||||||
|
MAP.shape = 'I7'
|
||||||
|
MAP.camera_data = ['D2', 'D5', 'F2', 'F5']
|
||||||
|
MAP.camera_data_spawn_point = ['F2']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ ++ -- ME -- Me ++ -- --
|
||||||
|
++ ++ Me -- -- -- -- -- SP
|
||||||
|
ME -- -- -- ++ MS -- ME SP
|
||||||
|
-- -- ME -- ++ __ ME -- ++
|
||||||
|
MB -- ++ MS -- ME -- -- --
|
||||||
|
-- -- -- -- ME -- Me ++ ME
|
||||||
|
-- ++ -- ME -- -- -- ++ --
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 1},
|
||||||
|
{'battle': 3, 'enemy': 1, 'boss': 1},
|
||||||
|
{'battle': 4, 'enemy': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Dewey']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.778
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.719
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_3(self):
|
||||||
|
return self.clear_boss()
|
75
campaign/war_archives_20210527_cn/a2.py
Normal file
75
campaign/war_archives_20210527_cn/a2.py
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .a1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('A2')
|
||||||
|
MAP.shape = 'H8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'E2', 'E6']
|
||||||
|
MAP.camera_data_spawn_point = ['E6', 'D6']
|
||||||
|
MAP.map_data = """
|
||||||
|
-- ++ ++ ++ -- MB -- ++
|
||||||
|
-- ME -- ME -- ME -- --
|
||||||
|
++ -- MS -- ME ++ Me --
|
||||||
|
-- Me ++ -- Me -- -- --
|
||||||
|
ME -- ++ ME -- __ ME MS
|
||||||
|
-- MS -- Me -- ++ -- --
|
||||||
|
++ -- ME -- -- -- ME ++
|
||||||
|
++ -- -- SP SP -- ++ ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 1},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['DD']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.512
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.462
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
75
campaign/war_archives_20210527_cn/a3.py
Normal file
75
campaign/war_archives_20210527_cn/a3.py
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .a1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('A3')
|
||||||
|
MAP.shape = 'J8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'G2', 'G6']
|
||||||
|
MAP.camera_data_spawn_point = ['G6', 'D6']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ ++ -- ++ ++ -- -- ME ++ ++
|
||||||
|
-- -- MB -- ME -- MS -- ++ ++
|
||||||
|
-- ME -- ME MS Me -- ME -- --
|
||||||
|
-- ++ -- ++ -- __ -- Me -- MS
|
||||||
|
ME ++ -- ++ ME Me ++ -- ME --
|
||||||
|
-- -- -- Me -- -- ME -- -- --
|
||||||
|
-- ME -- -- SP ++ -- ++ SP ++
|
||||||
|
-- ++ ++ ++ -- SP -- SP -- ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 1},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['CL']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.512
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.462
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
79
campaign/war_archives_20210527_cn/b1.py
Normal file
79
campaign/war_archives_20210527_cn/b1.py
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
MAP = CampaignMap('B1')
|
||||||
|
MAP.shape = 'J8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'G2', 'G6']
|
||||||
|
MAP.camera_data_spawn_point = ['D2', 'D6']
|
||||||
|
MAP.map_data = """
|
||||||
|
-- ME -- ME -- -- -- -- ++ ++
|
||||||
|
++ -- MS -- -- Me -- -- MB ++
|
||||||
|
++ -- -- MS Me ++ -- Me -- --
|
||||||
|
SP -- ME -- ME -- ME ++ -- ++
|
||||||
|
SP -- ++ ++ -- __ -- ++ -- ME
|
||||||
|
-- -- ++ ++ Me ME -- ME -- --
|
||||||
|
ME -- MS -- -- -- Me -- ++ ++
|
||||||
|
-- ++ -- ME -- MS -- ++ ++ ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2, 'boss': 1},
|
||||||
|
{'battle': 5, 'enemy': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Hammann', 'CL']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = False
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_ENEMY_GENRE_DETECTION_SCALING = {
|
||||||
|
'DD': 1.111,
|
||||||
|
'CL': 1.111,
|
||||||
|
'CA': 1.111,
|
||||||
|
'CV': 1.111,
|
||||||
|
'BB': 1.111,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
76
campaign/war_archives_20210527_cn/b2.py
Normal file
76
campaign/war_archives_20210527_cn/b2.py
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .b1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('B2')
|
||||||
|
MAP.shape = 'J8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'G2', 'G6']
|
||||||
|
MAP.camera_data_spawn_point = ['G6']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ ++ -- ME -- -- MS ++ ++ ++
|
||||||
|
++ ++ -- ++ ++ -- -- -- -- ME
|
||||||
|
-- Me -- -- ME -- Me -- ++ --
|
||||||
|
ME ++ MS MB -- -- ME -- ++ --
|
||||||
|
-- ++ -- -- ME __ -- MS ++ ME
|
||||||
|
-- ++ -- Me -- -- Me -- -- --
|
||||||
|
ME -- ME -- -- ++ ++ -- -- SP
|
||||||
|
++ ++ ++ MS -- ME -- -- SP ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Atlanta', 'CL']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.523
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.472
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
81
campaign/war_archives_20210527_cn/b3.py
Normal file
81
campaign/war_archives_20210527_cn/b3.py
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .b1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('B3')
|
||||||
|
MAP.shape = 'I9'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'D7', 'F2', 'F6', 'F7']
|
||||||
|
MAP.camera_data_spawn_point = ['F7', 'D7']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ -- ME -- -- -- ME -- ++
|
||||||
|
++ ++ ++ -- MB -- ++ ++ ++
|
||||||
|
ME -- -- -- ++ -- -- -- ME
|
||||||
|
-- ME Me -- Me -- Me ME --
|
||||||
|
-- ++ ++ -- __ -- ++ ++ --
|
||||||
|
MS ++ ++ -- Me -- ++ ++ MS
|
||||||
|
-- ME MS -- -- -- MS ME --
|
||||||
|
ME Me -- ++ -- ++ -- Me ME
|
||||||
|
++ -- -- SP -- SP -- -- ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Dewey', 'Northampton', 'CA']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.477
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.428
|
||||||
|
INTERNAL_LINES_HOUGHLINES_THRESHOLD = 40
|
||||||
|
# EDGE_LINES_HOUGHLINES_THRESHOLD = 40
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
77
campaign/war_archives_20210527_cn/c1.py
Normal file
77
campaign/war_archives_20210527_cn/c1.py
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
MAP = CampaignMap('C1')
|
||||||
|
MAP.shape = 'I7'
|
||||||
|
MAP.camera_data = ['D2', 'D5', 'F2', 'F5']
|
||||||
|
MAP.camera_data_spawn_point = ['F2']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ ++ -- ME -- Me ++ -- --
|
||||||
|
++ ++ Me -- -- -- -- -- SP
|
||||||
|
ME -- -- -- ++ MS -- ME SP
|
||||||
|
-- -- ME -- ++ __ ME -- ++
|
||||||
|
MB -- ++ MS -- ME -- -- --
|
||||||
|
-- -- -- -- ME -- Me ++ ME
|
||||||
|
-- ++ -- ME -- -- -- ++ --
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Dewey', 'CA']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.778
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.719
|
||||||
|
MAP_ENEMY_GENRE_DETECTION_SCALING = {
|
||||||
|
'DD': 1.111,
|
||||||
|
'CL': 1.111,
|
||||||
|
'CA': 1.111,
|
||||||
|
'CV': 1.111,
|
||||||
|
'BB': 1.111,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
81
campaign/war_archives_20210527_cn/c2.py
Normal file
81
campaign/war_archives_20210527_cn/c2.py
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .c1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('C2')
|
||||||
|
MAP.shape = 'H8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'E2', 'E6']
|
||||||
|
MAP.camera_data_spawn_point = ['E6', 'D6']
|
||||||
|
MAP.map_data = """
|
||||||
|
-- ++ ++ ++ -- MB -- ++
|
||||||
|
-- ME -- ME -- ME -- --
|
||||||
|
++ -- MS -- ME ++ Me --
|
||||||
|
-- Me ++ -- Me -- -- --
|
||||||
|
ME -- ++ ME -- __ ME MS
|
||||||
|
-- MS -- Me -- ++ -- --
|
||||||
|
++ -- ME -- -- -- ME ++
|
||||||
|
++ -- -- SP SP -- ++ ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Atlanta', 'CA']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.512
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.462
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(3,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_4(self):
|
||||||
|
return self.clear_boss()
|
82
campaign/war_archives_20210527_cn/c3.py
Normal file
82
campaign/war_archives_20210527_cn/c3.py
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .c1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('C3')
|
||||||
|
MAP.shape = 'J8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'G2', 'G6']
|
||||||
|
MAP.camera_data_spawn_point = ['G6', 'D6']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ ++ -- ++ ++ -- -- ME ++ ++
|
||||||
|
-- -- MB -- ME -- MS -- ++ ++
|
||||||
|
-- ME -- ME MS Me -- ME -- --
|
||||||
|
-- ++ -- ++ -- __ -- Me -- MS
|
||||||
|
ME ++ -- ++ ME Me ++ -- ME --
|
||||||
|
-- -- -- Me -- -- ME -- -- --
|
||||||
|
-- ME -- -- SP ++ -- ++ SP ++
|
||||||
|
-- ++ ++ ++ -- SP -- SP -- ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 1},
|
||||||
|
{'battle': 5, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Northampton', 'CA', 'BB']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.512
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.462
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(3,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
85
campaign/war_archives_20210527_cn/d1.py
Normal file
85
campaign/war_archives_20210527_cn/d1.py
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
MAP = CampaignMap('D1')
|
||||||
|
MAP.shape = 'J8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'G2', 'G6']
|
||||||
|
MAP.camera_data_spawn_point = ['D2', 'D6']
|
||||||
|
MAP.map_data = """
|
||||||
|
-- ME -- ME -- -- -- -- ++ ++
|
||||||
|
++ -- MS -- -- Me -- -- MB ++
|
||||||
|
++ -- -- MS Me ++ -- Me -- --
|
||||||
|
SP -- ME -- ME -- ME ++ -- ++
|
||||||
|
SP -- ++ ++ -- __ -- ++ -- ME
|
||||||
|
-- -- ++ ++ Me ME -- ME -- --
|
||||||
|
ME -- MS -- -- -- Me -- ++ ++
|
||||||
|
-- ++ -- ME -- MS -- ++ ++ ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Hammann', 'Atlanta', 'CA']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = False
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_ENEMY_GENRE_DETECTION_SCALING = {
|
||||||
|
'DD': 1.111,
|
||||||
|
'CL': 1.111,
|
||||||
|
'CA': 1.111,
|
||||||
|
'CV': 1.111,
|
||||||
|
'BB': 1.111,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(3,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
93
campaign/war_archives_20210527_cn/d2.py
Normal file
93
campaign/war_archives_20210527_cn/d2.py
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .d1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('D2')
|
||||||
|
MAP.shape = 'J8'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'G2', 'G6']
|
||||||
|
MAP.camera_data_spawn_point = ['G6']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ ++ -- ME -- -- MS ++ ++ ++
|
||||||
|
++ ++ -- ++ ++ -- -- -- -- ME
|
||||||
|
-- Me -- -- ME -- Me -- ++ --
|
||||||
|
ME ++ MS MB -- -- ME -- ++ --
|
||||||
|
-- ++ -- -- ME __ -- MS ++ ME
|
||||||
|
-- ++ -- Me -- -- Me -- -- --
|
||||||
|
ME -- ME -- -- ++ ++ -- -- SP
|
||||||
|
++ ++ ++ MS -- ME -- -- SP ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1},
|
||||||
|
{'battle': 6, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, J1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, J2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, J3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, J4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, J5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, J6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, J7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, J8, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Dewey', 'Northampton', 'BB']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.523
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.472
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(3,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(3,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_6(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
100
campaign/war_archives_20210527_cn/d3.py
Normal file
100
campaign/war_archives_20210527_cn/d3.py
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
from ..campaign_war_archives.campaign_base import CampaignBase
|
||||||
|
from module.logger import logger
|
||||||
|
from module.map.map_base import CampaignMap
|
||||||
|
from module.map.map_grids import RoadGrids, SelectedGrids
|
||||||
|
|
||||||
|
from .d1 import Config as ConfigBase
|
||||||
|
|
||||||
|
MAP = CampaignMap('D3')
|
||||||
|
MAP.shape = 'I9'
|
||||||
|
MAP.camera_data = ['D2', 'D6', 'D7', 'F2', 'F6', 'F7']
|
||||||
|
MAP.camera_data_spawn_point = ['F7', 'D7']
|
||||||
|
MAP.map_data = """
|
||||||
|
++ -- ME -- -- -- ME -- ++
|
||||||
|
++ ++ ++ -- MB -- ++ ++ ++
|
||||||
|
ME -- -- -- ++ -- -- -- ME
|
||||||
|
-- ME Me -- Me -- Me ME --
|
||||||
|
-- ++ ++ -- __ -- ++ ++ --
|
||||||
|
MS ++ ++ -- Me -- ++ ++ MS
|
||||||
|
-- ME MS -- -- -- MS ME --
|
||||||
|
ME Me -- ++ -- ++ -- Me ME
|
||||||
|
++ -- -- SP -- SP -- -- ++
|
||||||
|
"""
|
||||||
|
MAP.weight_data = """
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
50 50 50 50 50 50 50 50 50
|
||||||
|
"""
|
||||||
|
MAP.spawn_data = [
|
||||||
|
{'battle': 0, 'enemy': 2, 'siren': 2},
|
||||||
|
{'battle': 1, 'enemy': 1},
|
||||||
|
{'battle': 2, 'enemy': 2, 'siren': 1},
|
||||||
|
{'battle': 3, 'enemy': 1},
|
||||||
|
{'battle': 4, 'enemy': 2},
|
||||||
|
{'battle': 5, 'enemy': 1},
|
||||||
|
{'battle': 6, 'boss': 1},
|
||||||
|
]
|
||||||
|
A1, B1, C1, D1, E1, F1, G1, H1, I1, \
|
||||||
|
A2, B2, C2, D2, E2, F2, G2, H2, I2, \
|
||||||
|
A3, B3, C3, D3, E3, F3, G3, H3, I3, \
|
||||||
|
A4, B4, C4, D4, E4, F4, G4, H4, I4, \
|
||||||
|
A5, B5, C5, D5, E5, F5, G5, H5, I5, \
|
||||||
|
A6, B6, C6, D6, E6, F6, G6, H6, I6, \
|
||||||
|
A7, B7, C7, D7, E7, F7, G7, H7, I7, \
|
||||||
|
A8, B8, C8, D8, E8, F8, G8, H8, I8, \
|
||||||
|
A9, B9, C9, D9, E9, F9, G9, H9, I9, \
|
||||||
|
= MAP.flatten()
|
||||||
|
|
||||||
|
|
||||||
|
class Config(ConfigBase):
|
||||||
|
# ===== Start of generated config =====
|
||||||
|
MAP_SIREN_TEMPLATE = ['Atlanta', 'Northampton', 'CV']
|
||||||
|
MOVABLE_ENEMY_TURN = (2,)
|
||||||
|
MAP_HAS_SIREN = True
|
||||||
|
MAP_HAS_MOVABLE_ENEMY = True
|
||||||
|
MAP_HAS_MAP_STORY = True
|
||||||
|
MAP_HAS_FLEET_STEP = True
|
||||||
|
MAP_HAS_AMBUSH = False
|
||||||
|
# ===== End of generated config =====
|
||||||
|
|
||||||
|
MAP_SWIPE_MULTIPLY = 1.477
|
||||||
|
MAP_SWIPE_MULTIPLY_MINITOUCH = 1.428
|
||||||
|
INTERNAL_LINES_HOUGHLINES_THRESHOLD = 40
|
||||||
|
# EDGE_LINES_HOUGHLINES_THRESHOLD = 40
|
||||||
|
|
||||||
|
|
||||||
|
class Campaign(CampaignBase):
|
||||||
|
MAP = MAP
|
||||||
|
|
||||||
|
def battle_0(self):
|
||||||
|
if self.fleet_2_protect():
|
||||||
|
return True
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(3,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_5(self):
|
||||||
|
if self.clear_siren():
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(1,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(2,)):
|
||||||
|
return True
|
||||||
|
if self.clear_enemy(scale=(3,)):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return self.battle_default()
|
||||||
|
|
||||||
|
def battle_6(self):
|
||||||
|
return self.fleet_boss.clear_boss()
|
@ -228,6 +228,7 @@ class CampaignRun(CampaignEvent):
|
|||||||
'event_20200917_cn',
|
'event_20200917_cn',
|
||||||
'event_20221124_cn',
|
'event_20221124_cn',
|
||||||
'event_20230525_cn',
|
'event_20230525_cn',
|
||||||
|
'war_archives_20200917_cn',
|
||||||
# chapter T
|
# chapter T
|
||||||
'event_20211125_cn',
|
'event_20211125_cn',
|
||||||
'event_20231026_cn',
|
'event_20231026_cn',
|
||||||
|
@ -3383,16 +3383,18 @@
|
|||||||
"war_archives_20211014_cn",
|
"war_archives_20211014_cn",
|
||||||
"war_archives_20211028_cn",
|
"war_archives_20211028_cn",
|
||||||
"war_archives_20220210_cn",
|
"war_archives_20220210_cn",
|
||||||
"war_archives_20220414_cn"
|
"war_archives_20220414_cn",
|
||||||
|
"war_archives_20200917_cn",
|
||||||
|
"war_archives_20210527_cn"
|
||||||
],
|
],
|
||||||
"option_bold": [
|
"option_bold": [
|
||||||
"war_archives_20201229_cn",
|
"war_archives_20201229_cn",
|
||||||
"war_archives_20220414_cn"
|
"war_archives_20210527_cn"
|
||||||
],
|
],
|
||||||
"cn": "war_archives_20201229_cn",
|
"cn": "war_archives_20210527_cn",
|
||||||
"en": "war_archives_20201229_cn",
|
"en": "war_archives_20210527_cn",
|
||||||
"jp": "war_archives_20201229_cn",
|
"jp": "war_archives_20210527_cn",
|
||||||
"tw": "war_archives_20220414_cn"
|
"tw": "war_archives_20210527_cn"
|
||||||
},
|
},
|
||||||
"Mode": {
|
"Mode": {
|
||||||
"type": "select",
|
"type": "select",
|
||||||
|
@ -740,7 +740,9 @@
|
|||||||
"war_archives_20211014_cn": "archives Crescendo of Polaris",
|
"war_archives_20211014_cn": "archives Crescendo of Polaris",
|
||||||
"war_archives_20211028_cn": "archives Skybound Oratorio",
|
"war_archives_20211028_cn": "archives Skybound Oratorio",
|
||||||
"war_archives_20220210_cn": "archives Northern Overture",
|
"war_archives_20220210_cn": "archives Northern Overture",
|
||||||
"war_archives_20220414_cn": "archives Aurora Noctis"
|
"war_archives_20220414_cn": "archives Aurora Noctis",
|
||||||
|
"war_archives_20200917_cn": "archives Dreamwaker's Butterfly",
|
||||||
|
"war_archives_20210527_cn": "archives Mirror Involution"
|
||||||
},
|
},
|
||||||
"Mode": {
|
"Mode": {
|
||||||
"name": "Level Mode",
|
"name": "Level Mode",
|
||||||
|
@ -740,7 +740,9 @@
|
|||||||
"war_archives_20211014_cn": "檔案 激奏のポラリス",
|
"war_archives_20211014_cn": "檔案 激奏のポラリス",
|
||||||
"war_archives_20211028_cn": "檔案 神穹を衝く聖歌",
|
"war_archives_20211028_cn": "檔案 神穹を衝く聖歌",
|
||||||
"war_archives_20220210_cn": "檔案 凍絶の北海",
|
"war_archives_20220210_cn": "檔案 凍絶の北海",
|
||||||
"war_archives_20220414_cn": "檔案 極夜照らす幻光"
|
"war_archives_20220414_cn": "檔案 極夜照らす幻光",
|
||||||
|
"war_archives_20200917_cn": "檔案 刹那觀る胡蝶の夢",
|
||||||
|
"war_archives_20210527_cn": "檔案 照らす螺旋の鏡海"
|
||||||
},
|
},
|
||||||
"Mode": {
|
"Mode": {
|
||||||
"name": "Campaign.Mode.name",
|
"name": "Campaign.Mode.name",
|
||||||
|
@ -740,7 +740,9 @@
|
|||||||
"war_archives_20211014_cn": "档案 激奏的Polaris",
|
"war_archives_20211014_cn": "档案 激奏的Polaris",
|
||||||
"war_archives_20211028_cn": "档案 穹顶下的圣咏曲",
|
"war_archives_20211028_cn": "档案 穹顶下的圣咏曲",
|
||||||
"war_archives_20220210_cn": "档案 北境序曲",
|
"war_archives_20220210_cn": "档案 北境序曲",
|
||||||
"war_archives_20220414_cn": "档案 永夜幻光"
|
"war_archives_20220414_cn": "档案 永夜幻光",
|
||||||
|
"war_archives_20200917_cn": "档案 蝶海梦花",
|
||||||
|
"war_archives_20210527_cn": "档案 镜位螺旋"
|
||||||
},
|
},
|
||||||
"Mode": {
|
"Mode": {
|
||||||
"name": "关卡模式",
|
"name": "关卡模式",
|
||||||
|
@ -740,7 +740,9 @@
|
|||||||
"war_archives_20211014_cn": "archives Crescendo of Polaris",
|
"war_archives_20211014_cn": "archives Crescendo of Polaris",
|
||||||
"war_archives_20211028_cn": "檔案 穹頂下的聖詠曲",
|
"war_archives_20211028_cn": "檔案 穹頂下的聖詠曲",
|
||||||
"war_archives_20220210_cn": "檔案 北境序曲",
|
"war_archives_20220210_cn": "檔案 北境序曲",
|
||||||
"war_archives_20220414_cn": "檔案 永夜幻光"
|
"war_archives_20220414_cn": "檔案 永夜幻光",
|
||||||
|
"war_archives_20200917_cn": "檔案 蝶海夢花",
|
||||||
|
"war_archives_20210527_cn": "檔案 鏡位螺旋"
|
||||||
},
|
},
|
||||||
"Mode": {
|
"Mode": {
|
||||||
"name": "地圖模式",
|
"name": "地圖模式",
|
||||||
|
@ -10,6 +10,7 @@ TEMPLATE_AURORA_NOCTIS = Template(file={'cn': './assets/cn/war_archives/TEMPLATE
|
|||||||
TEMPLATE_CRESCENDO_OF_POLARIS = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_CRESCENDO_OF_POLARIS.png', 'en': './assets/en/war_archives/TEMPLATE_CRESCENDO_OF_POLARIS.png', 'jp': './assets/jp/war_archives/TEMPLATE_CRESCENDO_OF_POLARIS.png', 'tw': './assets/cn/war_archives/TEMPLATE_CRESCENDO_OF_POLARIS.png'})
|
TEMPLATE_CRESCENDO_OF_POLARIS = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_CRESCENDO_OF_POLARIS.png', 'en': './assets/en/war_archives/TEMPLATE_CRESCENDO_OF_POLARIS.png', 'jp': './assets/jp/war_archives/TEMPLATE_CRESCENDO_OF_POLARIS.png', 'tw': './assets/cn/war_archives/TEMPLATE_CRESCENDO_OF_POLARIS.png'})
|
||||||
TEMPLATE_CRIMSON_ECHOES = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_CRIMSON_ECHOES.png', 'en': './assets/en/war_archives/TEMPLATE_CRIMSON_ECHOES.png', 'jp': './assets/jp/war_archives/TEMPLATE_CRIMSON_ECHOES.png', 'tw': './assets/cn/war_archives/TEMPLATE_CRIMSON_ECHOES.png'})
|
TEMPLATE_CRIMSON_ECHOES = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_CRIMSON_ECHOES.png', 'en': './assets/en/war_archives/TEMPLATE_CRIMSON_ECHOES.png', 'jp': './assets/jp/war_archives/TEMPLATE_CRIMSON_ECHOES.png', 'tw': './assets/cn/war_archives/TEMPLATE_CRIMSON_ECHOES.png'})
|
||||||
TEMPLATE_DIVERGENT_CHESSBOARD = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_DIVERGENT_CHESSBOARD.png', 'en': './assets/en/war_archives/TEMPLATE_DIVERGENT_CHESSBOARD.png', 'jp': './assets/jp/war_archives/TEMPLATE_DIVERGENT_CHESSBOARD.png', 'tw': './assets/tw/war_archives/TEMPLATE_DIVERGENT_CHESSBOARD.png'})
|
TEMPLATE_DIVERGENT_CHESSBOARD = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_DIVERGENT_CHESSBOARD.png', 'en': './assets/en/war_archives/TEMPLATE_DIVERGENT_CHESSBOARD.png', 'jp': './assets/jp/war_archives/TEMPLATE_DIVERGENT_CHESSBOARD.png', 'tw': './assets/tw/war_archives/TEMPLATE_DIVERGENT_CHESSBOARD.png'})
|
||||||
|
TEMPLATE_DREAMWAKERS_BUTTERFLY = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_DREAMWAKERS_BUTTERFLY.png', 'en': './assets/cn/war_archives/TEMPLATE_DREAMWAKERS_BUTTERFLY.png', 'jp': './assets/cn/war_archives/TEMPLATE_DREAMWAKERS_BUTTERFLY.png', 'tw': './assets/cn/war_archives/TEMPLATE_DREAMWAKERS_BUTTERFLY.png'})
|
||||||
TEMPLATE_EMPYREAL_TRAGICOMEDY = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_EMPYREAL_TRAGICOMEDY.png', 'en': './assets/en/war_archives/TEMPLATE_EMPYREAL_TRAGICOMEDY.png', 'jp': './assets/cn/war_archives/TEMPLATE_EMPYREAL_TRAGICOMEDY.png', 'tw': './assets/cn/war_archives/TEMPLATE_EMPYREAL_TRAGICOMEDY.png'})
|
TEMPLATE_EMPYREAL_TRAGICOMEDY = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_EMPYREAL_TRAGICOMEDY.png', 'en': './assets/en/war_archives/TEMPLATE_EMPYREAL_TRAGICOMEDY.png', 'jp': './assets/cn/war_archives/TEMPLATE_EMPYREAL_TRAGICOMEDY.png', 'tw': './assets/cn/war_archives/TEMPLATE_EMPYREAL_TRAGICOMEDY.png'})
|
||||||
TEMPLATE_ENCIRCLING_GRAF_SPEE = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_ENCIRCLING_GRAF_SPEE.png', 'en': './assets/en/war_archives/TEMPLATE_ENCIRCLING_GRAF_SPEE.png', 'jp': './assets/jp/war_archives/TEMPLATE_ENCIRCLING_GRAF_SPEE.png', 'tw': './assets/tw/war_archives/TEMPLATE_ENCIRCLING_GRAF_SPEE.png'})
|
TEMPLATE_ENCIRCLING_GRAF_SPEE = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_ENCIRCLING_GRAF_SPEE.png', 'en': './assets/en/war_archives/TEMPLATE_ENCIRCLING_GRAF_SPEE.png', 'jp': './assets/jp/war_archives/TEMPLATE_ENCIRCLING_GRAF_SPEE.png', 'tw': './assets/tw/war_archives/TEMPLATE_ENCIRCLING_GRAF_SPEE.png'})
|
||||||
TEMPLATE_FALLEN_WINGS = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_FALLEN_WINGS.png', 'en': './assets/en/war_archives/TEMPLATE_FALLEN_WINGS.png', 'jp': './assets/jp/war_archives/TEMPLATE_FALLEN_WINGS.png', 'tw': './assets/tw/war_archives/TEMPLATE_FALLEN_WINGS.png'})
|
TEMPLATE_FALLEN_WINGS = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_FALLEN_WINGS.png', 'en': './assets/en/war_archives/TEMPLATE_FALLEN_WINGS.png', 'jp': './assets/jp/war_archives/TEMPLATE_FALLEN_WINGS.png', 'tw': './assets/tw/war_archives/TEMPLATE_FALLEN_WINGS.png'})
|
||||||
@ -18,6 +19,7 @@ TEMPLATE_INK_STAINED_STEEL_SAKURA = Template(file={'cn': './assets/cn/war_archiv
|
|||||||
TEMPLATE_INVERTED_ORTHANT = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_INVERTED_ORTHANT.png', 'en': './assets/cn/war_archives/TEMPLATE_INVERTED_ORTHANT.png', 'jp': './assets/cn/war_archives/TEMPLATE_INVERTED_ORTHANT.png', 'tw': './assets/cn/war_archives/TEMPLATE_INVERTED_ORTHANT.png'})
|
TEMPLATE_INVERTED_ORTHANT = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_INVERTED_ORTHANT.png', 'en': './assets/cn/war_archives/TEMPLATE_INVERTED_ORTHANT.png', 'jp': './assets/cn/war_archives/TEMPLATE_INVERTED_ORTHANT.png', 'tw': './assets/cn/war_archives/TEMPLATE_INVERTED_ORTHANT.png'})
|
||||||
TEMPLATE_IRIS_OF_LIGHT_AND_DARK = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_IRIS_OF_LIGHT_AND_DARK.png', 'en': './assets/en/war_archives/TEMPLATE_IRIS_OF_LIGHT_AND_DARK.png', 'jp': './assets/jp/war_archives/TEMPLATE_IRIS_OF_LIGHT_AND_DARK.png', 'tw': './assets/cn/war_archives/TEMPLATE_IRIS_OF_LIGHT_AND_DARK.png'})
|
TEMPLATE_IRIS_OF_LIGHT_AND_DARK = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_IRIS_OF_LIGHT_AND_DARK.png', 'en': './assets/en/war_archives/TEMPLATE_IRIS_OF_LIGHT_AND_DARK.png', 'jp': './assets/jp/war_archives/TEMPLATE_IRIS_OF_LIGHT_AND_DARK.png', 'tw': './assets/cn/war_archives/TEMPLATE_IRIS_OF_LIGHT_AND_DARK.png'})
|
||||||
TEMPLATE_MICROLAYER_MEDLEY = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_MICROLAYER_MEDLEY.png', 'en': './assets/en/war_archives/TEMPLATE_MICROLAYER_MEDLEY.png', 'jp': './assets/cn/war_archives/TEMPLATE_MICROLAYER_MEDLEY.png', 'tw': './assets/cn/war_archives/TEMPLATE_MICROLAYER_MEDLEY.png'})
|
TEMPLATE_MICROLAYER_MEDLEY = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_MICROLAYER_MEDLEY.png', 'en': './assets/en/war_archives/TEMPLATE_MICROLAYER_MEDLEY.png', 'jp': './assets/cn/war_archives/TEMPLATE_MICROLAYER_MEDLEY.png', 'tw': './assets/cn/war_archives/TEMPLATE_MICROLAYER_MEDLEY.png'})
|
||||||
|
TEMPLATE_MIRROR_INVOLUTION = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_MIRROR_INVOLUTION.png', 'en': './assets/cn/war_archives/TEMPLATE_MIRROR_INVOLUTION.png', 'jp': './assets/cn/war_archives/TEMPLATE_MIRROR_INVOLUTION.png', 'tw': './assets/cn/war_archives/TEMPLATE_MIRROR_INVOLUTION.png'})
|
||||||
TEMPLATE_NORTHERN_OVERTURE = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_NORTHERN_OVERTURE.png', 'en': './assets/en/war_archives/TEMPLATE_NORTHERN_OVERTURE.png', 'jp': './assets/cn/war_archives/TEMPLATE_NORTHERN_OVERTURE.png', 'tw': './assets/cn/war_archives/TEMPLATE_NORTHERN_OVERTURE.png'})
|
TEMPLATE_NORTHERN_OVERTURE = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_NORTHERN_OVERTURE.png', 'en': './assets/en/war_archives/TEMPLATE_NORTHERN_OVERTURE.png', 'jp': './assets/cn/war_archives/TEMPLATE_NORTHERN_OVERTURE.png', 'tw': './assets/cn/war_archives/TEMPLATE_NORTHERN_OVERTURE.png'})
|
||||||
TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD.png', 'en': './assets/en/war_archives/TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD.png', 'jp': './assets/cn/war_archives/TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD.png', 'tw': './assets/cn/war_archives/TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD.png'})
|
TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD.png', 'en': './assets/en/war_archives/TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD.png', 'jp': './assets/cn/war_archives/TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD.png', 'tw': './assets/cn/war_archives/TEMPLATE_SCHERZO_OF_IRON_AND_BLOOD.png'})
|
||||||
TEMPLATE_SKYBOUND_ORATORIO = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_SKYBOUND_ORATORIO.png', 'en': './assets/en/war_archives/TEMPLATE_SKYBOUND_ORATORIO.png', 'jp': './assets/cn/war_archives/TEMPLATE_SKYBOUND_ORATORIO.png', 'tw': './assets/cn/war_archives/TEMPLATE_SKYBOUND_ORATORIO.png'})
|
TEMPLATE_SKYBOUND_ORATORIO = Template(file={'cn': './assets/cn/war_archives/TEMPLATE_SKYBOUND_ORATORIO.png', 'en': './assets/en/war_archives/TEMPLATE_SKYBOUND_ORATORIO.png', 'jp': './assets/cn/war_archives/TEMPLATE_SKYBOUND_ORATORIO.png', 'tw': './assets/cn/war_archives/TEMPLATE_SKYBOUND_ORATORIO.png'})
|
||||||
|
@ -24,4 +24,6 @@ dic_archives_template = {
|
|||||||
'war_archives_20220210_cn': TEMPLATE_NORTHERN_OVERTURE,
|
'war_archives_20220210_cn': TEMPLATE_NORTHERN_OVERTURE,
|
||||||
'war_archives_20220414_cn': TEMPLATE_AURORA_NOCTIS,
|
'war_archives_20220414_cn': TEMPLATE_AURORA_NOCTIS,
|
||||||
'war_archives_20201229_cn': TEMPLATE_INVERTED_ORTHANT,
|
'war_archives_20201229_cn': TEMPLATE_INVERTED_ORTHANT,
|
||||||
|
'war_archives_20200917_cn': TEMPLATE_DREAMWAKERS_BUTTERFLY,
|
||||||
|
'war_archives_20210527_cn': TEMPLATE_MIRROR_INVOLUTION,
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user