本文整理汇总了C++中TwoDArray::LengthX方法的典型用法代码示例。如果您正苦于以下问题:C++ TwoDArray::LengthX方法的具体用法?C++ TwoDArray::LengthX怎么用?C++ TwoDArray::LengthX使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TwoDArray
的用法示例。
在下文中一共展示了TwoDArray::LengthX方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: VFilter
void VFilter( const TwoDArray<unsigned char>& pic_data, TwoDArray<unsigned char>& out_data, const OneDArray<int>& filter, const int bits )
{
const int offset = (1<<(bits-1));
int sum, j, jout;
// Do the first bit
for (j=0, jout=0; j<filter.Last(); j+=2, jout++)
{
for (int i=0; i<pic_data.LengthX(); ++i)
{
sum = offset;
for (int k=filter.Last(); k>=filter.First(); --k)
sum += filter[k]*static_cast<int>( pic_data[std::max(j-k,0)][i] );
sum >>= bits;
sum = std::min( 255, std::max( 0, sum) );
out_data[jout][i] = static_cast<unsigned char>( sum );
}// i
}// j
// Do the middle bit
for (; j<=pic_data.LastY()+filter.First(); j+=2, jout++)
{
for (int i=0; i<pic_data.LengthX(); ++i)
{
sum = offset;
for (int k=filter.Last(); k>=filter.First(); --k)
sum += filter[k]*static_cast<int>( pic_data[j-k][i] );
sum >>= bits;
sum = std::min( 255, std::max( 0, sum) );
out_data[jout][i] = static_cast<unsigned char>( sum );
}// i
}// j
// Do the last bit
for (; j<pic_data.LengthY(); j+=2, jout++)
{
for (int i=0; i<pic_data.LengthX(); ++i)
{
sum = offset;
for (int k=filter.Last(); k>=filter.First(); --k)
sum += filter[k]*static_cast<int>( pic_data[std::min(j-k,pic_data.LastY())][i] );
sum >>= bits;
sum = std::min( 255, std::max( 0, sum) );
out_data[jout][i] = static_cast<unsigned char>( sum );
}// i
}// j
}
示例2: HFilter
void HFilter( const TwoDArray<unsigned char>& pic_data, TwoDArray<unsigned char>& out_data, const OneDArray<int>& filter, const int bits )
{
unsigned char* line_data;
const int offset = (1<<(bits-1));
int sum;
int i, iout;
for (int j=0; j<pic_data.LengthY(); ++j)
{
line_data = out_data[j];
// Do the first bit
for (i=0, iout=0; i<filter.Last(); i+=2, iout++)
{
sum = offset;
for (int k=filter.Last(); k>=filter.First(); --k)
sum += filter[k]*static_cast<int>(pic_data[j][std::max(i-k,0)]);
sum >>= bits;
sum = std::min( 255, std::max( 0, sum) );
line_data[iout] = static_cast<unsigned char>( sum );
}// i
// Do the middle bit
for (; i<=pic_data.LastX()+filter.First(); i+=2, iout++)
{
sum = offset;
for (int k=filter.Last(); k>=filter.First(); --k)
sum += filter[k]*static_cast<int>( pic_data[j][i-k] );
sum >>= bits;
sum = std::min( 255, std::max( 0, sum) );
line_data[iout] = static_cast<unsigned char>( sum );
}// i
// Do the last bit
for (; i<pic_data.LengthX(); i+=2, iout++)
{
sum = offset;
for (int k=filter.Last(); k>=filter.First(); --k)
sum += filter[k]*static_cast<int>( pic_data[j][std::min(i-k,pic_data.LastX())] );
sum >>= bits;
sum = std::min( 255, std::max( 0, sum) );
line_data[iout] = static_cast<unsigned char>( sum );
}// i
}// j
}