我暂时不想使用地图,我想如果用精灵直接制造成方块也是可以的。代码如下,这个是添加地板
void Stage::addGround() { auto g=Sprite::create(); g->setTextureRect(Rect(0,0,visible.width,15)); g->setColor(Color3B(100,100,100)); g->setPosition(visible.width/2,world_y-8.5); this->addChild(g); }我并不知道Rect的前两个参数是干什么的,源代码写的是x和y,好像是坐标的意思,但是我设置了不同的值效果是一样的..
顺便提一句,血的教训,在继承自父类之后,在init()里要先执行一下父类的init。
写一个block类
bool myblock::init() { Sprite::init(); speed = 5; auto visible = Director::getInstance()->getVisibleSize(); /*Size s =(Size(rand()%20+5,rand()%20+5));*/ s =Size(rand()%25+10,rand()%35+5); this->setPhysicsBody(PhysicsBody::createBox(s)); this->setTextureRect(Rect(0,0,s.width,s.height)); this->setColor(Color3B(100,100,100)); this->setPositionX(visible.width-s.width/2); this->schedule(schedule_selector(myblock::block_run)); return true; } void myblock::block_run(float f) { this->setPositionX(this->getPosition().x-speed); if (this->getPositionX()<0) <span style="white-space:pre"> </span>{ <span style="white-space:pre"> </span> removeFromParent(); <span style="white-space:pre"> </span>} }加了定时器,让方块一直往左走,当block离开屏幕就移除。
然后在Stage中加定时器,隔一段时间出现一个方块,但是又不能在计时器函数参数后面加一个rand()做时间,因为这是个伪随机数,后来在网上找到了一个很聪明的办法。
让数a=0,让b取一个制定范围的随机数,在updat里让a++,当a>b就生成一个障碍,并且让a=0,b再取一个随机数。如此循环。
void Stage::restar() { a=0; b=rand()%120+60; } void Stage::addblock(float f) { a++; if(a>=b) { auto b=myblock::create(); this->addChild(b); b->setPositionY(world_y+b->s.height/2); b->getPhysicsBody()->setDynamic(false); restar(); } }
</pre><pre name="code" class="cpp" style="box-sizing: border-box; font-family: Arial, 'Microsoft YaHei'; font-size: 13px; white-space: pre-wrap; padding: 0px; margin-top: 0px; margin-bottom: 0px; line-height: 1.42857; color: rgb(51, 51, 51); word-break: break-all; word-wrap: break-word; border: 1px solid rgb(204, 204, 204); border-radius: 4px; overflow: hidden; width: 1543px; background-color: rgb(245, 245, 245);">
由于block得添加两种,一种地上的,一种浮空的,只能趴着过的。两者必须随机添加。我的方法如下。
myblock.h
static myblock* create(Size s);
myblock* myblock::create(Size s) { myblock* bl = new myblock(); //Sprite::init(); bl->init(); bl->speed = 10; auto visible = Director::getInstance()->getVisibleSize(); /*Size s =(Size(rand()%20+5,rand()%20+5));*/ /*i =Size(rand()%35+20,rand()%45+15);*/ bl->setPhysicsBody(PhysicsBody::createBox(s)); bl->setTextureRect(Rect(0,0,s.width,s.height)); bl->setColor(Color3B(100,100,100)); bl->setPositionX(visible.width-s.width/2+300); bl->schedule(schedule_selector(myblock::block_run)); bl->getPhysicsBody()->setContactTestBitmask(1); return bl; }
void Stage::addblock(float f) { a++; if(a>=b) { if (b>90) { Size s =Size(rand()%35+20,rand()%45+15); auto bl=myblock::create(s); this->addChild(bl); bl->setPositionY(world_y+s.height/2); bl->getPhysicsBody()->setDynamic(false); restar(); } else { Size s =Size(rand()%75+35,rand()%25+10); auto bl=myblock::create(s); this->addChild(bl); bl->setPositionY(world_y+s.height/2+100); bl->getPhysicsBody()->setDynamic(false); restar(); } } }
测试碰撞,先添加Listener,这个物理引擎有自己的碰撞监听。
auto listen = EventListenerPhysicsContact::create(); listen->onContactBegin=[&](PhysicsContact& contact) { log("<<<<<<<<<<<<<<"); return true; }; Director::getInstance()->getEventDispatcher()->addEventListenerWithSceneGraphPriority(listen,this);然后给主角和block类各填一句话,打开碰撞检测开关,都设置成相同的数,两者就可以碰撞检测
->getPhysicsBody()->setContactTestBitmask(1);然后就可以添加死掉的动作在拉姆达表达式中。