本文整理汇总了Java中com.watabou.utils.GameMath类的典型用法代码示例。如果您正苦于以下问题:Java GameMath类的具体用法?Java GameMath怎么用?Java GameMath使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
GameMath类属于com.watabou.utils包,在下文中一共展示了GameMath类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: proc
import com.watabou.utils.GameMath; //导入依赖的package包/类
@Override
public int proc(Armor armor, Char attacker, Char defender, int damage) {
int level = (int) GameMath.gate(0, armor.level, 6);
if (Dungeon.level.adjacent(attacker.pos, defender.pos)
&& Random.Int(level / 2 + 5) >= 4) {
int duration = Random.IntRange(3, 7);
Buff.affect(attacker, Charm.class, Charm.durationFactor(attacker)
* duration).object = defender.id();
attacker.sprite.centerEmitter().start(Speck.factory(Speck.HEART),
0.2f, 5);
//duration *= Random.Float(0.5f, 1);
//Buff.affect(defender, Charm.class, Charm.durationFactor(defender)
// * duration).object = attacker.id();
//defender.sprite.centerEmitter().start(Speck.factory(Speck.HEART),
// 0.2f, 5);
}
return damage;
}
示例2: zoom
import com.watabou.utils.GameMath; //导入依赖的package包/类
private float zoom( float value ) {
value = GameMath.gate( PixelScene.minZoom, value, PixelScene.maxZoom );
UNISTPixelDungeon.zoom((int) (value - PixelScene.defaultZoom));
camera.zoom( value );
//Resets character sprite positions with the new camera zoom
//This is important as characters are centered on a 16x16 tile, but may have any sprite size
//This can lead to none-whole coordinate, which need to be aligned with the zoom
for (Char c : Actor.chars()){
if (c.sprite != null && !c.sprite.isMoving){
c.sprite.point(c.sprite.worldToCamera(c.pos));
}
}
return value;
}
示例3: updateMotion
import com.watabou.utils.GameMath; //导入依赖的package包/类
protected void updateMotion()
{
float elapsed = Game.elapsed;
float d = (GameMath.speed(speed.x, acc.x) - speed.x) / 2;
speed.x += d;
x += speed.x * elapsed;
speed.x += d;
d = (GameMath.speed(speed.y, acc.y) - speed.y) / 2;
speed.y += d;
y += speed.y * elapsed;
speed.y += d;
angle += angularSpeed * elapsed;
}
示例4: updateMotion
import com.watabou.utils.GameMath; //导入依赖的package包/类
protected void updateMotion() {
float elapsed = Game.elapsed;
float d = (GameMath.speed( speed.x, acc.x ) - speed.x) / 2;
speed.x += d;
x += speed.x * elapsed;
speed.x += d;
d = (GameMath.speed( speed.y, acc.y ) - speed.y) / 2;
speed.y += d;
y += speed.y * elapsed;
speed.y += d;
angle += angularSpeed * elapsed;
}
示例5: updateMotion
import com.watabou.utils.GameMath; //导入依赖的package包/类
protected void updateMotion() {
float elapsed = Game.elapsed;
float d = (GameMath.speed(speed.x, acc.x) - speed.x) / 2;
speed.x += d;
x += speed.x * elapsed;
speed.x += d;
d = (GameMath.speed(speed.y, acc.y) - speed.y) / 2;
speed.y += d;
y += speed.y * elapsed;
speed.y += d;
angle += angularSpeed * elapsed;
}
示例6: zoom
import com.watabou.utils.GameMath; //导入依赖的package包/类
private float zoom( float value ) {
value = GameMath.gate( PixelScene.minZoom, value, PixelScene.maxZoom );
ShatteredPixelDungeon.zoom((int) (value - PixelScene.defaultZoom));
camera.zoom( value );
//Resets character sprite positions with the new camera zoom
//This is important as characters are centered on a 16x16 tile, but may have any sprite size
//This can lead to none-whole coordinate, which need to be aligned with the zoom
for (Char c : Actor.chars()){
if (c.sprite != null && !c.sprite.isMoving){
c.sprite.point(c.sprite.worldToCamera(c.pos));
}
}
return value;
}
示例7: getDoorCenter
import com.watabou.utils.GameMath; //导入依赖的package包/类
protected final Point getDoorCenter(){
PointF doorCenter = new PointF(0, 0);
for (Door door : connected.values()) {
doorCenter.x += door.x;
doorCenter.y += door.y;
}
Point c = new Point((int)doorCenter.x / connected.size(), (int)doorCenter.y / connected.size());
if (Random.Float() < doorCenter.x % 1) c.x++;
if (Random.Float() < doorCenter.y % 1) c.y++;
c.x = (int) GameMath.gate(left+2, c.x, right-2);
c.y = (int)GameMath.gate(top+2, c.y, bottom-2);
return c;
}
示例8: getDoorCenter
import com.watabou.utils.GameMath; //导入依赖的package包/类
protected final Point getDoorCenter(){
PointF doorCenter = new PointF(0, 0);
for (Door door : connected.values()) {
doorCenter.x += door.x;
doorCenter.y += door.y;
}
Point c = new Point((int)doorCenter.x / connected.size(), (int)doorCenter.y / connected.size());
if (Random.Float() < doorCenter.x % 1) c.x++;
if (Random.Float() < doorCenter.y % 1) c.y++;
c.x = (int)GameMath.gate(left+1, c.x, right-1);
c.y = (int)GameMath.gate(top+1, c.y, bottom-1);
return c;
}
示例9: screenToTile
import com.watabou.utils.GameMath; //导入依赖的package包/类
public int screenToTile(int x, int y, boolean wallAssist ) {
PointF p = camera().screenToCamera( x, y ).
offset( this.point().negate() ).
invScale( SIZE );
//snap to the edges of the tilemap
p.x = GameMath.gate(0, p.x, Dungeon.level.width()-0.001f);
p.y = GameMath.gate(0, p.y, Dungeon.level.height()-0.001f);
int cell = (int)p.x + (int)p.y * Dungeon.level.width();
if (wallAssist
&& map != null
&& DungeonTileSheet.wallStitcheable(map[cell])){
if (cell + mapWidth < size
&& p.y % 1 >= 0.75f
&& !DungeonTileSheet.wallStitcheable(map[cell + mapWidth])){
cell += mapWidth;
}
}
return cell;
}
示例10: screenToTile
import com.watabou.utils.GameMath; //导入依赖的package包/类
public int screenToTile(int x, int y, boolean wallAssist ) {
PointF p = camera().screenToCamera( x, y ).
offset( this.point().negate() ).
invScale( SIZE );
//snap to the edges of the tilemap
p.x = GameMath.gate(0, p.x, Dungeon.level.width()-0.001f);
p.y = GameMath.gate(0, p.y, Dungeon.level.height()-0.001f);
int cell = (int)p.x + (int)p.y * Dungeon.level.width();
if (wallAssist
&& map != null
&& DungeonTileSheet.wallStitcheable(map[cell])){
if (cell + mapWidth < size
&& p.y % 1 >= 0.75f
&& !DungeonTileSheet.wallStitcheable(map[cell + mapWidth])){
cell += mapWidth;
}
}
return cell;
}
示例11: onDrag
import com.watabou.utils.GameMath; //导入依赖的package包/类
@Override
protected void onDrag(Touch t) {
camera.target = null;
if (pinching) {
float curSpan = PointF.distance(touch.current, another.current);
camera.zoom(GameMath.gate(PixelScene.minZoom, startZoom * curSpan
/ startSpan, PixelScene.maxZoom));
} else {
if (!dragging
&& PointF.distance(t.current, t.start) > dragThreshold) {
dragging = true;
lastPos.set(t.current);
} else if (dragging) {
camera.scroll.offset(PointF.diff(lastPos, t.current).invScale(
camera.zoom));
lastPos.set(t.current);
}
}
}
示例12: onDrag
import com.watabou.utils.GameMath; //导入依赖的package包/类
@Override
protected void onDrag( Touch t ) {
camera.target = null;
if (pinching) {
float curSpan = PointF.distance( touch.current, another.current );
camera.zoom( GameMath.gate(
PixelScene.minZoom,
startZoom * curSpan / startSpan,
PixelScene.maxZoom ) );
} else {
if (!dragging && PointF.distance( t.current, t.start ) > dragThreshold) {
dragging = true;
lastPos.set( t.current );
} else if (dragging) {
camera.scroll.offset( PointF.diff( lastPos, t.current ).invScale( camera.zoom ) );
lastPos.set( t.current );
}
}
}
示例13: randomArmor
import com.watabou.utils.GameMath; //导入依赖的package包/类
public static Armor randomArmor(int floorSet) {
floorSet = (int)GameMath.gate(0, floorSet, floorSetTierProbs.length-1);
try {
Armor a = (Armor)Category.ARMOR.classes[Random.chances(floorSetTierProbs[floorSet])].newInstance();
a.random();
return a;
} catch (Exception e) {
UNISTPixelDungeon.reportException(e);
return null;
}
}
示例14: randomWeapon
import com.watabou.utils.GameMath; //导入依赖的package包/类
public static Weapon randomWeapon(int floorSet) {
floorSet = (int)GameMath.gate(0, floorSet, floorSetTierProbs.length-1);
try {
Category c = wepTiers[Random.chances(floorSetTierProbs[floorSet])];
Weapon w = (Weapon)c.classes[Random.chances(c.probs)].newInstance();
w.random();
return w;
} catch (Exception e) {
UNISTPixelDungeon.reportException(e);
return null;
}
}
示例15: onDrag
import com.watabou.utils.GameMath; //导入依赖的package包/类
@Override
protected void onDrag( NoosaInputProcessor.Touch t ) {
camera.target = null;
if (pinching) {
float curSpan = PointF.distance( touch.current, another.current );
camera.zoom( GameMath.gate(
PixelScene.minZoom,
startZoom * curSpan / startSpan,
PixelScene.maxZoom ) );
} else {
if (!dragging && PointF.distance( t.current, t.start ) > dragThreshold) {
dragging = true;
lastPos.set( t.current );
} else if (dragging) {
camera.scroll.offset( PointF.diff( lastPos, t.current ).invScale( camera.zoom ) );
lastPos.set( t.current );
}
}
}