本文整理汇总了C++中DataArray::end方法的典型用法代码示例。如果您正苦于以下问题:C++ DataArray::end方法的具体用法?C++ DataArray::end怎么用?C++ DataArray::end使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类DataArray
的用法示例。
在下文中一共展示了DataArray::end方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的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);
}
}
}
示例2: SortCommand
int Ardb::SortCommand(Context& ctx, const Slice& key, SortOptions& options, DataArray& values)
{
values.clear();
KeyType keytype = KEY_END;
GetType(ctx, key, keytype);
switch (keytype)
{
case LIST_META:
{
ListRange(ctx, key, 0, -1);
break;
}
case SET_META:
{
SetMembers(ctx, key);
break;
}
case ZSET_META:
{
ZSetRange(ctx, key, 0, -1, false, false, OP_GET);
if (NULL == options.by)
{
options.nosort = true;
}
break;
}
default:
{
return ERR_INVALID_TYPE;
}
}
DataArray sortvals;
if (ctx.reply.MemberSize() > 0)
{
for (uint32 i = 0; i < ctx.reply.MemberSize(); i++)
{
Data v;
v.SetString(ctx.reply.MemberAt(i).str, true);
sortvals.push_back(v);
}
}
if (sortvals.empty())
{
return 0;
}
if (options.with_limit)
{
if (options.limit_offset < 0)
{
options.limit_offset = 0;
}
if ((uint32) options.limit_offset > sortvals.size())
{
values.clear();
return 0;
}
if (options.limit_count < 0)
{
options.limit_count = sortvals.size();
}
}
std::vector<SortValue> sortvec;
if (!options.nosort)
{
if (NULL != options.by)
{
sortvec.reserve(sortvals.size());
}
for (uint32 i = 0; i < sortvals.size(); i++)
{
if (NULL != options.by)
{
sortvec.push_back(SortValue(&sortvals[i]));
if (GetValueByPattern(ctx, options.by, sortvals[i], sortvec[i].cmp) < 0)
{
DEBUG_LOG("Failed to get value by pattern:%s", options.by);
sortvec[i].cmp.Clear();
continue;
}
}
if (options.with_alpha)
{
if (NULL != options.by)
{
sortvec[i].cmp.ToString();
}
else
{
sortvals[i].ToString();
}
}
}
if (NULL != options.by)
{
if (!options.is_desc)
{
std::sort(sortvec.begin(), sortvec.end(), less_value<SortValue>);
//.........这里部分代码省略.........