Professional Documents
Culture Documents
Phần mở đầu
Đây sẽ là hướng dẫn sườn cho các bạn khởi đầu viết karaoke đầu tiên.
Một template code của karaoke đơn giản nên có ba dòng xác định thời gian như sau, tùy độ phức tạp có thể thêm bớt
những cái khác. Tuy chia ra như thế nhưng thời gian của cả 3 line là khớp đầu-cuối với nhau lên tính tổng thể vẫn liên
tục.
Code:
Giải thích:
+ Chúng ta sử dụng template syl để tạo cho mỗi âm của cả dòng karaoke một line riêng. Các sắp line như thế sẽ không
làm các âm trong dòng kara ấy ảnh hưởng lẫn nhau, dễ tạo các hiệu ứng hơn.
noblank mục đích để loại bỏ những dấu cách, những phần tag \k không có chữ để sub nhẹ hơn
+ Phần !retime! chính là phần xác định lại thời gian (re timming) cho line so với thời gian gốc. Cấu trúc của nó là
!retime("vị trí", độ lệch bắt đầu, độ lệch kết thúc)!
!retime("start2syl", 0, 0)! là khoảng thời tính từ đầu line đến đầu của âm (syl), đó là khoảng thời gian chưa hát tới.
Mực lệch ở đây là 0 , nghĩa là không thay đổi gì với kara gốc.
!retime("syl", 0, 0)! là khoảng thời gian của âm đó, tiếng hát sẽ có ở đây. Hiệu ứng nằm ở phần này là chủ yếu.
!retime("syl2end", 0, 0)! là khoảng thời gian tính từ cuối âm đó đến hết line, đó là khoảng thời gian đã hát qua.
Các hiệu ứng kiểu dáng và màu sắc
Giờ tôi sẽ định hướng cho các bạn về dạng này, đầy là dạng hiệu ứng dễ để bắt đầu.
- Đổi đổi màu chữ, viền,...
Đây là hiệu ứng, khi hát tới nơi chữ sẽ có viền lớn hơn và hát xong chữ sẽ trở lại lúc đầu (có thể thấy ở OP Kimi ni
Todoke [Eclipse] khá hợp với video dù hiệu ứng đơn giản)
Code:
Giải thích:
- Phần start2syl và syl2end là giống nhau, ở đây sử dụng \an5 để các chữ đựng neo ở chính giữa điểm \pos(), các hiệu
ứng sẽ được đều về mọi phía. Ví trí đặt chữ ở đây là trung tâm của chữ khi ở line gốc, ta gọi tọa độ ấy ra bằng hai time
số $scenter và $smiddle. \an5 và ($scenter, $smiddle) thường đi cũng với nhau.
- Phần từ bắt đầu đến lúc hát đến nơi (start2syl) thì viền của chữ sẽ ở mức 1 nhờ tag \bord1.
- Trong khi hát (syl) thì chữ sẽ có mức viền \bord2 và giữ nguyên đến hết âm. Ở đây không sử dụng tag biển đổi \t()
nên viền của chữ sẽ tăng lên ngay lập tức
- Sau khi qua âm đó đến hết line (syl2end) chữ sẽ lập tức trở về mức viền \bord1. Thời gian của line mới giữ nguyên
với line kara gốc
Để đổi thêm màu của chữ, kích thước chữ,... ta có thể cho thêm những tag đó vào.
Code:
layer 0 template syl noblank: !retime("start2syl", 0, 0)!{\an5\pos($scenter,
$smiddle)\bord1\c!line.styleref.color1!}
layer 1 template syl noblank: !retime("syl", 0, 0)!{\an5\pos($scenter,
$smiddle)\bord2\c!line.styleref.color2!\3c&HFFFFFF&\fscx120}
layer 0 template syl noblank: !retime("syl2end", 0, 0)!{\an5\pos($scenter,
$smiddle)\bord1\c!line.styleref.color1!\3c&HFFFFFF}
Giải thích:
Đây là phát triển thêm của hiệu ứng trước, các phần cũ không nói thêm
- Ở phần start2syl, thay vì đưa thẳng mã màu vào (cũng chẳng nhớ màu nào) cho tag \c, ta dùng tham số
này !line.styleref.color1! để auto4 tự đưa mã màu đã đặt sẵn trong style (ở đây là &H00F4A6FC&) kết quả sẽ được
\c&H00F4A6FC&. Ở trong style có 4 ô màu tương tự ở đây sẽ có !line.styleref.color1! đến !line.styleref.color4!.
- Đến phần syl, vẫn với cách tra màu như trên nhưng ta sẽ lấy màu ở ô số 2 trong style nhờ !line.stylere f.color2!, như
thế sub sẽ đổi màu (kết quả là \c&H00F4A6FC&). Ở đầy màu viền \3c, ta không muốn tra ở trong style nữa mà đặt
hẳn là màu trắng \3c&HFFFFFF&
Ở đây có sử dụng thêm cả tag \fscx, mục đích là để chữ sẽ kéo dài ra theo chiều ngang là 120%, trông chữ sẽ to hơn.
Ta có thể sử dụng thêm một số tag khác như \fs hay \fscy để thu hay phóng kích thước của chữ. Tùy theo \an mà chữ
sẽ được co kéo theo chiều nào, \an8 chữ sẽ kéo xuống dưới, \an6 là sang trái, \an2 là lên trên, \an4 là sang phải, có
thêm cả với 7, 9, 3, 1)
- Ở phần về cuối line syl2end, chữ sẽ được trả về mức viền như ban đầu bằng \bord1 và độ co kéo là \fscx100 như
mặc định có trong style. Thêm đó vẫn giữ nguyên màu viền ở đoạn syl là 3c&HFFFFFF& và đổi lại màu
thànhc!line.styleref.color1!.
Lý do tại sao ở đây lại set cho line syl có layer lớn hơn hai line còn lại vì muốn để cho line này nằm trên, khi tăng độ
lớn chữ sẽ không bị chữ nằm cạnh che mất.
Đổi style của chữ một cách từ từ bằng \t()
Các hiệu ứng bên trên đều xuất hiện đột ngột chứ không có chuyển đổi dần dần, giờ tôi sẽ hướng dẫn các bạn sử dụng
\t() để hiệu ứng được uyển chuyển.
Trước tiên nói về tác dụng và khả năng của \t():
Tag \t() dùng để biến đổi dần dần từ giá trị này đến giá trị kia của một số tag khác. Chẳng hạn như tăng dần fontsize từ
18 thành 26 làm cho chữ to lên hay tăng/giảm góc lệch làm cho chữ xoay tròn. Vì \t() là tag biến đổi dần dần nên nó
chỉ có tác dụng với những tag có nhiều mức độ giá trị khác nhau, như để chuyển font size từ 18 thành 26 nó sẽ đổi font
dần dần trung gian giữa hai mức đó.
Chính vì thế nó không có tác dụng với các tag chỉ có hai giá trị cố định là \b, \i, \u, \s, \fn, \an hay các vector đồ họa.
Với tag tọa độ \pos() hiện nay chỉ có thể dùng \move() để làm chữ di chuyển.
Code:
Giải thích
- Ở đây các bạn sẽ thấy ở phần !retime("syl", 0, 0)! chữ không đổi sang màu !line.styleref.color2! và to lên ngay lập
tức mà từ từ, ở đây khác với bên trên là cho chữ giãn ra 125% theo chiều dọc nhờ \fscy
Nhờ \t() mà trong khoảng thời gian từ 0 tới 50% của tiếng hát (0.5*$dur), $dur chính là thời gian nằm trong \k, hiệu
ững chữ đã thay đổi dần dần.
- Trong phần syl2end, phần phía trước \t() vẫn giữ nguyên so với của syl, sau đó mới đổi sang màu chữ và viền là
\c&HFFFFFF&\3c!line.styleref.color2!, thêm nữa giảm độ giãn chiều dọc \fscy từ 125% xuống 100% và độ dày của
viền về \bord1 trong thời lượng 500 (mili giây - nửa giây)
Hiệu ứng chữ xoay
Code:
Giải thích
- Với dòng start2syl không hề có gì thay đổi cả, vẫn viền mức 1 và màu chữ ô số 1.
- Với dòng syl tôi đã thay đổi một chút về tọa độ, chuyển phần neo chữ sang \an8 do đó cũng chuyển vị trí của syl text
sang \pos($scenter, $stop) - chính giữa phía trên để cho chữ không lệch với dòng start2syl. Màu sắc sẽ không dùng
tag \t để đổi nữa mà cho đổi màu ngay lập tức, thay vào đó tôi sẽ cho chữ xoay 270 độ nhờ tag góc \frx (như lộn xà
đơn) với tâm chính là vị trí \pos() (nhờ có neo là \an8). Ở đầy thời gian sẽ là cả toàn bộ thời lượng $dur của syl. Dĩ
nhiên 270 độ thì mới được có 3/4 vòng.
- Với phần cuối syl2end giữ nguyên màu viền, màu chữ \c theo mặc định sẽ !line.styleref.color1! luôn nên không cần
gõ và đây. Vì ở phần syl chữ mới quay được 270 độ, chưa đủ một vòng nên tôi muốn nó quay tiếp trông liền mạch cần
đặt \frx270 trước \t() đã. Tiếp đó ta sẽ nhập giá trị cuối cùng muốn chữ xoay tớitrong thời gian 500 ấy - \frx360 nghĩa
là đủ một vòng.
Có thể thêm dấu trừ thành \frx-270 và \frx-360 để đổi chiều xoay. Các bạn có thể dùng với \frz để đuổi phương xoay
của chữ thành lăn vòng, hay cả \fry
Tính toán thời gian và tọa độ
Giờ chúng ta sẽ nghiên cứu thêm về phần khai báo thời gian retime cho mỗi line template và cách tính tọa độ cơ bản
sau này dùng vào các hiệu ứng di chuyển
Trước tiên nói về syl, line
Có thể coi syl chính là tag \k, hay chi tiết hơn là khoảng nội dung giữa tag \k này đến tag \k tiếp theo. Thời gian của
syl là thời gian đã có ở tag \k, như \k45 thời gian của syl là 450ms (450 phần nghìn giây). Sự khác biệt ở phần nghìn là
nhỏ nên trong tag chỉ có hai số (phần trăm giây).
Thứ tự của syl - syl index chính là số thứ tự của tag \k ấy trong cả line đếm từ trái qua phải (dĩ nhiên), ta tính số tag \k
chứ không tính số chữ. Và tổng số tag \k gọi là syl number.
Viết tắt của số thứ tự syl có hai cách là: syl.i hoặc $si Tương tự với tổng số syl của một line là syl.n hoặc $syln. Chữ
syl được viết gọn lại thành $s. Khi được viết đầy đủ nó là tên gọi còn khi có dạng $ nó trở thành tham số, cả hai đều có
thể dùng để tra các thông tin về karaoke gốc.
Tương tự với syl là line với cách viết line. và $l
Một số giá trị của karaoke được dùng thường xuyên
Bài viết gốc về variables ở đây
Aegisub/docs/Karaoke_Templater_Reference__Inline_variables.html
- Thời lượng của syl: $dur hoặc $sdur - syl.duration (mặc định nếu không để template line thì hai cái đó là một) và
$skdur
- Thời gian bắt đầu và kết thúc của syl so với cả line: $sstart, $send - syl.start_time, syl.end_time
- Thời gian giữa của syl: $smid (tương đương với vị trí 50% của $sdur)
- Số thứ tự của syl và tổng số syl trong line: $si, $syln - syl.i, syl.n
Code:
Ở đây có tất cả là 10 tag \k tương đương 10 syl, nhưng chỉ có 9 từ để hát vì có hai syl liền nhau
Giờ ta sẽ nói về các tham số tọa độ của syl và line:
- Vị trí chính giữa tính theo trục ngang (trục x): $scenter
- Rìa bên trái của syl: $sleft - syl.left
- Rìa bên phải của syl: $sright - syl.right
- Vị trí giữa tính theo trục dọc (trục y): $smiddle
- Rìa phía trên của syl: $stop - syl.top
- Rìa phía dưới của syl: $sbottom - syl.bottom
- $sx và $sy là giá trị mặc định tính theo style, ít dùng
- Chiều rộng của syl, tính từ bên trái đến bên phải: $swidth - syl.width
- Chiều dài của syl, từ trên xuống dưới: $sheight - syl.height
Vì muốn chữ được nằm đúng vị trí của dòng karaoke gốc nên ta cần sử dụng \an và \pos();\move() cho tương thích.
Chủ yếu vẫn là \an5\pos($scenter,$smiddle)
Với line ta chỉ cần thay $s bằng $l hay syl. bằng line.
Tính tọa độ và thời gian là phần quan trọng trong việc tạo hiệu ứng về di chuyển, vẽ, cắt. Nó cũng giúp bù bớt đi một
số hạn chế của auto4 và lua, nhất là việc không thể chia chữ thành các điểm nhỏ như python, ta có thể dùng \clip để
thay thế.
Chỉnh lại thời gian karaoke bằng retime
Đây là code cho một hiệu ứng hiện chữ rất phổ biến, có thể thấy ở OP Mahoraba [Vi-Anime]
Code:
Đầu tiên nói về phần ($si-1)*30: đây chính là khoảng thời gian đầu của syl so với đầu của line karaoke gốc. Nó cộng
thêm 30 (mili giây) cho mỗi syl tiếp theo để tăng dần thời gian, do đó làm syl sau xuất hiện muộn hơn syl ở trước
1*30 = 30 => !retime("start2syl", 30, 0)!
2*30 = 60 => !retime("start2syl", 60, 0)!
3*30 = 90 => !retime("start2syl", 90, 0)!
Vậy tại sao lại trừ 1, vì dĩ nhiên thời gian của syl đầu tiên $si = 1 phải là 0 nên ta trừ 1 để khi nhân 30, start_time của
nó là 0.
Còn với phần -350, đây thực ra là khoảng thời gian bù cho việc chữ của syl xuất hiện quá muộn so với lúc bắt đầu của
line gốc. Các khoảng lệch retime bên trên đều mang giá trị dương, ta sẽ trừ đi 350 để nó sớm hơn.
!retime("start2syl", -350+90, 0)! = !retime("start2syl", -240, 0)!
sớm 240 (mili giây) so với thời gian gốc.
Code:
!retime("syl2end", 0, 350-($syln-$si)*30)!
Đây lại là phần tính thời gian kết thúc giảm dần được dùng cho cuối line làm chữ biến mất. Ta lấy tổng số syl trừ đi số
thứ của syl, kết quả sẽ giảm dần cho đến 0.
Một cách biến hóa khác là đổi dấu cộng thành dầu trừ cho thời gian bù thêm, ta sẽ đổi được chiều của hiệu ứng, thay
vì từ trái qua phải lại thành từ phải qua trái. -350+($si-1)*30 thành -350-($si-1)*30 Với cách chỉnh lại thời gian thế
này ta có thể làm được rất nhiều hiệu ứng hiện chữ khi kết hợp với di chuyển và xoay
Trong phần !retime! có thể thay bằng các giá trị khác sẽ được nói sau
Căn chỉnh thời gian cho hiệu ứng
Giờ ta sẽ nói về việc sử dụng tag \t cũng một số khác với thời gian của syl. Cái này các bạn có thể tùy ý ra nhiều
Code:
C:\Program Files\Aegisub\csri\
Sau đó, mở Aegisub lên. Vào menu View\Option (Alt + O), chọn nhãn Video ở bên trái. Đổi Subtitle
provider từ csri/vsfilter_textsub thành csri/vsfiltermod_textsub.
Với avisynth
Code:
Trong nội dung file avs, đơn giản chỉ cần gõ từ TextSub() sang TextsubMod() để hardsub.
Với DirectShow (xem video softsub) (Không nên dùng)
Bật hộp Run (Ctrl + R) lên và gõ nội dung này vào và enter để đăng ký cho window biết
Code:
Với VirtualDub (load sub qua avs thì cái này không cần thiết)
Copy VSFilterMod.dll vào thư mục plugins của VirtualDub và đổi tên file VSFilterMod.dll thành VSFilterMod.vdf.
Chọn filter này giống như chọn bản VSFilter (textsub) trước)
Danh sách tag mới
Co kéo cỡ chữ (Font scale)
\fsc<phần trăm> - Đây là gộp gọn lại của hai tag cũ \fscx<scale>\fscy<scale>. Sử dụng tương tự, cái này không có gì
đặc biệt. Dùng được với \t()
\fsc200 = \fscx200\fscy200.
Dẫn hướng (Leading)
\fsvp<số> Đổi hướng và độ cao của chữ (chưa rõ), giá trị là các số. Dùng được với \t() \t(\fsvp10)
Nghiêng chữ theo hàng (Baseline obliquity).\frs<góc> Xoay các chữ cái theo một một đường thẳng, giống như các
tag \frx\frz\fry nó cũng phụ thuộc vào \an. Dùng được với \t(). {\an6\t(\frs-15\frz25)\pos(306,239)} - đu quay
Tọa độ z (Z coordinate)
\z<số> Đặt thêm tọa độ của trục z cho chữ, thay vì chỉ có ngang dọc (x, y) như hiện giờ. Đặt giá trị dương để chữ lùi
ra xa, đặt âm để làm chữ lại gần (gần giống scale) Dùng được với \t()
\org(x1, x2, x2, y2 [,t1, t2]) Dịch chuyển tọa độ của tâm
{\an5\org(100, 200, 700, 200)\fs50\shad0\frz0\t(\frz360)\pos(400,200)}foo bar
Không xoay
Code:
Xoay và mờ dần
Giải thích: Cái chính ở đây là template char, khi dùng template char hiệu ứng sẽ được áp dụng cho từng chữ cái của
karaoke, nếu không có nó, ta sẽ thấy chữ vẫn dính vào nhau.
Để có thể di chuyển chữ ra xung quanh như thế ta dùng math.random để nhặt số ngẫu nhiên rồi cộng nó với tọa độ
cũ, math.random(-5, 30) là nhặt ra các số từ khoảng -5 đến 30, $dur, !line.duration! khoảng thời gian này là từ khi hết
âm rồi chữ mới tách ra, tương đương với độ dài 1000 ở phần retime.
Nếu muốn chữ trong khi di chuyển có thể xoay nữa ta dùng thêm các tag góc như \frz, \frx hay \fry đặt trong
\t(). \frz!math.random(-45, 90)![/B] Ở đây chữ sẽ xoay nghiêng theo một góc nào đó từ -45 đến 90 nhờ math.random,
nhờ thế tạo được vẻ tự nhiên.
Đổi ngược thời gian và vị trí lại ta có chữ lắp ráp
Code:
Giải thích:
!retime("sylpct", 0, 50)! là từ 0% đến 50% của thời lượng syl, tương đương với !retime("syl", 0, -0.5*$dur)! hay
!retime("presyl", 0, 0.5*$dur)!. Khi đó chữ sẽ chạy lên 15 pixel.
Sau đó phần !retime("sylpct", 50, 100)! là từ 50% còn lại đến 100% của thời lượng syl, tương đương với !retime("syl",
0.5*$dur, 0)! hay !retime("presyl", 0.5*$dur, $dur)! chữ sẽ từ mức 15 pixel kia chạy xuống vị trí gốc.
Làm cách này nếu để chữ nhảy qua trái hay phải (trừ hay cộng thêm vào $scenter) sẽ trông như đường rích rắc, không
được mượt nên ta sẽ dùng một cách khác là cho chữ trượt trên đường tròn thật to.
Code:
template noblank: !retime("syl", 0, 0)!{\an5\move($scenter, $smiddle, !$scenter-15!,
$smiddle, 0, !$dur*0.80!)\org(-10000, $smiddle)\t(0, !$dur*0.50!, \frz-
0.05)\t(!$dur*0.60!, $dur, \frz0)}
Chữ sẽ xoay theo đường tròn có tâm ở tận tọa độ (-10000, $smiddle) với một góc rất nhỏ chỉ 0.05 độ nên tạo cảm giác
như chạy thẳng, đừng đặt quá to nếu không chữ sẽ biến mất khỏi màn hình đấy. Trong khi nhảy nên nó còn chạy sang
trái một đoạn 15 pixel như thể nhảy xa. Nhược điểm của kiểu này là vì có đặt tâm ở xa nên ta không thể dùng các tag
xoay khác như \frx và \fry với giá trị lớn, nó sẽ khiến chữ bị xoay theo chiều x và y rất loạn. Nếu muốn chữ lắc lư có
thể đổi vị trí của tâm thay vì nằm ngang tầm mà lại nằm bên trên hoặc bên dưới \org($scenter, -10000) nó sẽ xoay qua
trái phải. Xem trong OP Minami-ke [Vi-Anime] để thấy hiệu ứng là sử dụng rất đẹp