tsharpensettings.cpp.svn-base
来自「ffshow源码」· SVN-BASE 代码 · 共 163 行
SVN-BASE
163 行
/* * Copyright (c) 2003-2006 Milan Cutka * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */#include "stdafx.h"#include "TsharpenSettings.h"#include "TimgFilterSharpen.h"#include "Csharpen.h"#include "TffdshowPageDec.h"const TfilterIDFF TsharpenSettings::idffs={ /*name*/ _l("Sharpen"), /*id*/ IDFF_filterSharpen, /*is*/ IDFF_isSharpen, /*order*/ IDFF_orderSharpen, /*show*/ IDFF_showSharpen, /*full*/ IDFF_fullSharpen, /*half*/ IDFF_halfSharpen, /*dlgId*/ IDD_SHARPEN,};TsharpenSettings::TsharpenSettings(TintStrColl *Icoll,TfilterIDFFs *filters):TfilterSettingsVideo(sizeof(*this),Icoll,filters,&idffs){ static const TintOptionT<TsharpenSettings> iopts[]= { IDFF_isSharpen ,&TsharpenSettings::is ,0,0,_l(""),1, _l("xsharpen"),0, IDFF_showSharpen ,&TsharpenSettings::show ,0,0,_l(""),1, _l("showSharpen"),1, IDFF_orderSharpen ,&TsharpenSettings::order ,1,1,_l(""),1, _l("orderSharpen"),0, IDFF_fullSharpen ,&TsharpenSettings::full ,0,0,_l(""),1, _l("fullSharpen"),0, IDFF_halfSharpen ,&TsharpenSettings::half ,0,0,_l(""),1, _l("halfSharpen"),0, IDFF_sharpenMethod ,&TsharpenSettings::method ,0,5,_l(""),1, _l("sharpenMethod"),0, IDFF_xsharp_strength ,&TsharpenSettings::xsharpStrength ,1,127,_l(""),1, _l("xsharp_strenght"),xsharpStrengthDef, IDFF_xsharp_threshold ,&TsharpenSettings::xsharpThreshold ,0,255,_l(""),1, _l("xsharp_threshold"),xsharpThresholdDef, IDFF_unsharp_strength ,&TsharpenSettings::unsharpStrength ,1,127,_l(""),1, _l("unsharp_strength"),unsharpStrengthDef, IDFF_unsharp_threshold ,&TsharpenSettings::unsharpThreshold,0,255,_l(""),1, _l("unsharp_threshold"),unsharpThresholdDef, IDFF_msharp_strength ,&TsharpenSettings::msharpStrength ,0,255,_l(""),1, _l("msharpStrength"),msharpStrengthDef, IDFF_msharp_threshold ,&TsharpenSettings::msharpThreshold ,0,255,_l(""),1, _l("msharpThreshold"),msharpThresholdDef, IDFF_msharpHQ ,&TsharpenSettings::msharpHQ ,0,0,_l(""),1, _l("msharpHQ"),0, IDFF_msharpMask ,&TsharpenSettings::msharpMask ,0,0,_l(""),1, _l("msharpMask"),0, IDFF_asharpT ,&TsharpenSettings::asharpT ,-100,3200,_l(""),1, _l("asharpT"),200, IDFF_asharpD ,&TsharpenSettings::asharpD ,0,1600,_l(""),1, _l("asharpD"),400, IDFF_asharpB ,&TsharpenSettings::asharpB ,0,400,_l(""),1, _l("asharpB"),0, IDFF_asharpHQBF ,&TsharpenSettings::asharpHQBF ,0,0,_l(""),1, _l("asharpHQBF"),0, IDFF_mplayerSharpLuma ,&TsharpenSettings::mplayerLuma ,0,400,_l(""),1, _l("mplayerSharpLuma"),50, IDFF_mplayerSharpChroma ,&TsharpenSettings::mplayerChroma ,0,400,_l(""),1, _l("mplayerSharpChroma"),50, 0 }; addOptions(iopts);}void TsharpenSettings::createFilters(size_t filtersorder,Tfilters *filters,TfilterQueue &queue) const{ idffOnChange(idffs,filters,queue.temporary); if (is && show) { if (!queue.temporary) setOnChange(IDFF_sharpenMethod,filters,&Tfilters::onQueueChange); switch (method) { case SHARPEN_XSHARP:queueFilter<TimgFilterXsharp>(filtersorder,filters,queue); return; case SHARPEN_UNSHARP:queueFilter<TimgFilterUnsharp>(filtersorder,filters,queue); return; case SHARPEN_MSHARP:queueFilter<TimgFilterMsharp>(filtersorder,filters,queue); return; case SHARPEN_ASHARP:queueFilter<TimgFilterAsharp>(filtersorder,filters,queue); return; case SHARPEN_MPLAYER:queueFilter<TimgFilterMplayerSharp>(filtersorder,filters,queue); return; } } }void TsharpenSettings::createPages(TffdshowPageDec *parent) const{ parent->addFilterPage<TsharpenPage>(&idffs);}const int* TsharpenSettings::getResets(unsigned int pageId){ static const int idResets[]={ IDFF_sharpenMethod, IDFF_xsharp_strength,IDFF_xsharp_threshold, IDFF_unsharp_strength,IDFF_unsharp_threshold, IDFF_msharp_strength,IDFF_msharp_threshold,IDFF_msharpHQ,IDFF_msharpMask, IDFF_asharpT,IDFF_asharpD,IDFF_asharpB,IDFF_asharpHQBF, IDFF_mplayerSharpLuma,IDFF_mplayerSharpChroma, 0}; return idResets;}bool TsharpenSettings::getTip(unsigned int pageId,char_t *buf,size_t len){ char_t tipS[256]; const char_t *name=_l(""); const char_t *capts[3]={NULL,NULL,NULL}; int vals[3]; int strength=0,threshold=0; switch (method) { case 0:name=_l("xsharpen");capts[0]=_l("strength");capts[1]=_l("threshold"); vals[0]=xsharpStrength; vals[1]=xsharpThreshold; break; case 1:name=_l("unsharp mask");capts[0]=_l("strength"); vals[0]=unsharpStrength; break; case 2:name=_l("msharpen");capts[0]=_l("strength");capts[1]=_l("threshold"); vals[0]=msharpStrength; vals[1]=msharpThreshold; break; case 4:name=_l("asharp");capts[0]=_l("Unsharp masking threshold");capts[1]=_l("Adaptive sharpenning strength");capts[2]=_l("Block adaptive sharpenning"); vals[0]=asharpT; vals[1]=asharpD; vals[2]=asharpB; break; case 5:name=_l("swscaler");capts[0]=_l("Luma sharpening");capts[1]=_l("Chroma sharpening"); vals[0]=mplayerLuma; vals[1]=mplayerChroma; break; } tsprintf(tipS,_l("method:%s\n"),name); if (capts[0]) strcatf(tipS,_l("%s: %i"),capts[0],vals[0]); if (capts[1]) strcatf(tipS,_l(", %s: %i"),capts[1],vals[1]); if (capts[2]) strcatf(tipS,_l(", %s: %i"),capts[2],vals[2]); strncpy(buf,tipS,len);buf[len-1]='\0'; return true;}void TsharpenSettings::reg_op(TregOp &t){ TfilterSettingsVideo::reg_op(t); if (method==3) method=4;}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?