| package li.cil.oc.client.gui |
| |
| import li.cil.oc.client.KeyBindings |
| import li.cil.oc.client.renderer.MonospaceFontRenderer |
| import li.cil.oc.client.renderer.gui.BufferRenderer |
| import li.cil.oc.util.RenderState |
| import li.cil.oc.util.mods.NEI |
| import net.minecraft.client.Minecraft |
| import net.minecraft.client.gui.GuiScreen |
| import org.lwjgl.input.Keyboard |
| import org.lwjgl.opengl.GL11 |
| import scala.collection.mutable |
| import li.cil.oc.api |
| |
| trait TextBuffer extends GuiScreen { |
| protected def buffer: api.component.TextBuffer |
| |
| private val pressedKeys = mutable.Map.empty[Int, Char] |
| |
| protected var currentWidth, currentHeight = -1 |
| |
| private var shouldRecompileDisplayLists = true |
| |
| protected var scale = 0.0 |
| |
| def recompileDisplayLists() { |
| shouldRecompileDisplayLists = true |
| } |
| |
| override def doesGuiPauseGame = false |
| |
| override def initGui() = { |
| super.initGui() |
| MonospaceFontRenderer.init(Minecraft.getMinecraft.renderEngine) |
| BufferRenderer.init(Minecraft.getMinecraft.renderEngine) |
| Keyboard.enableRepeatEvents(true) |
| recompileDisplayLists() |
| } |
| |
| override def onGuiClosed() = { |
| super.onGuiClosed() |
| if (buffer != null) for ((code, char) <- pressedKeys) { |
| buffer.keyUp(char, code, null) |
| } |
| Keyboard.enableRepeatEvents(false) |
| } |
| |
| protected def drawBufferLayer() { |
| if (shouldRecompileDisplayLists) { |
| shouldRecompileDisplayLists = false |
| if (buffer != null) { |
| currentWidth = buffer.getWidth |
| currentHeight = buffer.getHeight |
| } |
| else { |
| currentWidth = 0 |
| currentHeight = 0 |
| } |
| scale = changeSize(currentWidth, currentHeight) |
| } |
| GL11.glPushMatrix() |
| RenderState.disableLighting() |
| drawBuffer() |
| GL11.glPopMatrix() |
| } |
| |
| protected def drawBuffer() |
| |
| override def handleKeyboardInput() { |
| super.handleKeyboardInput() |
| |
| if (NEI.isInputFocused) return |
| |
| val code = Keyboard.getEventKey |
| if (buffer != null && code != Keyboard.KEY_ESCAPE && code != Keyboard.KEY_F11) { |
| if (Keyboard.getEventKeyState) { |
| val char = Keyboard.getEventCharacter |
| if (!pressedKeys.contains(code) || !ignoreRepeat(char, code)) { |
| buffer.keyDown(char, code, null) |
| pressedKeys += code -> char |
| } |
| } |
| else pressedKeys.remove(code) match { |
| case Some(char) => buffer.keyUp(char, code, null) |
| case _ => // Wasn't pressed while viewing the screen. |
| } |
| |
| if (Keyboard.isKeyDown(KeyBindings.clipboardPaste.keyCode) && Keyboard.getEventKeyState) { |
| buffer.clipboard(GuiScreen.getClipboardString, null) |
| } |
| } |
| } |
| |
| override protected def mouseClicked(x: Int, y: Int, button: Int) { |
| super.mouseClicked(x, y, button) |
| if (buffer != null && button == 2) { |
| buffer.clipboard(GuiScreen.getClipboardString, null) |
| } |
| } |
| |
| protected def changeSize(w: Double, h: Double): Double |
| |
| private def ignoreRepeat(char: Char, code: Int) = { |
| code == Keyboard.KEY_LCONTROL || |
| code == Keyboard.KEY_RCONTROL || |
| code == Keyboard.KEY_LMENU || |
| code == Keyboard.KEY_RMENU || |
| code == Keyboard.KEY_LSHIFT || |
| code == Keyboard.KEY_RSHIFT || |
| code == Keyboard.KEY_LMETA || |
| code == Keyboard.KEY_RMETA |
| } |
| } |