微信小程序——自定义导航栏

在一定情况下,我们需要用到自定义的导航,在此记录

取消原生头部

 "navigationStyle": "custom"

在这里插入图片描述

获取胶囊的信息

wx.getMenuButtonBoundingClientRect()

getMeunInfo() {
    let Menuinfo = wx.getMenuButtonBoundingClientRect()
    // @ts-ignore
    console.log("Menuinfo", Menuinfo);

    // 获取设备信息
    wx.getSystemInfo({
      success: res => {
        // @ts-ignore
        console.log(res)
        //自定义导航栏的高度
        let height = res.statusBarHeight + Menuinfo.height + ((Menuinfo.top - res.statusBarHeight) * 2)

        // @ts-ignore
        this.navHeight = height
        // @ts-ignore
        this.statusBarHeight = res.statusBarHeight
        this.setData({
          statusBarHeight: res.statusBarHeight,
          marginTop: Menuinfo.top + (Menuinfo.height / 4)
        })
      }
    })
    /**
     * 通过这些信息我们可以计算出上面说的3个值:

1. 整个导航栏高度 = statausBarHeight + height + (top-statausBarHeight )*2;

2. 胶囊按钮与顶部的距离 = top;

3.胶囊按钮与右侧的距离 = windowWidth - right。
     */
  },
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,我在之前的代码中犯了一个错误。请尝试将`origin`变量的声明移动到`CustomWindow`类的顶部,如下所示: java import java.awt.*; import javax.swing.*; import java.awt.event.*; public class CustomWindow extends JFrame { private JPanel titleBarPanel; private JButton minimizeButton; private JButton maximizeButton; private JButton closeButton; private Point origin; public CustomWindow() { // 设置窗口大小和背景色 this.setSize(1100, 700); this.getContentPane().setBackground(new Color(204, 204, 204)); // 去除窗口边框默认样式 this.setUndecorated(true); // 禁用窗口缩放 this.setResizable(false); // 居中显示窗口 Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize(); int screenWidth = screenSize.width; int screenHeight = screenSize.height; int windowWidth = this.getWidth(); int windowHeight = this.getHeight(); int x = (screenWidth - windowWidth) / 2; int y = (screenHeight - windowHeight) / 2; this.setLocation(x, y); // 鼠标可以移动窗口 titleBarPanel = new JPanel(); titleBarPanel.setBackground(Color.WHITE); titleBarPanel.addMouseListener(new MouseAdapter() { @Override public void mousePressed(MouseEvent e) { origin = new Point(e.getX(), e.getY()); } @Override public void mouseReleased(MouseEvent e) { origin = null; } }); titleBarPanel.addMouseMotionListener(new MouseMotionAdapter() { @Override public void mouseDragged(MouseEvent e) { Point p = getLocation(); setLocation(p.x + e.getX() - origin.x, p.y + e.getY() - origin.y); } }); // 添加最小化、最大化和关闭按钮 minimizeButton = new JButton(new ImageIcon("minimize.png")); maximizeButton = new JButton(new ImageIcon("maximize.png")); closeButton = new JButton(new ImageIcon("close.png")); minimizeButton.setBorderPainted(false); maximizeButton.setBorderPainted(false); closeButton.setBorderPainted(false); minimizeButton.setOpaque(false); maximizeButton.setOpaque(false); closeButton.setOpaque(false); minimizeButton.setContentAreaFilled(false); maximizeButton.setContentAreaFilled(false); closeButton.setContentAreaFilled(false); // 添加按钮功能 minimizeButton.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { setExtendedState(JFrame.ICONIFIED); } }); maximizeButton.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { if (getExtendedState() != JFrame.MAXIMIZED_BOTH) { setExtendedState(JFrame.MAXIMIZED_BOTH); } else { setExtendedState(JFrame.NORMAL); } } }); closeButton.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { System.exit(0); } }); // 高亮按钮 minimizeButton.addMouseListener(new MouseAdapter() { @Override public void mouseEntered(MouseEvent e) { minimizeButton.setIcon(new ImageIcon("minimize_highlight.png")); } @Override public void mouseExited(MouseEvent e) { minimizeButton.setIcon(new ImageIcon("minimize.png")); } }); maximizeButton.addMouseListener(new MouseAdapter() { @Override public void mouseEntered(MouseEvent e) { maximizeButton.setIcon(new ImageIcon("maximize_highlight.png")); } @Override public void mouseExited(MouseEvent e) { maximizeButton.setIcon(new ImageIcon("maximize.png")); } }); closeButton.addMouseListener(new MouseAdapter() { @Override public void mouseEntered(MouseEvent e) { closeButton.setIcon(new ImageIcon("close_highlight.png")); } @Override public void mouseExited(MouseEvent e) { closeButton.setIcon(new ImageIcon("close.png")); } }); // 将按钮添加到标题 titleBarPanel.add(minimizeButton); titleBarPanel.add(maximizeButton); titleBarPanel.add(closeButton); // 将标题添加到窗口 this.add(titleBarPanel, BorderLayout.NORTH); // 设置窗口关闭操作 this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); this.setVisible(true); } public static void main(String[] args) { SwingUtilities.invokeLater(new Runnable() { public void run() { new CustomWindow(); } }); } } ``` 这样,`origin`变量就能在窗口移动的方法中正确地使用了。希望这次能帮到你!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值