本文整理汇总了C++中Packer::getW方法的典型用法代码示例。如果您正苦于以下问题:C++ Packer::getW方法的具体用法?C++ Packer::getW怎么用?C++ Packer::getW使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Packer
的用法示例。
在下文中一共展示了Packer::getW方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: combineImages
/**
* packerに基づきイメージを結合する
*/
static void combineImages(){
// 出力フォーマットの選別
const int ch = getChannels(ofmt_type);
const int type = (ch == 4)? CV_8UC4 : CV_8UC3;
const cv::Scalar scalar = (ch == 4)? cv::Scalar(127, 127, 127, 255) : cv::Scalar(127, 127, 127); // 初期色
cv::Mat dst(cv::Size(packer.getW(), packer.getH()), type, scalar);
int count = 0; // for debug
DataArray::iterator it = inputs.begin();
for(; it != inputs.end(); it++){
if(!it->fit)
continue; // skip
cv::Mat src = cv::imread(it->path, -1);
if(src.channels() != ch){
adjustmentImage(src, ch);
}
cv::Mat roi = dst(cv::Rect(it->fit->rect.getX() + packer.getPadding(), it->fit->rect.getY() + packer.getPadding(), it->w, it->h));
src.copyTo(roi);
// for debug
#if 0
cv::rectangle(dst, cv::Rect(it->fit->rect.getX(), it->fit->rect.getY(), it->fit->rect.getW(), it->fit->rect.getH()), cv::Scalar(255, 255, 255), 1);
std::ostringstream oss;
oss << it->w << "x" << it->h << "(" << count << ")";
count++;
const std::string size = oss.str();
cv::putText(dst, size, cv::Point(it->fit->rect.getX() + 1, it->fit->rect.getY() + 21), cv::FONT_HERSHEY_SIMPLEX, 0.5, cv::Scalar(0, 0, 0), 1);
cv::putText(dst, size, cv::Point(it->fit->rect.getX(), it->fit->rect.getY() + 20), cv::FONT_HERSHEY_SIMPLEX, 0.5, cv::Scalar(255, 255, 255), 1);
#endif
}
// 出力
if((om_type == OutputMode_WriteOnly) || (om_type == OutputMode_Both)){
bool ret = cv::imwrite(output_path, dst, params);
}
if((om_type == OutputMode_DisplayOnly) || (om_type == OutputMode_Both)){
std::ostringstream oss;
oss << "packed image(" << packer.getW() << " x " << packer.getH() << ")";
const std::string name = oss.str();
cv::namedWindow(name, CV_WINDOW_AUTOSIZE | CV_WINDOW_KEEPRATIO);
cv::imshow(name, dst);
if(ch == 4){
std::vector<cv::Mat> mv;
cv::split(dst, mv);
cv::Mat dsta = mv[3].clone();
cv::imshow("packed image(alpha)", dsta);
}
}
}