This commit is contained in:
Anuken 2020-06-01 11:12:06 -04:00
parent d984862c69
commit 8273198c56
9 changed files with 130 additions and 33 deletions

View File

@ -14,9 +14,8 @@ uniform float OriginalIntensity;
varying MED vec2 v_texCoords; varying MED vec2 v_texCoords;
void main(){ void main(){
vec4 original = texture2D(u_texture0, v_texCoords) * OriginalIntensity;
vec3 original = texture2D(u_texture0, v_texCoords).rgb; vec4 bloom = texture2D(u_texture1, v_texCoords) * BloomIntensity;
vec3 bloom = texture2D(u_texture1, v_texCoords).rgb * BloomIntensity; original = original * (vec4(1.0) - bloom);
original = OriginalIntensity * (original - original * bloom); gl_FragColor = original + bloom;
gl_FragColor.rgb = original + bloom;
} }

View File

@ -5,6 +5,7 @@ import arc.*;
import arc.assets.*; import arc.assets.*;
import arc.files.*; import arc.files.*;
import arc.graphics.*; import arc.graphics.*;
import arc.graphics.g3d.*;
import arc.scene.ui.layout.*; import arc.scene.ui.layout.*;
import arc.struct.*; import arc.struct.*;
import arc.util.*; import arc.util.*;
@ -164,6 +165,7 @@ public class Vars implements Loadable{
/** list of all locales that can be switched to */ /** list of all locales that can be switched to */
public static Locale[] locales; public static Locale[] locales;
public static Camera3D cam3;
public static FileTree tree = new FileTree(); public static FileTree tree = new FileTree();
public static Net net; public static Net net;
public static ContentLoader content; public static ContentLoader content;
@ -262,6 +264,10 @@ public class Vars implements Loadable{
mods.load(); mods.load();
maps.load(); maps.load();
if(!headless){
cam3 = new Camera3D();
}
} }
public static void loadLogger(){ public static void loadLogger(){

View File

@ -0,0 +1,53 @@
package mindustry.ui;
import arc.scene.ui.layout.*;
import arc.struct.*;
import mindustry.*;
import mindustry.gen.*;
import mindustry.type.*;
import mindustry.world.blocks.storage.CoreBlock.*;
import static mindustry.Vars.*;
public class CoreItemsDisplay extends Table{
private final ObjectSet<Item> usedItems = new ObjectSet<>();
public CoreItemsDisplay(){
rebuild();
}
public void resetUsed(){
usedItems.clear();
}
void rebuild(){
clear();
background(Tex.button);
update(() -> {
CoreEntity core = Vars.player.team().core();
for(Item item : content.items()){
if(core != null && core.items.get(item) > 0 && usedItems.add(item)){
rebuild();
break;
}
}
});
int i = 0;
CoreEntity core = Vars.player.team().core();
for(Item item : content.items()){
if(usedItems.contains(item)){
image(item.icon(Cicon.medium)).padRight(4);
label(() -> core == null ? "0" : ui.formatAmount(core.items.get(item))).padRight(4);
if(++i % 2 == 0){
row();
}
}
}
}
}

View File

@ -44,7 +44,6 @@ public class PlanetDialog extends BaseDialog{
private final Planet solarSystem = Planets.sun; private final Planet solarSystem = Planets.sun;
private final Mesh[] outlines = new Mesh[10]; private final Mesh[] outlines = new Mesh[10];
private final Camera3D cam = new Camera3D();
private final VertexBatch3D batch = new VertexBatch3D(10000, false, true, 0); private final VertexBatch3D batch = new VertexBatch3D(10000, false, true, 0);
private final PlaneBatch3D projector = new PlaneBatch3D(); private final PlaneBatch3D projector = new PlaneBatch3D();
private final Mat3D mat = new Mat3D(); private final Mat3D mat = new Mat3D();
@ -101,7 +100,7 @@ public class PlanetDialog extends BaseDialog{
//buttons.button("Database", Icon.book, style, () -> ui.database.show()).margin(bmargin); //buttons.button("Database", Icon.book, style, () -> ui.database.show()).margin(bmargin);
//buttons.button("Resources", Icon.file, style, resources::show).margin(bmargin); //buttons.button("Resources", Icon.file, style, resources::show).margin(bmargin);
cam.fov = 60f; cam3.fov = 60f;
camRelative.set(0, 0f, camLength); camRelative.set(0, 0f, camLength);
projector.setScaling(1f / 150f); projector.setScaling(1f / 150f);
@ -114,13 +113,13 @@ public class PlanetDialog extends BaseDialog{
//scale X speed depending on polar coordinate //scale X speed depending on polar coordinate
float speed = 1f - Math.abs(upV - 90) / 90f; float speed = 1f - Math.abs(upV - 90) / 90f;
camRelative.rotate(cam.up, cx / xscale * speed); camRelative.rotate(cam3.up, cx / xscale * speed);
//prevent user from scrolling all the way up and glitching it out //prevent user from scrolling all the way up and glitching it out
float amount = cy / yscale; float amount = cy / yscale;
amount = Mathf.clamp(upV + amount, margin, 180f - margin) - upV; amount = Mathf.clamp(upV + amount, margin, 180f - margin) - upV;
camRelative.rotate(Tmp.v31.set(cam.up).rotate(cam.direction, 90), amount); camRelative.rotate(Tmp.v31.set(cam3.up).rotate(cam3.direction, 90), amount);
}); });
scrolled(value -> { scrolled(value -> {
@ -129,7 +128,7 @@ public class PlanetDialog extends BaseDialog{
update(() -> { update(() -> {
if(planet.isLandable()){ if(planet.isLandable()){
hovered = planet.getSector(cam.getMouseRay(), outlineRad); hovered = planet.getSector(cam3.getMouseRay(), outlineRad);
}else{ }else{
hovered = selected = null; hovered = selected = null;
} }
@ -162,6 +161,14 @@ public class PlanetDialog extends BaseDialog{
} }
public void show(Sector selected, int range){ public void show(Sector selected, int range){
this.selected = null;
this.hovered = null;
//update view to sector
camRelative.set(Tmp.v33.set(selected.tile.v).rotate(Vec3.Y, -selected.planet.getRotation()));
zoom = smoothZoom = 1f;
show();
//TODO //TODO
} }
@ -172,6 +179,27 @@ public class PlanetDialog extends BaseDialog{
cont.rect((x, y, w, h) -> render()).grow(); cont.rect((x, y, w, h) -> render()).grow();
} }
FrameBuffer buffer = new FrameBuffer(2, 2, true);
@Override
public void draw(){
boolean doBuffer = color.a < 0.99f;
if(doBuffer){
buffer.resize(Core.graphics.getWidth(), Core.graphics.getHeight());
buffer.begin(Color.clear);
}
super.draw();
if(doBuffer){
buffer.end();
Draw.color(color);
Draw.rect(Draw.wrap(buffer.getTexture()), Core.graphics.getWidth()/2f, Core.graphics.getHeight()/2f, Core.graphics.getWidth(), -Core.graphics.getHeight());
Draw.color();
}
}
private void render(){ private void render(){
Draw.flush(); Draw.flush();
Gl.clear(Gl.depthBufferBit); Gl.clear(Gl.depthBufferBit);
@ -182,23 +210,23 @@ public class PlanetDialog extends BaseDialog{
Gl.cullFace(Gl.back); Gl.cullFace(Gl.back);
//lock to up vector so it doesn't get confusing //lock to up vector so it doesn't get confusing
cam.up.set(Vec3.Y); cam3.up.set(Vec3.Y);
cam.resize(Core.graphics.getWidth(), Core.graphics.getHeight()); cam3.resize(Core.graphics.getWidth(), Core.graphics.getHeight());
camRelative.setLength(planet.radius * camLength + (smoothZoom-1f) * planet.radius * 2); camRelative.setLength(planet.radius * camLength + (smoothZoom-1f) * planet.radius * 2);
cam.position.set(planet.position).add(camRelative); cam3.position.set(planet.position).add(camRelative);
cam.lookAt(planet.position); cam3.lookAt(planet.position);
cam.update(); cam3.update();
//TODO hacky //TODO hacky
Shaders.planet.camDir.set(cam.direction).rotate(Vec3.Y, planet.getRotation()); Shaders.planet.camDir.set(cam3.direction).rotate(Vec3.Y, planet.getRotation());
projector.proj(cam.combined); projector.proj(cam3.combined);
batch.proj(cam.combined); batch.proj(cam3.combined);
beginBloom(); beginBloom();
skybox.render(cam.combined); skybox.render(cam3.combined);
renderPlanet(solarSystem); renderPlanet(solarSystem);
@ -226,14 +254,14 @@ public class PlanetDialog extends BaseDialog{
if(selected != null){ if(selected != null){
addChild(stable); addChild(stable);
Vec3 pos = cam.project(Tmp.v31.set(selected.tile.v).setLength(outlineRad).rotate(Vec3.Y, -planet.getRotation()).add(planet.position)); Vec3 pos = cam3.project(Tmp.v31.set(selected.tile.v).setLength(outlineRad).rotate(Vec3.Y, -planet.getRotation()).add(planet.position));
stable.setPosition(pos.x, pos.y, Align.center); stable.setPosition(pos.x, pos.y, Align.center);
stable.toFront(); stable.toFront();
}else{ }else{
stable.remove(); stable.remove();
} }
cam.update(); cam3.update();
} }
private void beginBloom(){ private void beginBloom(){
@ -246,7 +274,7 @@ public class PlanetDialog extends BaseDialog{
private void renderPlanet(Planet planet){ private void renderPlanet(Planet planet){
//render planet at offsetted position in the world //render planet at offsetted position in the world
planet.mesh.render(cam.combined, planet.getTransform(mat)); planet.mesh.render(cam3.combined, planet.getTransform(mat));
renderOrbit(planet); renderOrbit(planet);
@ -257,7 +285,7 @@ public class PlanetDialog extends BaseDialog{
if(planet.parent != null && planet.hasAtmosphere && Core.settings.getBool("atmosphere")){ if(planet.parent != null && planet.hasAtmosphere && Core.settings.getBool("atmosphere")){
Blending.additive.apply(); Blending.additive.apply();
Shaders.atmosphere.camera = cam; Shaders.atmosphere.camera = cam3;
Shaders.atmosphere.planet = planet; Shaders.atmosphere.planet = planet;
Shaders.atmosphere.bind(); Shaders.atmosphere.bind();
Shaders.atmosphere.apply(); Shaders.atmosphere.apply();
@ -330,11 +358,11 @@ public class PlanetDialog extends BaseDialog{
//render sector grid //render sector grid
Mesh mesh = outline(planet.grid.size); Mesh mesh = outline(planet.grid.size);
Shader shader = Shaders.planetGrid; Shader shader = Shaders.planetGrid;
Vec3 tile = planet.intersect(cam.getMouseRay(), outlineRad); Vec3 tile = planet.intersect(cam3.getMouseRay(), outlineRad);
Shaders.planetGrid.mouse.lerp(tile == null ? Vec3.Zero : tile.sub(planet.position).rotate(Vec3.Y, planet.getRotation()), 0.2f); Shaders.planetGrid.mouse.lerp(tile == null ? Vec3.Zero : tile.sub(planet.position).rotate(Vec3.Y, planet.getRotation()), 0.2f);
shader.bind(); shader.bind();
shader.setUniformMatrix4("u_proj", cam.combined.val); shader.setUniformMatrix4("u_proj", cam3.combined.val);
shader.setUniformMatrix4("u_trans", planet.getTransform(mat).val); shader.setUniformMatrix4("u_trans", planet.getTransform(mat).val);
shader.apply(); shader.apply();
mesh.render(shader, Gl.lines); mesh.render(shader, Gl.lines);
@ -476,7 +504,7 @@ public class PlanetDialog extends BaseDialog{
if(selected != null){ if(selected != null){
//fade out UI when not facing selected sector //fade out UI when not facing selected sector
Tmp.v31.set(selected.tile.v).rotate(Vec3.Y, -planet.getRotation()).scl(-1f).nor(); Tmp.v31.set(selected.tile.v).rotate(Vec3.Y, -planet.getRotation()).scl(-1f).nor();
float dot = cam.direction.dot(Tmp.v31); float dot = cam3.direction.dot(Tmp.v31);
stable.getColor().a = Math.max(dot, 0f)*2f; stable.getColor().a = Math.max(dot, 0f)*2f;
if(dot*2f <= -0.1f){ if(dot*2f <= -0.1f){
stable.remove(); stable.remove();

View File

@ -35,6 +35,8 @@ public class HudFragment extends Fragment{
private Table lastUnlockLayout; private Table lastUnlockLayout;
private boolean shown = true; private boolean shown = true;
private float dsize = 47.2f; private float dsize = 47.2f;
//TODO implement
private CoreItemsDisplay coreItems = new CoreItemsDisplay();
private String hudText = ""; private String hudText = "";
private boolean showHudText; private boolean showHudText;
@ -54,6 +56,10 @@ public class HudFragment extends Fragment{
showToast("Sector[accent] captured[]!"); showToast("Sector[accent] captured[]!");
}); });
Events.on(ResetEvent.class, e -> {
coreItems.resetUsed();
});
//TODO tear this all down //TODO tear this all down
//menu at top left //menu at top left
parent.fill(cont -> { parent.fill(cont -> {

View File

@ -4,7 +4,10 @@ import mindustry.*;
import mindustry.gen.*; import mindustry.gen.*;
import mindustry.world.*; import mindustry.world.*;
import static mindustry.Vars.state;
public class CoreLauncher extends Block{ public class CoreLauncher extends Block{
public int range = 1;
public CoreLauncher(String name){ public CoreLauncher(String name){
super(name); super(name);
@ -23,12 +26,10 @@ public class CoreLauncher extends Block{
@Override @Override
public boolean configTapped(){ public boolean configTapped(){
//TODO show w/ sector if(state.isCampaign()){
Vars.ui.planet.show(); Vars.ui.planet.show(state.rules.sector, range);
}
return false; return false;
} }
} }
} }

View File

@ -21,6 +21,11 @@ public class ResearchBlock extends Block{
configurable = true; configurable = true;
} }
@Override
public boolean outputsItems(){
return false;
}
public class ResearchBlockEntity extends TileEntity{ public class ResearchBlockEntity extends TileEntity{
public @Nullable UnlockableContent researching; public @Nullable UnlockableContent researching;

View File

@ -132,7 +132,6 @@ public class Conveyor extends Block implements Autotiler{
Draw.rect(regions[blendbits][frame], x, y, tilesize * blendsclx, tilesize * blendscly, rotation * 90); Draw.rect(regions[blendbits][frame], x, y, tilesize * blendsclx, tilesize * blendscly, rotation * 90);
//TODO is sprite Z layer clustering necessary? does it create garbage?
Draw.z(Layer.blockOver); Draw.z(Layer.blockOver);
for(int i = 0; i < len; i++){ for(int i = 0; i < len; i++){

View File

@ -1,3 +1,3 @@
org.gradle.daemon=true org.gradle.daemon=true
org.gradle.jvmargs=-Xms256m -Xmx1024m org.gradle.jvmargs=-Xms256m -Xmx1024m
archash=f9cc0eb5711f3e2f640c59d63e3a50da29bca49d archash=713b7e105ae8dde696c1ee8e25b4cc257ca1bf04