-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathCameraWorkMacro.ks
182 lines (173 loc) · 6.82 KB
/
CameraWorkMacro.ks
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
176
177
178
179
180
181
182
;yu-risのようなカメラ機能を加えるマクロ
;TJSに挑戦!で配布しているexmove.ksをラップして、
;すべてのレイヤーを同じ方向、同じ点を中心に同時に
;移動、回転, 拡大縮小させることで実現しています。
;exmove.ksの使用のため背景レイヤにはつかえないので
;一時的に前景レイヤを背景レイヤとして使うことになります。
;
;@camera_Init baselayer=0 messagelayer=1
;最初にメッセージレイヤの枠を表示するレイヤ(あったら)、
;背景として使うレイヤを指定する。
;ここで設定したbaselayerよりおおきいレイヤ番号のレイヤに作用する。
;
;使えるタグ
;@camera cx=絶対座標 cy=絶対座標 angle=傾き close=倍率(%) time=時間 accel=加速度 delay= opacity=(255) except=例外レイヤ
;cx,cyで指定した位置に視点を移動する。
;closeで倍率指定 100で通常の大きさ、200で倍
;angle cx, cyで指定した位置中心に回転する
; angleに360の整数倍を指定してはいけない、
; その後の回転がおかしくなる。使ってもいいが、
; すぐに@camera_resetをすること
; 回転を使った後通常の画面に戻ったら必ずすぐに
; @camera_resetをすること
;
; 注意!! (バグが多過ぎるので画面の中心以外を回転軸にはしないでください)
;
;except ここで指定したレイヤには動作しない
;
;@camera_wait
;@camera_moveの動作を待つ
;
;@camera_reset
;変数を初期化する。回転後、タイトル画面で使う
;回転機能を使わないなら、必要なし
@iscript
var camera = %[];
f.CameraWorkMacro = %[];
function camera_Init(elm)
{
f.CameraWorkMacro.pre_top = %[];
f.CameraWorkMacro.pre_left = %[];
camera.messagelayer = 'kara';
camera.messagelayer = elm.messagelayer if elm.messagelayer !== void;
camera.baselayer = elm.baselayer;
}
function camera_reset()
{
f.CameraWorkMacro.pre_cx = void;
f.CameraWorkMacro.pre_cy = void;
(Dictionary.clear incontextof f.CameraWorkMacro.pre_top )();
(Dictionary.clear incontextof f.CameraWorkMacro.pre_left)();
}
function camera_move(elm)
{
elm.camerax = elm.cx;
elm.cameray = elm.cy;
elm.time = 500 if elm.time === void;
elm.opacity = 255 if elm.opacity === void;
for ( var i=(int) camera.baselayer; i<kag.numCharacterLayers; i++ )
{
if ( i != camera.messagelayer || i != elm.except)
{
elm.layer = (string)i;
elm.path = '(' + ( kag.fore.layers[i].left + kag.scWidth/2 - elm.camerax ) + ', ' + ( kag.fore.layers[i].top + kag.scHeight/2 - elm.cameray ) + ', ' + elm.opacity + ')';
kag.tagHandlers.move(elm);
}
}
}
function camera_exmove(elm)
{
elm.close = 100 if elm.close === void;
elm.angle = 0 if elm.angle === void;
elm.opacity = 255 if elm.opacity === void;
elm.time = 500 if elm.time === void;
elm.except = 'kara' if elm.except === void;
elm.layer = camera.baselayer;
elm.cx = kag.scWidth/2 if elm.cx === void;
elm.cy = kag.scHeight/2 if elm.cy === void;
elm.camerax = elm.cx;
elm.cameray = elm.cy;
if (f.CameraWorkMacro.pre_angle == 0)
{
for ( var i=(int) camera.baselayer ; i<kag.numCharacterLayers; i++ )
{
if (i != camera.messagelayer && i != elm.except )
{
elm.layer = (string)i;
elm.cx = (string)(elm.camerax - kag.fore.layers[i].left);
elm.cy = (string)(elm.cameray - kag.fore.layers[i].top);
elm.path = '(' + kag.scWidth/2 + ', ' + kag.scHeight/2 + ', ' + elm.opacity + ', ' + elm.close + ', ' + elm.angle + ')';
ExtendedMover.beginMove(mp);
f.CameraWorkMacro.pre_top[i] = kag.fore.layers[i].top;
f.CameraWorkMacro.pre_left[i] = kag.fore.layers[i].left;
//Debug.message('path: ' + elm.path);
//Debug.message('cx: ' + elm.cx);
//Debug.message('cy: ' + elm.cy);
}
}
}
else
{
for ( var i=(int) camera.baselayer; i<kag.numCharacterLayers; i++ )
{
if (i != camera.messagelayer && i != elm.except)
{
//Debug.message(i);
//Debug.message('pre_left: '+f.CameraWorkMacro.pre_left[i]);
//Debug.message('pre_top: '+f.CameraWorkMacro.pre_top[i]);
//Debug.message('pre_cx: '+f.CameraWorkMacro.pre_cx);
//Debug.message('pre_cy: '+f.CameraWorkMacro.pre_cy);
var r = Math.sqrt(Math.pow((f.CameraWorkMacro.pre_left[i] - f.CameraWorkMacro.pre_cx),2) + Math.pow((f.CameraWorkMacro.pre_top[i] - f.CameraWorkMacro.pre_cy),2));
var angle = f.CameraWorkMacro.pre_top[i] < f.CameraWorkMacro.pre_cy ? f.CameraWorkMacro.pre_angle*3.14159265/180 - Math.acos( 1 - (Math.pow(f.CameraWorkMacro.pre_left[i] - f.CameraWorkMacro.pre_cx - r,2) + Math.pow(f.CameraWorkMacro.pre_top[i] - f.CameraWorkMacro.pre_cy,2)) / ( 2*Math.pow(r,2) ) ) : (f.CameraWorkMacro.pre_angle - 360)*3.14159265/180 + Math.acos( 1 - (Math.pow(f.CameraWorkMacro.pre_left[i] - f.CameraWorkMacro.pre_cx - r,2) + Math.pow(f.CameraWorkMacro.pre_top[i] - f.CameraWorkMacro.pre_cy,2)) / ( 2*Math.pow(r,2) ) );
var now_left = r*Math.cos(angle) + kag.scWidth/2;
var now_top = r*Math.sin(angle) + kag.scHeight/2;
var a = 100;
var b = Math.pow(now_left - elm.camerax,2) + Math.pow(now_top - elm.cameray,2);
var c = Math.pow(now_left - (int)elm.camerax + 10,2) + Math.pow(now_top - (int)elm.cameray, 2);
var angle2 = elm.cameray >= now_top ? Math.acos( (a + b - c)/(2*Math.sqrt(a*b)) ) - f.CameraWorkMacro.pre_angle*3.14159265/180 : ( 360 - f.CameraWorkMacro.pre_angle)*3.14159265/180 - Math.acos( (a + b - c)/(2*Math.sqrt(a*b)) );
elm.cx = (string) (int) (Math.sqrt(b)*Math.cos(angle2));
elm.cy = (string) (int) (Math.sqrt(b)*Math.sin(angle2));
elm.path = '(' + kag.scWidth/2 + ', ' + kag.scHeight/2 + ', ' + elm.opacity + ', ' + elm.close + ', ' + elm.angle + ')';
elm.layer = (string)i;
//Debug.message(i);
//Debug.message(elm.cameray);
//Debug.message('r: ' + r);
//Debug.message('angle: ' + angle*180/3.14);
//Debug.message('left: ' + now_left);
//Debug.message('top: ' + now_top);
//Debug.message(a);
//Debug.message(b);
//Debug.message(c);
//Debug.message('path: ' + elm.path);
//Debug.message('cx: ' + elm.cx);
//Debug.message('cy: ' + elm.cy);
//Debug.message('angle2: ' + angle2*180/3.14);
ExtendedMover.beginMove(mp);
f.CameraWorkMacro.pre_top[i] = now_left;
f.CameraWorkMacro.pre_left[i] = now_top;
}
}
}
f.CameraWorkMacro.pre_cx = elm.camerax;
f.CameraWorkMacro.pre_cy = elm.cameray;
f.CameraWorkMacro.pre_angle = elm.angle;
}
@endscript
;マクロ登録
;初期化
@macro name=camera_Init
@eval exp="camera_Init(mp)"
@endmacro
;カメラを動かす。
@macro name=camera_move
@eval exp="camera_exmove(mp)" cond="mp.close !== void || mp.angle !== void"
@eval exp="camera_move(mp)" cond="mp.close === void"
@endmacro
;ウェイト
@macro name=camera_wait
@call storage=CameraWorkMacro.ks target=*camera_wait
@endmacro
;変数リセット
@macro name=camera_reset
@eval exp="camera_reset()"
@endmacro
@return
;サブルーチン
*camera_wait
@wm
@eval exp="camera.count = camera.messagelayer === void ? (int)camera.baselayer + 1: (int)camera.baselayer + 2"
*step
@wm
@eval exp="camera.count += 1"
@jump storage="CameraWorkMacro.ks" target=*step cond="camera.count < kag.numCharacterLayers"
@return