本文整理汇总了C++中Response::addElement方法的典型用法代码示例。如果您正苦于以下问题:C++ Response::addElement方法的具体用法?C++ Response::addElement怎么用?C++ Response::addElement使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Response
的用法示例。
在下文中一共展示了Response::addElement方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: queryRegion
void TileNode::queryRegion(const SpatialDimension* hashing, const Query& query, Response& response, ulong level) const {
const ulong d = level % hashing->key().size();
if (query.evalRegion(d)) {
/*std::cout << "eval" << std::endl;
std::cout << query.getRegion(d).lon0 << std::endl;
std::cout << util::tilex2lon(_pivot.value().x, 0) << std::endl;
std::cout << query.getRegion(d).lon1 << std::endl;
std::cout << util::tilex2lon(_pivot.value().x + 1, 0) << std::endl;
std::cout << query.getRegion(d).lat0 << std::endl;
std::cout << util::tiley2lat(_pivot.value().y, 0) << std::endl;
std::cout << query.getRegion(d).lat1 << std::endl;
std::cout << util::tiley2lat(_pivot.value().y + 1, 0) << std::endl;*/
if (util::intersectsTile(_pivot.value(), query.getRegion(d))) {
//std::cout << "intersects" << std::endl;
if (d == query.getLastValidRegion() && (last() || _pivot.value().z == query.zoom)) {
response.addElement(&_pivot);
} else {
if (_container[0] != nullptr) _container[0]->queryRegion(hashing, query, response, level + 1);
if (_container[1] != nullptr) _container[1]->queryRegion(hashing, query, response, level + 1);
if (_container[2] != nullptr) _container[2]->queryRegion(hashing, query, response, level + 1);
if (_container[3] != nullptr) _container[3]->queryRegion(hashing, query, response, level + 1);
}
} else {
return;
}
} else {
if (_container[0] != nullptr) _container[0]->queryRegion(hashing, query, response, level + 1);
if (_container[1] != nullptr) _container[1]->queryRegion(hashing, query, response, level + 1);
if (_container[2] != nullptr) _container[2]->queryRegion(hashing, query, response, level + 1);
if (_container[3] != nullptr) _container[3]->queryRegion(hashing, query, response, level + 1);
}
}
示例2: query
void TemporalNode::query(const TemporalInterval& interval, Response& response) const {
if (interval.contains(lower(), upper())) {
response.addElement(&_pivot);
} else {
queryInterval(interval, response);
}
}
示例3: aggregateTile
void TileNode::aggregateTile(const SpatialDimension* hashing, const Query& query, Response& response, ulong level) const {
const ulong d = level % hashing->key().size();
if (query.evalTile(d) && (last() || _pivot.value().z >= query.zoom + query.resolution)) {
response.addElement(&_pivot);
} else {
if (_container[0] != nullptr) _container[0]->aggregateTile(hashing, query, response, level + 1);
if (_container[1] != nullptr) _container[1]->aggregateTile(hashing, query, response, level + 1);
if (_container[2] != nullptr) _container[2]->aggregateTile(hashing, query, response, level + 1);
if (_container[3] != nullptr) _container[3]->aggregateTile(hashing, query, response, level + 1);
}
}