本文整理汇总了C++中Cell函数的典型用法代码示例。如果您正苦于以下问题:C++ Cell函数的具体用法?C++ Cell怎么用?C++ Cell使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了Cell函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: tmp
bool Command::setFromString(const QString &inp_str)
{
QString delim = ";";
QString tmp(inp_str);
if ( !tmp.contains(QRegExp("[0-7],[0-7]"+delim+"( |F|K|Q|R|B|P|Kn)"+delim+"[wb]"+delim+delim+"[0-7],[0-7]"+delim+"( |F|K|Q|R|B|P|Kn)"+delim+"[wb]\n")) )
return false;
tmp.remove("\n");
QStringList line = tmp.split(delim+delim);
QStringList b_info_list = line[0].split(delim);
QStringList b_cell_list = b_info_list[0].split(",");
b_cell_info_.cell_ = Cell(b_cell_list[0].toInt(), b_cell_list[1].toInt());
b_cell_info_.ftype_ = b_info_list[1];
QString b_color = b_info_list[2];
if (b_color == "w")
b_cell_info_.fcolor_ = WHITE;
else if(b_color == "b")
b_cell_info_.fcolor_ = BLACK;
else
b_cell_info_.fcolor_ = NONE;
QStringList e_info_list = line[1].split(delim);
QStringList e_cell_list = e_info_list[0].split(",");
e_cell_info_.cell_ = Cell(e_cell_list[0].toInt(), e_cell_list[1].toInt());
e_cell_info_.ftype_ = e_info_list[1];
QString e_color = e_info_list[2];
if (e_color == "w")
e_cell_info_.fcolor_ = WHITE;
else if(e_color == "b")
e_cell_info_.fcolor_ = BLACK;
else
e_cell_info_.fcolor_ = NONE;
return true;
}
示例2: Cell
double GlobalPlanner::getRisk(Cell & cell) {
double risk = explorePenalty;
if (occProb.find(cell) != occProb.end()) {
risk = octomap::probability(occProb[cell]);
}
Cell front = Cell(cell.x()+1, cell.y(), cell.z());
Cell back = Cell(cell.x()-1, cell.y(), cell.z());
Cell right = Cell(cell.x(), cell.y()+1, cell.z());
Cell left = Cell(cell.x(), cell.y()-1, cell.z());
Cell up = Cell(cell.x(), cell.y(), cell.z()+1);
Cell down = Cell(cell.x(), cell.y(), cell.z()-1);
if (occProb.find(front) != occProb.end()) {
risk += octomap::probability(occProb[front]);
}
if (occProb.find(back) != occProb.end()) {
risk += octomap::probability(occProb[back]);
}
if (occProb.find(right) != occProb.end()) {
risk += octomap::probability(occProb[right]);
}
if (occProb.find(left) != occProb.end()) {
risk += octomap::probability(occProb[left]);
}
if (occProb.find(up) != occProb.end()) {
risk += octomap::probability(occProb[up]);
}
if (occProb.find(down) != occProb.end()) {
risk += octomap::probability(occProb[down]);
}
double prior = heightPrior[floor(cell.z())];
// ROS_INFO("risk: %f \t prior: %f \n", risk, prior);
return risk * prior;
}
示例3: FancyTable
// Colored table
void FancyTable(wxArrayString& header, wxArrayPtrVoid& data)
{
// Colors, line width and bold font
SetFillColour(wxColour(255,0,0));
SetTextColour(255);
SetDrawColour(wxColour(128,0,0));
SetLineWidth(.3);
SetFont(wxT(""),wxT("B"));
//Header
double w[4] = {40,35,40,45};
size_t i;
for (i = 0; i < header.GetCount(); i++)
{
Cell(w[i],7,header[i],wxPDF_BORDER_FRAME, 0, wxPDF_ALIGN_CENTER, 1);
}
Ln();
// Color and font restoration
SetFillColour(wxColour(224,235,255));
SetTextColour(0);
SetFont(wxT(""));
// Data
int fill = 0;
size_t j;
for (j = 0; j < data.GetCount(); j++)
{
wxArrayString* row = (wxArrayString*) data[j];
Cell(w[0],6,(*row)[0],wxPDF_BORDER_LEFT | wxPDF_BORDER_RIGHT,0,wxPDF_ALIGN_LEFT,fill);
Cell(w[1],6,(*row)[1],wxPDF_BORDER_LEFT | wxPDF_BORDER_RIGHT,0,wxPDF_ALIGN_LEFT,fill);
Cell(w[2],6,(*row)[2],wxPDF_BORDER_LEFT | wxPDF_BORDER_RIGHT,0,wxPDF_ALIGN_RIGHT,fill);
Cell(w[3],6,(*row)[3],wxPDF_BORDER_LEFT | wxPDF_BORDER_RIGHT,0,wxPDF_ALIGN_RIGHT,fill);
Ln();
fill = 1 - fill;
}
Cell((w[0]+w[1]+w[2]+w[3]),0,wxT(""),wxPDF_BORDER_TOP);
}
示例4: ImprovedTable
// Better table
void ImprovedTable(wxArrayString& header,wxArrayPtrVoid& data)
{
// Column widths
double w[4] = {40,35,40,45};
// Header
size_t i;
for (i = 0; i <header.GetCount(); i++)
{
Cell(w[i],7,header[i],wxPDF_BORDER_FRAME,0,wxPDF_ALIGN_CENTER);
}
Ln();
// Data
size_t j;
for (j = 0; j < data.GetCount(); j++)
{
wxArrayString* row = (wxArrayString*) data[j];
Cell(w[0],6,(*row)[0],wxPDF_BORDER_LEFT | wxPDF_BORDER_RIGHT);
Cell(w[1],6,(*row)[1],wxPDF_BORDER_LEFT | wxPDF_BORDER_RIGHT);
Cell(w[2],6,(*row)[2],wxPDF_BORDER_LEFT | wxPDF_BORDER_RIGHT,0,wxPDF_ALIGN_RIGHT);
Cell(w[3],6,(*row)[3],wxPDF_BORDER_LEFT | wxPDF_BORDER_RIGHT,0,wxPDF_ALIGN_RIGHT);
Ln();
}
// Closure line
Cell((w[0]+w[1]+w[2]+w[3]),0,wxS(""),wxPDF_BORDER_TOP);
}
示例5: pk
void TileMap::set_cell(int p_x,int p_y,int p_tile,bool p_flip_x,bool p_flip_y,bool p_transpose) {
PosKey pk(p_x,p_y);
Map<PosKey,Cell>::Element *E=tile_map.find(pk);
if (!E && p_tile==INVALID_CELL)
return; //nothing to do
PosKey qk(p_x/_get_quadrant_size(),p_y/_get_quadrant_size());
if (p_tile==INVALID_CELL) {
//erase existing
tile_map.erase(pk);
Map<PosKey,Quadrant>::Element *Q = quadrant_map.find(qk);
ERR_FAIL_COND(!Q);
Quadrant &q=Q->get();
q.cells.erase(pk);
if (q.cells.size()==0)
_erase_quadrant(Q);
else
_make_quadrant_dirty(Q);
return;
}
Map<PosKey,Quadrant>::Element *Q = quadrant_map.find(qk);
if (!E) {
E=tile_map.insert(pk,Cell());
if (!Q) {
Q=_create_quadrant(qk);
}
Quadrant &q=Q->get();
q.cells.insert(pk);
} else {
ERR_FAIL_COND(!Q); // quadrant should exist...
if (E->get().id==p_tile && E->get().flip_h==p_flip_x && E->get().flip_v==p_flip_y && E->get().transpose==p_transpose)
return; //nothing changed
}
Cell &c = E->get();
c.id=p_tile;
c.flip_h=p_flip_x;
c.flip_v=p_flip_y;
c.transpose=p_transpose;
_make_quadrant_dirty(Q);
}
示例6: GetMap
void Transport::UpdatePosition(float x, float y, float z, float o)
{
bool newActive = GetMap()->IsGridLoaded(x, y);
Relocate(x, y, z, o);
UpdatePassengerPositions(_passengers);
/* There are four possible scenarios that trigger loading/unloading passengers:
1. transport moves from inactive to active grid
2. the grid that transport is currently in becomes active
3. transport moves from active to inactive grid
4. the grid that transport is currently in unloads
*/
if (_staticPassengers.empty() && newActive) // 1. and 2.
LoadStaticPassengers();
else if (!_staticPassengers.empty() && !newActive && Cell(x, y).DiffGrid(Cell(GetPositionX(), GetPositionY()))) // 3.
UnloadStaticPassengers();
else
UpdatePassengerPositions(_staticPassengers);
// 4. is handed by grid unload
}
示例7: resources
CCMSDIntegrator::CCMSDIntegrator(void)
:
resources((std::vector<IObjectPtr>&) Resource().objects()),
cells((std::vector<IObjectPtr>&) Cell().objects()),
parts((std::vector<IObjectPtr>&) Part().objects()),
processplans((std::vector<IObjectPtr>&) ProcessPlan().objects()),
jobs((std::vector<IObjectPtr>&) Job().objects()),
distributions((std::vector<IObjectPtr>&) Distribution().objects()),
calendars((std::vector<IObjectPtr>&) Calendar().objects()),
layouts((std::vector<IObjectPtr>&) Layout().objects())
{
}
示例8: TEST
TEST(Parser, correctParsCels) {
int m(3), n(3);
std::istringstream inp( "...\n"
".*.\n"
".**");
std::vector<Cell> corr_cell = {
Cell(0, 0, Status::DEAD), Cell(1, 0, Status::DEAD), Cell(2, 0, Status::DEAD),
Cell(0, 1, Status::DEAD), Cell(1, 1, Status::LIVE), Cell(2, 1, Status::DEAD),
Cell(0, 2, Status::DEAD), Cell(1, 2, Status::LIVE), Cell(2, 2, Status::LIVE)
};
Parser parser(inp);
std::vector<Cell> g_inp = parser.getGrid(m, n);
EXPECT_EQ(g_inp, corr_cell);
}
示例9: switch
const list<Cell> Combo::getList() {
int r, c;
list<Cell> cells;
switch (getState()) {
case Combo::VERT:
r = down()->row;
c = down()->col;
for (r; r <= up()->row; ++r) {
cells.push_back(Cell(r, c));
}
break;
case Combo::HORI:
r = left()->row;
c = left()->col;
for (c; c <= right()->col; ++c) {
cells.push_back(Cell(r, c));
}
break;
case Combo::MULTI:
r = left()->row;
c = left()->col;
for (c; c <= right()->col; ++c) {
cells.push_back(Cell(r, c));
}
c = down()->col;
r = down()->row;
for (r; r <= up()->row; ++r) {
cells.push_back(Cell(r, c));
}
}
return cells;
}
示例10: parts
TileCell::TileCell(String const& rString, bool remoteFlag) {
Strings const parts(rString, SEPARATOR);
ASSERT(parts.Count() == 2); // TODO recovery
String const first = parts.First();
mTile = Tile(IndexType(first), remoteFlag);
mSwapFlag = true;
String const second = parts.Second();
if (second != SWAP) {
mCell = Cell(second);
mSwapFlag = false;
}
}
示例11: addChild
void
TableLayout::addComponent(size_t col, size_t row, Component* component)
{
if(row >= rowproperties.size())
throw std::runtime_error("row out of range");
if(col >= colproperties.size())
throw std::runtime_error("col out of range");
if(cells[row * colproperties.size() + col].childid >= 0)
throw std::runtime_error("Already a component in this cell.");
addChild(component);
cells[row * colproperties.size() + col] = Cell(childs.size()-1);
}
示例12: DBObjTableField
void DBNetworkIF::SetMagnitude ()
{
DBInt cellID;
DBObjRecord *cellRec, *toCellRec;
if (MagnitudeFLD == (DBObjTableField *) NULL)
{
MagnitudeFLD = new DBObjTableField (DBrNMagnitude,DBTableFieldInt,"%4d",sizeof (DBShort));
CellTable->AddField (MagnitudeFLD);
}
for (cellID = 0;cellID < CellNum ();++cellID)
{
cellRec = Cell (cellID);
MagnitudeFLD->Int (cellRec,(FromCellDirs (cellRec) == 0x0) ? 1 : 0);
}
for (cellID = 0;cellID < CellNum ();++cellID)
{
cellRec = Cell (cellID);
DBPause ((CellNum () - cellRec->RowID ()) * 100 / CellNum ());
if ((toCellRec = ToCell (cellRec)) != (DBObjRecord *) NULL)
MagnitudeFLD->Int (toCellRec,MagnitudeFLD->Int (toCellRec) + MagnitudeFLD->Int (cellRec));
}
}
示例13: start_c
void BuyerParser::getAdCampaign(std::vector<std::vector<float> >& v) {
v.clear();
Cell start_c('c',41);
for( int b=0; b<N_BRANDS; b++ ) {
v.push_back(std::vector<float>(N_TIME_INTERVALS));
Cell c = Cell(start_c.first + b, start_c.second);
for( int t=0; t<N_TIME_INTERVALS; t++ ) {
v[b][t] = std::atof( getCell(c).c_str() );
c.second++;
}
}
}
示例14: Cell
inline
typename SlicedCartesian<ScalarParam,dimensionParam,VScalarParam>::Cell
SlicedCartesian<ScalarParam,dimensionParam,VScalarParam>::Cell::getNeighbour(
int neighbourIndex) const
{
Index neighbourCellIndex=index;
int face=neighbourIndex>>1;
if(neighbourIndex&0x1)
{
++neighbourCellIndex[face];
if(neighbourCellIndex[face]<grid->numCells[face])
return Cell(grid,neighbourCellIndex);
else
return Cell();
}
else
{
--neighbourCellIndex[face];
if(neighbourCellIndex[face]>=0)
return Cell(grid,neighbourCellIndex);
else
return Cell();
}
}
示例15: switch
Node *findLeaf(Node *node, Cell const &at, bool canSubdivide)
{
if(node->isLeaf()) return node;
// Into which quadrant do we need to descend?
Node::Quadrant q = node->quadrant(at);
// Has this quadrant been initialized yet?
Node **childAdr = &node->children[q];
if(!*childAdr)
{
if(!canSubdivide) return 0;
// Subdivide the space.
uint const subSize = node->size >> 1;
switch(q)
{
case Node::TopLeft:
*childAdr = newNode(node->cell, subSize);
break;
case Node::TopRight:
*childAdr = newNode(Cell(node->cell.x + subSize, node->cell.y), subSize);
break;
case Node::BottomLeft:
*childAdr = newNode(Cell(node->cell.x, node->cell.y + subSize), subSize);
break;
case Node::BottomRight:
*childAdr = newNode(Cell(node->cell.x + subSize, node->cell.y + subSize), subSize);
break;
}
}
return findLeaf(*childAdr, at, canSubdivide);
}