『漫游』酷论坛>『影音数码技术学习交流』>[分享]利用ConditionalFilt ..
Yuricon@2010-11-13 23:43
我不是大大啊OTZ
只会用avs做各种EP的事情罢了...
06_taro@2010-11-13 23:56
EP的萬國博覽秀……
linuxyouxia@2010-11-14 09:43
不EP不行啊 有些观众可是会EP到下多个Raw到逐帧对比的啊
以上说笑 勿当真
Yuricon@2010-11-14 10:21
引用
最初由 linuxyouxia 发布
不EP不行啊 有些观众可是会EP到下多个Raw到逐帧对比的啊
以上说笑 勿当真
他们需要MYEPTools里的MoMoE
linuxyouxia@2010-11-14 10:27
引用
最初由 Yuricon 发布
他们需要MYEPTools里的MoMoE
其实avs本身也提供了一个对比函数
Compare(clip_filtered clip, clip_original clip, string channels, string logfile, bool show_graph)
还有个
Subtract(clip1 clip, clip2 clip)
Subtract produces an output clip in which every pixel is set according to the difference between the corresponding pixels in clip1 and clip2. More specifically, it sets each pixel to (50% grey) + (clip1 pixel) - (clip2 pixel). You can use Levels afterwards if you want to increase the contrast.
嘛 EP无止境 话说破沟有EP交流群吗:D
Yuricon@2010-11-14 10:39
这和MME性质不一样吧...
linuxyouxia@2010-11-14 10:47
引用
最初由 Yuricon 发布
这和MME性质不一样吧...
是不一样 但是也是一种对比的选择
实现同一目的或类似目的 可以有不同的选择
所以如果俺的方法行不通的时候 俺也会用大大的脚本 因为俺懒嘛 有现成的就用现成的
比如某一段需要对画中画处理 那么直接在俺自己的方法上加一行 调用大大编写的脚本
大大完全可以另开一帖在POPGO推广EP脚本 让POPGO一些不去NMM的群众不需要进俺的主题 就能了解大大写的脚本的优点 小弟一定捧场
小弟没有任何贬低大大写的脚本的意思 如果先前说的话有所冒犯 还请多多包涵:)
Yuricon@2010-11-14 11:08
MME重点在于双屏显示来更直观的进行视觉对比,这点上已经和Subtract之类的不同了
其实也就是利用overlay罢了,都这么久了,我自己也没怎么用过(拖
EP乃罪过啊....
linuxyouxia@2010-11-14 11:12
其实之前对比都是用Interleave(clip1.Subtitle("clip1"),clip2.Subtitle("clip2"))
这样VD预览时 按方向键在前后帧来回切换就能方便得看出不同了
Yuricon@2010-11-14 11:34
这方法也不错,其实你还可以加个ShowFrameNumber
upyzl@2010-11-14 11:40
其实以前一直想问了
EP的全称是啥?
Extreme P????
yuugi@2010-11-14 11:55
引用
最初由 upyzl 发布
其实以前一直想问了
EP的全称是啥?
Extreme P????
蛋+疼
http://popgo.net/wiki/%E6%89%80%E8%B0%93EP
linuxyouxia@2010-11-14 14:00
引用
最初由 Yuricon 发布
这方法也不错,其实你还可以加个ShowFrameNumber
这个主意真好:) 谢大大指点
-o-o-304-o-o-@2010-11-15 07:34
EP就是中文直译过来的egg pain饿(捂脸
于是路过学习了。
linuxyouxia@2011-04-27 20:41
无聊改了下tivtc中的tfm,当display=true时通过消息列队把场景切换帧帧号和交错帧帧号 发送给MyVDIVTC
MyVDIVTC CheckListBox中双击帧号,通过发送消息方式操作VD界面跳转到该帧
tfm函数初始化时,通过FindWindowEx搜索标题为 MyVDIVTC 的窗口 获取MyVDIVTC的窗口句柄
代码尚未整理,凑合着用似乎没问题
http://dl.dbank.com/c08u5ftvot
- diff -C 3 B/TFM.cpp A/TFM.cpp
- *** B/TFM.cpp 2008-01-17 13:01:06.000000000 +0800
- --- A/TFM.cpp 2011-04-27 14:12:56.000000000 +0800
- ***************
- *** 537,542 ****
- --- 537,543 ----
- int blockN, int xblocks, bool d2vmatch, int *mics, PVideoFrame &prv,
- PVideoFrame &src, PVideoFrame &nxt, IScriptEnvironment *env)
- {
- + bool isSC;
- if (combed > 1 && PP > 1) return;
- if (combed > 1 && PP == 1 && blockN != -20)
- {
- ***************
- *** 552,563 ****
- sprintf(buf, "order = %d field = %d mode = %d ", order, field, mode);
- if (np == 3) DrawYV12(dst, 0, 1, buf);
- else DrawYUY2(dst, 0, 1, buf);
- if (!over && !d2vmatch) sprintf(buf, "frame: %d match = %c %s", n, MTC(fmatch),
- ! ((ubsco || mmsco || flags == 5) && checkSceneChange(prv, src, nxt, env, n)) ? " (SC) " : "");
- else if (d2vmatch) sprintf(buf, "frame: %d match = %c (D2V) %s", n, MTC(fmatch),
- ! ((ubsco || mmsco || flags == 5) && checkSceneChange(prv, src, nxt, env, n)) ? " (SC) " : "");
- else sprintf(buf, "frame: %d match = %c (OVR) %s", n, MTC(fmatch),
- ! ((ubsco || mmsco || flags == 5) && checkSceneChange(prv, src, nxt, env, n)) ? " (SC) " : "");
- if (np == 3) DrawYV12(dst, 0, 2, buf);
- else DrawYUY2(dst, 0, 2, buf);
- int i = 3;
- --- 553,565 ----
- sprintf(buf, "order = %d field = %d mode = %d ", order, field, mode);
- if (np == 3) DrawYV12(dst, 0, 1, buf);
- else DrawYUY2(dst, 0, 1, buf);
- + isSC = checkSceneChange(prv, src, nxt, env, n);
- if (!over && !d2vmatch) sprintf(buf, "frame: %d match = %c %s", n, MTC(fmatch),
- ! ((ubsco || mmsco || flags == 5) && isSC) ? " (SC) " : "");
- else if (d2vmatch) sprintf(buf, "frame: %d match = %c (D2V) %s", n, MTC(fmatch),
- ! ((ubsco || mmsco || flags == 5) && isSC) ? " (SC) " : "");
- else sprintf(buf, "frame: %d match = %c (OVR) %s", n, MTC(fmatch),
- ! ((ubsco || mmsco || flags == 5) && isSC) ? " (SC) " : "");
- if (np == 3) DrawYV12(dst, 0, 2, buf);
- else DrawYUY2(dst, 0, 2, buf);
- int i = 3;
- ***************
- *** 606,611 ****
- --- 608,633 ----
- if (np == 3) DrawYV12(dst, 0, i, buf);
- else DrawYUY2(dst, 0, i, buf);
- }
- +
- + if ((MyVDIVTC == NULL) || ((!isSC) && (combed == 0)))
- + {
- + return;
- + } else
- + if ((combed != 0) && isSC)
- + {
- + SendMessage(MyVDIVTC, WM_USER+100, n, 0);
- + } else
- + if ((combed != 0) && (!isSC))
- + {
- + SendMessage(MyVDIVTC, WM_USER+100, n, 1);
- + } else
- + if ((combed == 0) && isSC)
- + {
- + SendMessage(MyVDIVTC, WM_USER+100, n, 2);
- +
- + }
- +
- +
- }
-
- void TFM::getSettingOvr(int n)
- ***************
- *** 2316,2321 ****
- --- 2338,2347 ----
- sprintf(buf, "TFM: %s by tritical\n", VERSION);
- OutputDebugString(buf);
- }
- + if (display)
- + {
- + MyVDIVTC = FindWindowEx(NULL,NULL,NULL,"MyVDIVTC");
- + }
- child->SetCacheHints(CACHE_RANGE, 3); // fixed to diameter (07/30/2005)
- lastMatch.frame = lastMatch.field = lastMatch.combed = lastMatch.match = -20;
- nfrms = vi.num_frames-1;
- diff -C 3 B/TFM.h A/TFM.h
- *** B/TFM.h 2008-01-17 13:01:28.000000000 +0800
- --- A/TFM.h 2011-04-26 12:38:22.000000000 +0800
- ***************
- *** 92,97 ****
- --- 92,98 ----
- int tpitchy, tpitchuv, *moutArray, *moutArrayE;
- MTRACK lastMatch;
- SCTRACK sclast;
- + HWND MyVDIVTC;
- double scthresh;
- char buf[4096], outputFull[270], outputCFull[270];
- PlanarFrame *map, *cmask;
«123»共3页
| TOP