-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfgosccalc.py
executable file
·175 lines (154 loc) · 4.91 KB
/
fgosccalc.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
#!/usr/bin/env python3
"""
fgosccalc CLI フロントエンド
"""
import argparse
import logging
import re
import sys
from io import BytesIO
from pathlib import Path
import cv2
import img2str
##from lib.setting import setting_file_path
##from lib.twitter import create_access_key_secret
from lib.twitter import upload_file
from dropitemseditor import (
DropsDiff,
get_questinfo,
get_questnames,
make_diff,
make_owned_diff,
detect_upper,
merge_sc,
read_owned_ss,
detect_missing_item,
ScrollPositionError
)
logging.basicConfig(level=logging.INFO, format='[%(levelname)s] %(message)s')
logger = logging.getLogger(__name__)
def parse_args():
parser = argparse.ArgumentParser()
parser.add_argument(
'-b', '--before',
nargs='+',
required=True,
help='1st screenshot(s)',
)
parser.add_argument(
'-a', '--after',
nargs='+',
required=True,
help='2nd screenshot(s)',
)
parser.add_argument(
'-o', '--owned',
nargs='+',
help='owned item scrennshot(s)',
)
parser.add_argument(
'-u', '--upload',
action='store_true',
help='upload images on twiter',
)
parser.add_argument(
'--loglevel',
choices=('DEBUG', 'INFO', 'WARNING'),
default='WARNING',
help='loglevel [default: WARNING]',
)
parser.add_argument(
'--output',
type=argparse.FileType('w'),
default=sys.stdout,
help='output file [default: STDOUT]',
)
return parser.parse_args()
def main(args):
dropitems = img2str.DropItems()
svm = cv2.ml.SVM_load(str(img2str.training))
# 素材が埋まっている可能性が高い周回後スクショから認識する
sc_after = []
for f in args.after:
file = Path(f)
img_rgb = img2str.imread(str(file))
sc = img2str.ScreenShot(img_rgb, svm, dropitems)
if len(sc.itemlist) == 0:
logger.error("After File: %s", sc.error)
exit()
sc_after.append(sc)
# スクロール上下を決める
try:
sc2 = detect_upper(sc_after)
except ScrollPositionError:
logger.critical("スクロール位置が同じファイルを認識しています")
exit()
# マージしたリストを作る
sc2_itemlist = merge_sc(sc_after)
logger.debug('sc_after0: %s', sc_after[0].itemlist)
if len(sc_after) == 2:
logger.debug('sc_after1: %s', sc_after[1].itemlist)
logger.debug('sc2: %s', sc2_itemlist)
sc_before = []
for f in args.before:
file = Path(f)
img_rgb = img2str.imread(str(file))
sc = img2str.ScreenShot(img_rgb, svm, dropitems)
if len(sc.itemlist) == 0:
logger.error("Before File: %s", sc.error)
exit()
sc_before.append(sc)
# スクロール上下を決める
try:
sc1 = detect_upper(sc_before)
except ScrollPositionError:
logger.critical("スクロール位置が同じファイルを認識しています")
exit()
# マージしたリストを作る
sc1_itemlist = merge_sc(sc_before)
logger.debug('sc_before0: %s', sc_before[0].itemlist)
if len(sc_before) == 2:
logger.debug('sc_before1: %s', sc_before[1].itemlist)
logger.debug('sc1: %s', sc1.itemlist)
# 足りないアイテムを求める
miss_items = detect_missing_item(sc2_itemlist, sc1_itemlist)
if args.owned:
code, owned_list = read_owned_ss(args.owned, dropitems, svm, miss_items)
else:
code = -1
if args.owned:
logger.debug('owned_list: %s', owned_list)
owned_diff = []
if code == 0:
owned_diff = make_owned_diff(sc1_itemlist, sc2_itemlist, owned_list)
newdic = make_diff(sc1_itemlist, sc2_itemlist, owned=owned_diff)
_, droplist = get_questinfo(sc1, sc2)
questnames = get_questnames(sc1, sc2)
if len(questnames) > 1:
logger.warning("クエスト名候補が複数あります: %s", questnames)
if len(questnames) > 0:
questname = questnames[0]
else:
questname = ""
logger.debug('questname: %s', questname)
logger.debug('questdrop: %s', droplist)
obj = DropsDiff(newdic, questname, droplist)
is_valid = obj.validate_dropitems()
parsed_obj = obj.parse(dropitems)
url = ""
if args.upload:
url = upload_file(args)
output = parsed_obj.as_syukai_counter(url)
if not is_valid:
logger.info('スクリーンショットからクエストを特定できません')
args.output.write(output)
if __name__ == '__main__':
args = parse_args()
logger.setLevel(args.loglevel)
if len(args.before) != len(args.after):
logger.critical('前後でスクショ数が合いません')
exit(1)
elif len(args.before) > 2:
logger.critical('3ペア以上のスクショ比較には対応していません')
exit(1)
main(args)