Merge pull request #122 from songchengjiang/billboard

BillBorad
This commit is contained in:
XiaoYang 2014-09-02 14:34:34 +08:00
commit e5dd91029a
3 changed files with 43 additions and 20 deletions

View File

@ -93,12 +93,13 @@ BillBorad* BillBorad::create()
void BillBorad::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) void BillBorad::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
{ {
auto camera = Camera::getVisitingCamera(); auto camera = Camera::getVisitingCamera();
if (memcmp(_preViewMat.m, camera->getViewMatrix().m, sizeof(float) * 16) != 0) const Mat4 &viewMat = camera->getViewMatrix();
if (memcmp(_preViewMat.m, viewMat.m, sizeof(float) * 16) != 0)
{ {
Mat4 viewInverseMat = camera->getInverseViewMatrix(); Mat4 viewInverseMat = camera->getInverseViewMatrix();
viewInverseMat.m[12] = viewInverseMat.m[13] = viewInverseMat.m[14] = 0; viewInverseMat.m[12] = viewInverseMat.m[13] = viewInverseMat.m[14] = 0;
Mat4 modelViewMat = camera->getViewMatrix() * transform; Mat4 modelViewMat = viewMat * transform;
_preViewMat = camera->getViewMatrix(); _preViewMat = viewMat;
_zDepthInView = -modelViewMat.m[14]; _zDepthInView = -modelViewMat.m[14];
_mv = viewInverseMat; _mv = viewInverseMat;
} }

View File

@ -456,7 +456,7 @@ void Renderer::render()
//Process render commands //Process render commands
//draw transparent objects here, do not batch for transparent objects //draw transparent objects here, do not batch for transparent objects
if (_transparentRenderGroups.size()) if (0 < _transparentRenderGroups.size())
{ {
_transparentRenderGroups.sort(); _transparentRenderGroups.sort();
glEnable(GL_DEPTH_TEST); glEnable(GL_DEPTH_TEST);

View File

@ -1538,7 +1538,6 @@ BillBoardTest::BillBoardTest()
auto layer3D=Layer::create(); auto layer3D=Layer::create();
addChild(layer3D,0); addChild(layer3D,0);
_layerBillBorad=layer3D; _layerBillBorad=layer3D;
DrawNode3D* line =DrawNode3D::create();
auto s = Director::getInstance()->getWinSize(); auto s = Director::getInstance()->getWinSize();
if (_camera == nullptr) if (_camera == nullptr)
{ {
@ -1551,8 +1550,8 @@ BillBoardTest::BillBoardTest()
{ {
std::string fileName = "Sprite3DTest/orc.c3b"; std::string fileName = "Sprite3DTest/orc.c3b";
auto sprite = Sprite3D::create(fileName); auto sprite = Sprite3D::create(fileName);
sprite->setScale(3);
sprite->setRotation3D(Vec3(0,180,0)); sprite->setRotation3D(Vec3(0,180,0));
sprite->setScale(2.0f);
_layerBillBorad->addChild(sprite); _layerBillBorad->addChild(sprite);
//test attach //test attach
auto sp = Sprite3D::create("Sprite3DTest/axe.c3b"); auto sp = Sprite3D::create("Sprite3DTest/axe.c3b");
@ -1564,6 +1563,43 @@ BillBoardTest::BillBoardTest()
sprite->runAction(RepeatForever::create(animate)); sprite->runAction(RepeatForever::create(animate));
} }
} }
{
std::string fileName = "Sprite3DTest/orc.c3b";
auto sprite = Sprite3D::create(fileName);
sprite->setRotation3D(Vec3(0,180,0));
sprite->setPosition3D(Vec3(100.0f, 0.0f, 0.0f));
sprite->setScale(2.0f);
_layerBillBorad->addChild(sprite);
//test attach
auto sp = Sprite3D::create("Sprite3DTest/axe.c3b");
sprite->getAttachNode("Bip001 R Hand")->addChild(sp);
auto animation = Animation3D::create(fileName);
if (animation)
{
auto animate = Animate3D::create(animation);
sprite->runAction(RepeatForever::create(animate));
}
}
{
std::string fileName = "Sprite3DTest/orc.c3b";
auto sprite = Sprite3D::create(fileName);
sprite->setRotation3D(Vec3(0,180,0));
sprite->setPosition3D(Vec3(-100.0f, 0.0f, 0.0f));
sprite->setScale(2.0f);
_layerBillBorad->addChild(sprite);
//test attach
auto sp = Sprite3D::create("Sprite3DTest/axe.c3b");
sprite->getAttachNode("Bip001 R Hand")->addChild(sp);
auto animation = Animation3D::create(fileName);
if (animation)
{
auto animate = Animate3D::create(animation);
sprite->runAction(RepeatForever::create(animate));
}
}
addNewBillBoradWithCoords(Vec3(20,5,0)); addNewBillBoradWithCoords(Vec3(20,5,0));
addNewBillBoradWithCoords(Vec3(60,5,0)); addNewBillBoradWithCoords(Vec3(60,5,0));
addNewBillBoradWithCoords(Vec3(100,5,0)); addNewBillBoradWithCoords(Vec3(100,5,0));
@ -1577,20 +1613,6 @@ BillBoardTest::BillBoardTest()
_camera->setPosition3D(Vec3(0, 130, 230)); _camera->setPosition3D(Vec3(0, 130, 230));
_camera->lookAt(Vec3(0,0,100), Vec3(0,1,0)); _camera->lookAt(Vec3(0,0,100), Vec3(0,1,0));
//for( int j =-20; j<=20 ;j++)
//{
// line->drawLine(Vec3(-100, 0, 5*j),Vec3(100,0,5*j),Color4F(0,1,0,1));
//}
////draw z
//for( int j =-20; j<=20 ;j++)
//{
// line->drawLine(Vec3(5*j, 0, -100),Vec3(5*j,0,100),Color4F(0,1,0,1));
//}
////draw y
////line->drawLine(Vec3(0, -50, 0),Vec3(0,0,0),Color4F(0,0.5,0,1));
////line->drawLine(Vec3(0, 0, 0),Vec3(0,50,0),Color4F(0,1,0,1));
//_layerBillBorad->addChild(line);
TTFConfig ttfConfig("fonts/arial.ttf", 20); TTFConfig ttfConfig("fonts/arial.ttf", 20);
auto label1 = Label::createWithTTF(ttfConfig,"rotate+"); auto label1 = Label::createWithTTF(ttfConfig,"rotate+");
auto menuItem1 = MenuItemLabel::create(label1, CC_CALLBACK_1(BillBoardTest::rotateCameraCallback,this,10)); auto menuItem1 = MenuItemLabel::create(label1, CC_CALLBACK_1(BillBoardTest::rotateCameraCallback,this,10));