当前位置: 首页>>代码示例>>C++>>正文


C++ Body::addNode方法代码示例

本文整理汇总了C++中Body::addNode方法的典型用法代码示例。如果您正苦于以下问题:C++ Body::addNode方法的具体用法?C++ Body::addNode怎么用?C++ Body::addNode使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Body的用法示例。


在下文中一共展示了Body::addNode方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: createSolidWall

void Physics::createSolidWall(b2Vec2 position, float rotation,
                              b2Vec2 size, bool isWorkspace=false)
{
    Body wall;
    wall.setType(WALL);
    b2BodyDef wallDef; //static body by default
    wallDef.position.Set(position.x,position.y);
    wallDef.angle = rotation;
    b2Body* wallBody = world->CreateBody(&wallDef);
    b2PolygonShape wallShape;
    wallShape.SetAsBox(size.x,size.y);
    b2FixtureDef wallFixtureDef;
    wallFixtureDef.shape = &wallShape;
    wallBody->CreateFixture(&wallFixtureDef);
    wall.addNode(wallBody);
    wall.finish();
    wall.setName("Wall");
    wall.setWallPosition(rotation*180/pi);
    if(isWorkspace)
    {
        workspaceWalls.append(wall);
    }else
    {
        bodyList.append(wall);
        emit objectListUpdated(bodyList);
    }
}
开发者ID:HackTheForce2D,项目名称:HapticSoftware,代码行数:27,代码来源:physics.cpp

示例2: createBall

void Physics::createBall(b2Vec2 position,float radius, float stiffness,
                         float damping, float density, float maxSpacing)
{
    Body ball;
    ball.setType(BALL);
    float nodeRadius = maxSpacing*.45;
    ball.setNodeRadius(nodeRadius);
    float mass(density*radius*radius);
    int nodeCount = (2*pi*radius/maxSpacing); //not including center
    float nodeDensity(mass/(nodeRadius*nodeRadius*(nodeCount+1)));
    b2BodyDef ballNodeDef;
    ballNodeDef.linearDamping = 1;
    ballNodeDef.angularDamping = 1;
    b2CircleShape ballNodeShape;
    ballNodeShape.m_radius = nodeRadius;
    b2FixtureDef ballFixtureDef;
    ballFixtureDef.shape = &ballNodeShape;
    ballFixtureDef.density = nodeDensity;
    ballNodeDef.type = b2_dynamicBody;
    b2DistanceJointDef nodeLinkDef;
    b2MotorJointDef nodeLinkMotorDef;
    // Smaller stiffness in the link from the center to the edge
    // So that the effector can deform the ball without penetrating it
    nodeLinkDef.frequencyHz = sqrt((stiffness)*FORCE_FACTOR/mass);
    nodeLinkDef.dampingRatio = damping;
    nodeLinkMotorDef.correctionFactor = stiffness;
    nodeLinkMotorDef.maxForce = stiffness*radius;
    nodeLinkMotorDef.maxTorque = 0;

    //center
    ballNodeDef.position.Set(position.x,position.y);
    b2Body* ballCenter = world->CreateBody(&ballNodeDef);
    ballCenter->CreateFixture(&ballFixtureDef);
    ball.addNode(ballCenter);
    //circle
    b2Vec2 nodePosition;
    //b2Body* firstNode =ballCenter,lastNode = ballCenter;
    for(int i(0);i<nodeCount;i++)
    {
        ballNodeDef.type = b2_dynamicBody;
        nodePosition = position + radius*b2Vec2(cos(2*pi*i/nodeCount),
                                                sin(2*pi*i/nodeCount));
        ballNodeDef.position.Set(nodePosition.x,nodePosition.y);
        b2Body* ballNode = world->CreateBody(&ballNodeDef);
        ballNode->CreateFixture(&ballFixtureDef);
        nodeLinkDef.Initialize(ballCenter,ballNode,
                               ballCenter->GetWorldCenter(),
                               ballNode->GetWorldCenter());
        world->CreateJoint(&nodeLinkDef);
        nodeLinkMotorDef.Initialize(ballCenter,ballNode);
        world->CreateJoint(&nodeLinkMotorDef);
        if(i>0)
        {
            nodeLinkDef.Initialize(ballNode,ball.getNode(i-1),
                                   ballNode->GetWorldCenter(),
                                   ball.getNode(i-1)->GetWorldCenter());
            world->CreateJoint(&nodeLinkDef);
            nodeLinkMotorDef.Initialize(ballNode,ball.getNode(i-1));
            world->CreateJoint(&nodeLinkMotorDef);
        }
        ball.addNode(ballNode);
    }
    nodeLinkDef.Initialize(ball.getNode(nodeCount-1),ball.getNode(1),
                           ball.getNode(nodeCount-1)->GetWorldCenter(),
                           ball.getNode(1)->GetWorldCenter());
    world->CreateJoint(&nodeLinkDef);
    nodeLinkMotorDef.Initialize(ball.getNode(nodeCount-1),ball.getNode(1));
    world->CreateJoint(&nodeLinkMotorDef);
    ball.finish();
    ball.setName("Ball");
    ball.setTransform(physics2graphics);
    bodyList.append(ball);
    emit objectListUpdated(bodyList);
}
开发者ID:HackTheForce2D,项目名称:HapticSoftware,代码行数:74,代码来源:physics.cpp


注:本文中的Body::addNode方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。