[全民写端]#10绘制ToggleModules

简介: 找到renderGameOverlay这个类

首发于Enaium的个人博客


一.添加EventRender2D

public class EventRender2D extends Event {
   
   
    public EventRender2D()  {
   
   
        super(Type.PRE);
    }
}

二.钩子

  1. 搜索GuiIngame这个类打开

    10-1

  2. 找到renderGameOverlay这个类
  3. if (this.mc.playerController.isSpectator()){[...]}else{[...]}后面添加
    GlStateManager.pushMatrix();
    new EventRender2D().call();
    GlStateManager.popMatrix();
    

三. 绘制HUD

  1. 新建HUD类
package cn.enaium.coreium.module.render;

import cn.enaium.coreium.event.EventTarget;
import cn.enaium.coreium.event.events.EventRender2D;
import cn.enaium.coreium.module.Category;
import cn.enaium.coreium.module.Module;
import org.lwjgl.input.Keyboard;

public class HUD extends Module {
   
   
    public HUD() {
   
   
        super("HUD", Keyboard.KEY_P, Category.RENDER);
    }

    @EventTarget
    public void onRender(EventRender2D e) {
   
   

    }
}
  1. 在onRender方法里面写绘制
  2. 添加到loadModsthis.addModule(new HUD());
        //字体
        FontRenderer fr = mc.fontRendererObj;
        //获取屏幕长和高
        ScaledResolution sr = new ScaledResolution(mc);
        ArrayList<Module> modules = new ArrayList();
        for (Module m : Coreium.INSTANCE.moduleManager.getModules()) {
   
   
            //过滤没打开的Module
            if (m.isToggle())
                modules.add(m);
        }
        //根据Module名长度从长到短排序
        modules.sort((o1, o2) -> fr.getStringWidth(o2.getName()) - fr.getStringWidth(o1.getName()));
        //第一个显示的位置
        int index = 0;

        for (Module m : modules) {
   
   
            //获取当前要绘制的字体长度
            int mWidth = fr.getStringWidth(m.getName());
            //绘制字体
            fr.drawStringWithShadow(m.getName(), sr.getScaledWidth() - mWidth - 2, index, new Color(0, 16, 255).getRGB());
            //每绘制一个Module下一个Module的高度增加12
            index += 12;
        }

完成
10-2

目录
相关文章
|
6月前
|
JavaScript 前端开发
揭秘AngularJS ng-if!掌握它,让你的网页元素如魔法般瞬间现身或消失,性能与创意齐飞!
【8月更文挑战第22天】AngularJS的ng-if指令是控制元素显示与隐藏的关键工具。不同于ng-show/ng-hide仅更改CSS显示属性,ng-if依据表达式的真假动态增删DOM元素,优化页面性能与减少DOM操作。当条件为真时,元素加入DOM并显示;反之,则完全移除。此特性对于条件渲染特别有用,尤其在需移除元素及其子元素并考虑内存优化时。相较于ng-show/ng-hide,ng-if在元素不满足条件时不仅隐藏还会销毁相关作用域,虽可能增加重建元素的成本,却有效降低内存占用。进阶使用中,ng-if结合ng-template可轻松实现模板切换。
90 1
|
9月前
|
Perl
【不明觉厉】Angular的 pure pipe (纯管道) 和 impure pipe (非纯管道) 是啥意思?
【不明觉厉】Angular的 pure pipe (纯管道) 和 impure pipe (非纯管道) 是啥意思?
【不明觉厉】Angular的 pure pipe (纯管道) 和 impure pipe (非纯管道) 是啥意思?
|
机器学习/深度学习 测试技术 C++
[C++随笔录] stack && queue模拟实现
[C++随笔录] stack && queue模拟实现
|
Java
[全民写端]#4添加Event和Module
在EntityPlayerSP类里面找到onUpdate方法 在第一行写 new EventUpdate().call();
95 0
|
9月前
|
API 图形学
Unity Hololens2开发|(十)MRTK3空间操作 ObjectManipulator (对象操控器)
Unity Hololens2开发|(十)MRTK3空间操作 ObjectManipulator (对象操控器)
[全民写端]#12绘制ClickGUI
先复制进去FontUtils
140 0
[全民写端]#11绘制主菜单
搜索GuiMainMenu这个类
83 0
|
缓存 JavaScript 前端开发
每日一题:你是怎么理解ES6中Module的?使用场景有哪些?
每日一题:你是怎么理解ES6中Module的?使用场景有哪些?
191 0
|
Perl
Angular最新教程-第十三节 管道Pipes 自定义管道
Angular最新教程-第十三节 管道Pipes 自定义管道
161 0
Angular最新教程-第十三节 管道Pipes 自定义管道
|
JSON 前端开发 JavaScript
Angular最新教程-第十二节 管道Pipes 内置管道
Angular最新教程-第十二节 管道Pipes 内置管道
336 0