本来在网上找了一个JPopupButton【@author SunKing】,但是实际使用的时候,无法满足L&F效果,在JGoodies Looks下无法正常显示。
期间还在网络找了一个JPopupToggleButton【@author Alexander Wenckus】,但是感觉过于简单,也不够满意。
于是只好自己重写一个。
以下为相关代码:
注意: 勿遗落最后的/name/xio/util/swing/toolbar-buttonarrow.png文件。
name.xio.util.swing.JPopupButton
package name.xio.util.swing; import java.awt.BorderLayout; import java.awt.Color; import java.awt.Component; import java.awt.Graphics; import java.awt.Insets; import java.awt.Point; import java.awt.event.ActionEvent; import java.awt.event.MouseAdapter; import java.awt.event.MouseEvent; import javax.swing.AbstractAction; import javax.swing.AbstractButton; import javax.swing.Action; import javax.swing.BorderFactory; import javax.swing.ButtonModel; import javax.swing.Icon; import javax.swing.ImageIcon; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JOptionPane; import javax.swing.JPopupMenu; import javax.swing.JToolBar; import javax.swing.MenuElement; import javax.swing.UIManager; import javax.swing.UnsupportedLookAndFeelException; import javax.swing.WindowConstants; import javax.swing.event.ChangeEvent; import javax.swing.event.ChangeListener; import javax.swing.event.PopupMenuEvent; import javax.swing.event.PopupMenuListener; import name.xio.util.swing.icon.CompositeIcon; import name.xio.util.swing.icon.HTextIcon; import com.by.yb.util.Utilities; import com.jgoodies.looks.LookUtils; import com.jgoodies.looks.plastic.PlasticXPLookAndFeel; import com.jgoodies.looks.plastic.theme.ExperienceBlue; import com.jgoodies.looks.windows.WindowsLookAndFeel; /** * 弹出菜单按钮 * @author xio * */ public class JPopupButton extends JButton { private static final long serialVersionUID = -6783978058195706887L; /** * 弹出菜单 */ private JPopupMenu menu = new JPopupMenu(); /** * 按钮点击事件,与菜单中的第几项绑定 */ private int attachActionOnPopupMenuIndex = -1; /** * 是否显示箭头部分的分割线 */ private boolean showSeparator = false; public final static int NARROW_WIDTH = 11; public JPopupButton(Icon icon, JPopupMenu menu) { this(null, icon, menu); } public JPopupButton(String text, JPopupMenu menu) { this(text, null, menu); } public JPopupButton(String text, Icon icon, JPopupMenu menu) { initView(text, icon, menu); } /** * 初始化菜单按钮的视图 * @param text * @param icon * @param menu */ private void initView(String text, Icon icon, JPopupMenu menu) { //1.按钮绘制 this.setFocusable(false); this.setText(null); HTextIcon hTextIcon = new HTextIcon(this, text, 10); if (icon != null) { CompositeIcon commonButtonIcon = new CompositeIcon(icon, hTextIcon, CompositeIcon.LEFT); CompositeIcon popupButtonIcon = new CompositeIcon(commonButtonIcon, new ImageIcon(JPopupButton.class .getResource("toolbar-buttonarrow.png")), CompositeIcon.LEFT, 2, 0); this.setIcon(popupButtonIcon); } else { CompositeIcon popupButtonIcon = new CompositeIcon(hTextIcon, new ImageIcon(JPopupButton.class .getResource("toolbar-buttonarrow.png")), CompositeIcon.LEFT, 2, 0); this.setIcon(popupButtonIcon); } //this.setMargin(new Insets()); this.menu = menu; //2.事件监听 //Rollover监听 this.addChangeListener(new RolloverChangeListener()); //添加按钮鼠标事件监听 PopupButtonListener popupButtonListener = new PopupButtonListener(); this.addMouseMotionListener(popupButtonListener); this.addMouseListener(popupButtonListener); //添加菜单事件监听 if (menu != null) { menu.addPopupMenuListener(popupButtonListener); } //初始按钮事件绑定 clearAttachActionOnPopupMenu(); } /** * 清空按钮绑定事件 */ public void clearAttachActionOnPopupMenu() { attachActionOnPopupMenu(-1); } /** * 按钮行为绑定为弹出菜单第一项 */ public void attachDefaultActionOnPopupMenu() { attachActionOnPopupMenu(0); } /** * 按钮的行为绑定为弹出菜单 * @param index */ public void attachActionOnPopupMenu(int index) { if (menu == null) { attachActionOnPopupMenuIndex = -1; } else { MenuElement[] menuElements = menu.getSubElements(); if ((index < 0) || (Utilities.isEmpty(menuElements)) || (index >= menuElements.length)) { attachActionOnPopupMenuIndex = -1; } else { attachActionOnPopupMenuIndex = index; } } } /** * @return Returns the menu. */ public JPopupMenu getMenu() { return menu; } private void showMenu() { if (menu == null) { return; } Point locate = locateMenu(); menu.show(this, locate.x, locate.y); } private void showSeparator(boolean b) { showSeparator = b; this.repaint(); } /** * 按钮左部触发 */ public void onClick() { //点击位置为箭头位置 boolean mouseInNarrow = isMouseInNarrow(); if (mouseInNarrow) { onClickNarrow(); } else { if (attachActionOnPopupMenuIndex < 0) { onClickNarrow(); } else { MenuElement[] menuElements = menu.getSubElements(); ((AbstractButton) menuElements[attachActionOnPopupMenuIndex]).doClick(); } } } /** * 按钮箭头部触发 */ private void onClickNarrow() { showMenu(); } /** * 菜单位置 * @return */ protected Point locateMenu() { Point locate = new Point((int) getAlignmentX(), (int) getAlignmentY() + (getHeight() == 0 ? getPreferredSize().height : getHeight())); return locate; } public void paint(Graphics g) { super.paint(g); //绘制分离线 if (showSeparator) { Color oldColor = g.getColor(); Insets insets = this.getInsets(); int width = getWidth(); int height = getHeight(); Icon icon = this.getIcon(); //int x = icon == null ? (width - NARROW_WIDTH) : (mrgin.left - insets.left + icon.getIconWidth() - NARROW_WIDTH); int x = icon == null ? (width - NARROW_WIDTH) : (insets.left + icon.getIconWidth() - NARROW_WIDTH); int y = 0; // Button.light // Button.shadow // Button.darkShadow // Button.highlight //g.setColor(new Color(216, 214, 207)); g.setColor(UIManager.getColor("Button.shadow")); g.drawLine(x, y + 1, x, y + height - 3); //g.setColor(new Color(250, 250, 248)); g.setColor(UIManager.getColor("Button.highlight")); g.drawLine(x + 1, y + 1, x + 1, y + height - 3); g.setColor(oldColor); } } /** * 当前鼠标是否在按钮上 * @return */ public boolean isMouseOver() { return this.getMousePosition() != null; } /** * 鼠标位置是否在箭头部分 * @return */ public boolean isMouseInNarrow() { Point position = this.getMousePosition(); if (position == null) { return false; } else { return isMouseInNarrow(position); } } /** * 鼠标位置是否在箭头部分 * @param position * @return */ public boolean isMouseInNarrow(Point position) { Insets insets = this.getInsets(); Icon icon = this.getIcon(); int width = this.getWidth(); int height = this.getHeight(); //int narrowFromX = icon == null ? (width - NARROW_WIDTH) : (mrgin.left - insets.left + icon.getIconWidth() - NARROW_WIDTH); int narrowFromX = icon == null ? (width - NARROW_WIDTH) : (insets.left + icon.getIconWidth() - NARROW_WIDTH); int narrowFromY = 0; int narrowEndX = width; int narrowEndY = height; int eventX = (int) position.getX(); int eventY = (int) position.getY(); return ((narrowFromX <= eventX) && (eventX <= narrowEndX)) && ((narrowFromY <= eventY) && (eventY <= narrowEndY)); } /** * 按钮Rollover监听 * @author xio * */ class RolloverChangeListener implements ChangeListener { public void stateChanged(ChangeEvent e) { ButtonModel buttonModel = JPopupButton.this.getModel(); showSeparator(buttonModel.isRollover() || buttonModel.isPressed()); } } /** * 按钮和菜单的事件监听 * @author xio * */ class PopupButtonListener extends MouseAdapter implements PopupMenuListener { public void mouseEntered(MouseEvent e) { //防止部分L&F未设置Rollover JPopupButton.this.getModel().setRollover(true); } public void mouseExited(MouseEvent e) { //防止部分L&F未设置Rollover JPopupButton.this.getModel().setRollover(false); showSeparator(false); } public void mouseClicked(MouseEvent e) { JPopupButton.this.onClick(); } public void popupMenuCanceled(PopupMenuEvent e) { } public void popupMenuWillBecomeInvisible(PopupMenuEvent e) { //菜单不可见时,如果鼠标还在按钮上,设置Rollover状态,以便按钮的视图显示为Rollover if (isMouseOver()) { JPopupButton.this.getModel().setRollover(true); } } public void popupMenuWillBecomeVisible(PopupMenuEvent e) { //菜单显示时,修改按钮Rollover状态 JPopupButton.this.getModel().setRollover(false); } } public static void main(String[] args) { try { //不显示ToolBar的边界 UIManager.put("ToolBar.border", BorderFactory.createEmptyBorder()); if (LookUtils.IS_LAF_WINDOWS_XP_ENABLED) { UIManager.setLookAndFeel(new WindowsLookAndFeel()); } else { PlasticXPLookAndFeel.setCurrentTheme(new ExperienceBlue()); UIManager.setLookAndFeel(new PlasticXPLookAndFeel()); } // PlasticXPLookAndFeel.setCurrentTheme(new ExperienceBlue()); // UIManager.setLookAndFeel(new PlasticXPLookAndFeel()); } catch (UnsupportedLookAndFeelException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } JFrame frame = new JFrame("JPopupButton"); frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE); frame.setSize(400, 320); //SwingUtils.locateCenterOnScreen(frame); class DemoAction extends AbstractAction { private static final long serialVersionUID = 5232174589593930544L; public DemoAction(String id) { super.putValue(Action.NAME, "Demo JPopupButton " + id); } public void actionPerformed(ActionEvent e) { JOptionPane.showMessageDialog((Component) e.getSource(), super.getValue(Action.NAME)); } } JPopupMenu popup = new JPopupMenu("PopupMenu"); popup.add(new DemoAction("0")); popup.add(new DemoAction("1")); popup.add(new DemoAction("2")); JPopupButton btt1 = new JPopupButton("中文文字", null, popup); JPopupButton btt2 = new JPopupButton("中文文字", null, popup); btt2.attachDefaultActionOnPopupMenu(); JPopupButton btt3 = new JPopupButton("中文文字", UIManager.getIcon("FileView.computerIcon"), popup); btt3.attachActionOnPopupMenu(2); JToolBar toolbar = new JToolBar(); toolbar.add(btt1); toolbar.add(btt2); toolbar.add(btt3); toolbar.add(new JButton("中文文字", UIManager.getIcon("FileView.computerIcon"))); toolbar.setBorder(BorderFactory.createEmptyBorder(5, 15, 5, 3)); frame.getContentPane().add(toolbar, BorderLayout.NORTH); frame.setVisible(true); } }
name.xio.util.swing.icon.CompositeIcon
package name.xio.util.swing.icon; import java.awt.Component; import java.awt.Graphics; import javax.swing.Icon; import javax.swing.SwingConstants; /** CompositeIcon is an Icon implementation which draws two icons with a specified relative position: LEFT, RIGHT, TOP, BOTTOM specify how icon1 is drawn relative to icon2 CENTER: icon1 is drawn first, icon2 is drawn over it and with horizontal and vertical orientations within the alloted space It's useful with VTextIcon when you want an icon with your text: if icon1 is the graphic icon and icon2 is the VTextIcon, you get a similar effect to a JLabel with a graphic icon and text * @from http://www.macdevcenter.com/pub/a/mac/2002/03/22/vertical_text.html?page=last&x-order=date * @changedBy xio */ public class CompositeIcon implements Icon, SwingConstants { Icon fIcon1, fIcon2; int fPosition, fHorizontalOrientation, fVerticalOrientation; int widthOffset, heightOffset; /** Create a CompositeIcon from the specified Icons, using the default relative position (icon1 above icon2) and orientations (centered horizontally and vertically) */ public CompositeIcon(Icon icon1, Icon icon2) { this(icon1, icon2, TOP); } /** Create a CompositeIcon from the specified Icons, using the specified relative position and default orientations (centered horizontally and vertically) */ public CompositeIcon(Icon icon1, Icon icon2, int position) { this(icon1, icon2, position, CENTER, CENTER, (position == LEFT || position == RIGHT) ? 2 : -7, (position == LEFT || position == RIGHT) ? 0 : 6); } public CompositeIcon(Icon icon1, Icon icon2, int position, int widthOffset, int heightOffset) { this(icon1, icon2, position, CENTER, CENTER, widthOffset, heightOffset); } /** Create a CompositeIcon from the specified Icons, using the specified relative position and orientations */ public CompositeIcon(Icon icon1, Icon icon2, int position, int horizontalOrientation, int verticalOrientation, int widthOffset, int heightOffset) { fIcon1 = icon1; fIcon2 = icon2; fPosition = position; this.widthOffset = widthOffset; this.heightOffset = heightOffset; fHorizontalOrientation = horizontalOrientation; fVerticalOrientation = verticalOrientation; } /** * Draw the icon at the specified location. Icon implementations * may use the Component argument to get properties useful for * painting, e.g. the foreground or background color. */ public void paintIcon(Component c, Graphics g, int x, int y) { int width = getIconWidth(); int height = getIconHeight(); if (fPosition == LEFT || fPosition == RIGHT) { Icon leftIcon, rightIcon; if (fPosition == LEFT) { leftIcon = fIcon1; rightIcon = fIcon2; } else { leftIcon = fIcon2; rightIcon = fIcon1; } // "Left" orientation, because we specify the x position paintIcon(c, g, leftIcon, x, y, width, height, LEFT, fVerticalOrientation); paintIcon(c, g, rightIcon, x + leftIcon.getIconWidth(), y, width, height, LEFT, fVerticalOrientation); } else if (fPosition == TOP || fPosition == BOTTOM) { Icon topIcon, bottomIcon; if (fPosition == TOP) { topIcon = fIcon1; bottomIcon = fIcon2; } else { topIcon = fIcon2; bottomIcon = fIcon1; } // "Top" orientation, because we specify the y position paintIcon(c, g, topIcon, x, y, width, height, fHorizontalOrientation, TOP); paintIcon(c, g, bottomIcon, x, y + topIcon.getIconHeight(), width, height, fHorizontalOrientation, TOP); } else { paintIcon(c, g, fIcon1, x, y, width, height, fHorizontalOrientation, fVerticalOrientation); paintIcon(c, g, fIcon2, x, y, width, height, fHorizontalOrientation, fVerticalOrientation); } } /* Paints one icon in the specified rectangle with the given orientations */ void paintIcon(Component c, Graphics g, Icon icon, int x, int y, int width, int height, int horizontalOrientation, int verticalOrientation) { int xIcon, yIcon; switch (horizontalOrientation) { case LEFT: xIcon = x; break; case RIGHT: xIcon = x + width - icon.getIconWidth(); break; default: xIcon = x + (width - icon.getIconWidth()) / 2; break; } switch (verticalOrientation) { case TOP: yIcon = y; break; case BOTTOM: yIcon = y + height - icon.getIconHeight(); break; default: yIcon = y + (height - icon.getIconHeight()) / 2; break; } icon.paintIcon(c, g, xIcon, yIcon); } /** * Returns the icon's width. * * @return an int specifying the fixed width of the icon. */ public int getIconWidth() { if (fPosition == LEFT || fPosition == RIGHT) return fIcon1.getIconWidth() + fIcon2.getIconWidth() + widthOffset; return Math.max(fIcon1.getIconWidth(), fIcon2.getIconWidth()) + widthOffset; } /** * Returns the icon's height. * * @return an int specifying the fixed height of the icon. */ public int getIconHeight() { if (fPosition == TOP || fPosition == BOTTOM) return fIcon1.getIconHeight() + fIcon2.getIconHeight() + heightOffset; return Math.max(fIcon1.getIconHeight(), fIcon2.getIconHeight()) + heightOffset; } }
name.xio.util.swing.icon.HTextIcon
package name.xio.util.swing.icon; import java.awt.Component; import java.awt.FontMetrics; import java.awt.Graphics; import java.beans.PropertyChangeEvent; import java.beans.PropertyChangeListener; import javax.swing.Icon; /** * 水平文本Icon * @author xio * */ public class HTextIcon implements Icon, PropertyChangeListener { private String text; private int textWidth; private int textHeight; private int fontCharHeight; private Component fontComponent; private int marginLeft; private int marginRight; static final int MARGIN = 4; static final int MIN_TEXT_HEIGHT = 15; static final int MIN_TEXT_WIDTH = 16; public HTextIcon(Component component, String label) { this(component, label, MARGIN, MARGIN); } public HTextIcon(Component component, String label, int marginRight) { this(component, label, MARGIN, marginRight); } /** * 指定一个Component,创建水平文本Icon * @param component * @param label */ public HTextIcon(Component component, String label, int marginLeft, int marginRight) { fontComponent = component; text = label; this.marginLeft = marginLeft; this.marginRight = marginRight; calcDimensions(); fontComponent.addPropertyChangeListener(this); } /** * sets the label to the given string, updating the orientation as needed * and invalidating the layout if the size changes * @see #verifyRotation */ public void setLabel(String label) { text = label; recalcDimensions(); } /** * Checks for changes to the font on the fComponent * so that it can invalidate the layout if the size changes */ public void propertyChange(PropertyChangeEvent e) { String prop = e.getPropertyName(); if ("font".equals(prop)) { recalcDimensions(); } } /** * Calculates the dimensions. If they've changed, * invalidates the component */ void recalcDimensions() { int wOld = getIconWidth(); int hOld = getIconHeight(); calcDimensions(); if (wOld != getIconWidth() || hOld != getIconHeight()) fontComponent.invalidate(); } void calcDimensions() { FontMetrics fontMetrics = fontComponent.getFontMetrics(fontComponent.getFont()); int fontDescent = fontMetrics.getDescent(); fontCharHeight = fontMetrics.getAscent() + fontDescent; textWidth = fontMetrics.stringWidth(text) + marginLeft + marginRight; if (textWidth < MIN_TEXT_WIDTH) { textWidth = MIN_TEXT_WIDTH; } textHeight = fontCharHeight + fontDescent; if (textHeight < MIN_TEXT_HEIGHT) { textHeight = MIN_TEXT_HEIGHT; } // //强制调整尺寸 // fWidth -= 5; // fHeight += 6; } /** * 绘制文本 */ public void paintIcon(Component c, Graphics g, int x, int y) { g.setColor(c.getForeground()); g.setFont(c.getFont()); g.drawString(text, x + marginLeft, y + fontCharHeight - 2); } /** * icon宽度 */ public int getIconWidth() { return textWidth; } /** * icon高度 */ public int getIconHeight() { return textHeight; } }
/name/xio/util/swing/toolbar-buttonarrow.png: http://xio.iteye.com/upload/attachment/44097/f0b31625-ac6e-36a5-a5cd-d86bca96e72d.png
评论
1 楼
mikewang
2009-04-09
做的,不错, 在给你你加个点击记忆功能
思路
1 每次点击菜单的时候保存这个菜单的index,并且出发菜单下表变更事件
2 在JPopupButton中 监听事件, 并调用attachActionOnPopupMenu 绑定点击按钮所执行的菜单
实现:
JPopupMenu 达不到要求, 需要改造一下
JPopupButton 本部分都差不多, 就增加了一个属性监听器, 监听clickedMenuIndex, 并调用attachActionOnPopupMenu, 改变下标
思路
1 每次点击菜单的时候保存这个菜单的index,并且出发菜单下表变更事件
2 在JPopupButton中 监听事件, 并调用attachActionOnPopupMenu 绑定点击按钮所执行的菜单
实现:
JPopupMenu 达不到要求, 需要改造一下
package info.mikewang.part.test; import java.awt.Component; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.ContainerEvent; import java.awt.event.ContainerListener; import java.util.Vector; import javax.swing.AbstractButton; import javax.swing.JPopupMenu; import javax.swing.MenuElement; class JPopupButtonMenu extends JPopupMenu { private static final long serialVersionUID = -8812143869773395718L; private int clickedMenuIndex = -1; public JPopupButtonMenu() { this(null); } public JPopupButtonMenu(String label) { super(label); addContainerListener(new XContainerListener()); } public int getClickedMenuIndex() { return clickedMenuIndex; } public AbstractButton[] getSubClickedElements() { AbstractButton result[]; Vector<AbstractButton> tmpx = new Vector<AbstractButton>(); MenuElement tmp[] = getSubElements(); for (MenuElement menuElement : tmp) { if (menuElement instanceof AbstractButton) { tmpx.add((AbstractButton) menuElement); } } result = new AbstractButton[tmpx.size()]; for (int i = 0; i < tmpx.size(); i++) { result[i] = tmpx.elementAt(i); } return result; } // ---------------------------------- class XContainerListener implements ContainerListener { @Override public void componentAdded(ContainerEvent e) { Component c = e.getChild(); if (c instanceof AbstractButton) { ((AbstractButton) c).addActionListener(new XActionListener()); } } @Override public void componentRemoved(ContainerEvent e) { } } class XActionListener implements ActionListener { @Override public void actionPerformed(ActionEvent e) { AbstractButton ab = (AbstractButton) e.getSource(); AbstractButton abs[] = getSubClickedElements(); for (int i = 0; i < abs.length; i++) { if (ab == abs[i]) { int oldClickedMenuIndex = clickedMenuIndex; clickedMenuIndex = i; firePropertyChange("clickedMenuIndex", oldClickedMenuIndex, i); break; } } } } }
JPopupButton 本部分都差不多, 就增加了一个属性监听器, 监听clickedMenuIndex, 并调用attachActionOnPopupMenu, 改变下标
private void initClickRemember() { menu.addPropertyChangeListener("clickedMenuIndex", new PropertyChangeListener() { @Override public void propertyChange(PropertyChangeEvent evt) { Integer ii = (Integer) evt.getNewValue(); attachActionOnPopupMenu(ii.intValue()); } }); }
相关推荐
2006/01/20 修正了JPopupButton在XP风格下呈两个按钮样子的BUG 对JFontDialog进行了部分修改 2006/03/08 从JDatePicker提出来一个组件JCalendarPanel日期选择面板 并修改了JDatePicker的设计方式 2006/03/23 ...
只能输入0~255数字的IP地址 JListChooser 列表选择对话框 JNumberField 数字输入框,可限制小数位数,数字最大长度,最大最小能输入的数字 JPopupButton 带下拉菜单的工具栏按钮 JStatusBar 模拟Windows的...
2023年全国大学生英语竞赛样题(C类)样题答案及听力原文
出纳考核表
基于多种天气因素的光伏电站太阳能辐射量预测系统——采用人工神经网络与离线优化算法,MATLAB代码:考虑多种天气条件下光伏电站太阳能辐射量预测 关键词:辐射量预测 光伏预测 多种天气因素 参考文档:《Solar Radiation Prediction and Energy Allocation for Energy Harvesting Base Stations》 仿真平台:MATLAB+CPLEX 平台 优势:代码具有一定的深度和创新性,注释清晰,非烂大街的代码,非常精品 主要内容:代码主要做的是如何利用预测光伏电站太阳能辐射量的问题,利用人工神经网络对对其内太阳辐射量进行预测,并对无云天气以及多云天气进行了分别讨论,与线性模型相比该模型具有更好的性能,除此之外,代码还研究了太阳能的分配问题,采用离线优化算法和四种在线启发式算法分别进行分配策略的优化,并利用太阳辐射数据评估了算法的性能。 该代码适合新手学习以及在此基础上进行拓展,代码质量非常高,出图效果极佳 ,核心关键词: 1. 光伏电站太阳能辐射量预测 2. 多种天气因素 3. 人工神经网络 4. 预测模型 5. 线性
数据结构实验实习指导书(c语言)
"lyh不会打代码"生存小有戏改版
站群系统/泛目录站群源码/泛站群cms系统【小说泛目录站群源码】 效果截图和演示https://www.lxsjfx.cn/3181.html 绿茶小说站群2.x-秒收隔天速出权重-小说流量稳定收割机-精品轻量级PHP站群系统站群系统,小说行业专用引流精品站群,绿茶小说站群为独立站群系统(无需依托CMS),独立的整篇小说优化内容库(拒绝句子拼凑),模板自适应PC端和移动端,流量一起做! 1、绿茶小说站群为独立站群系统(无需依托CMS) 2、对域名要求不高,百元域名均可操作 3、独立的首页、列表页、小说阅读页 4、独立的整篇小说优化内容库(拒绝句子拼凑) 5、可自定页面后缀(html、shtml、xml…..) 6、拒绝全站404跳转到内容页 7、还有强大的网站XML地图功能,便于链接提交 8、模板自适应PC端和移动端,流量一起做! 站群系统/泛目录站群源码/泛站群cms系统【小说泛目录站群源码】
IQC检验员(来料检验员)绩效考核表
2024年全球AI应用趋势年度报告
安全生产绩效考核表
04-【标准制度】公司 KPI 绩效考核流程
第14讲:深入理解指针(4)
考虑用户舒适度的冷热电多能互补综合能源系统优化调度模型:结合PMV衡量与碳排放交易机制的MATLAB仿真实现,考虑用户舒适度的冷热电多能互补综合能源系统优化调度 MATLAB代码:考虑用户舒适度的冷热电多能互补综合能源系统优化调度 关键词:用户舒适度 综合能源 PMV 优化调度 参考文档:《冷热电气多能互补的微能源网鲁棒优化调度》基础模型加舒适度部分模型; 仿真平台:MATLAB+yalmip+cplex 主要内容:代码主要做的是考虑用户舒适度的冷热电多能互补综合能源系统优化调度模型,在传统的冷热电联供型综合能源系统的基础上,进一步考虑了热惯性以及用户的舒适度,并用预测平均投票数PMV对用户的舒适度进行衡量,且通过改变PMV的数值,可以对比不同舒适度要求对于综合能源系统调度结果的影响。 同时,代码还补充性的考虑了碳排放交易机制,并设置经济性最优以及碳排放最优两种对比场景,从而丰富算例,效果非常明显。 使用matlab+yalmip+cplex进行代码的 ,考虑用户舒适度; 综合能源系统; PMV; 优化调度; 冷热电多能互补; 碳排放交易机制。,考虑用户舒适度与碳排放交易的冷热电多能
内容概要:本文详细阐述了利用ANSI转义码在Xshell脚本中进行光标的灵活操控方法。介绍了从光标的隐藏、定位(特定行/列)、保存位置、复位、清除以及显示控制的基本命令,重点描述了如何使用以上提到的功能构建实用的UI组件——文本模式下工作的进度条。文中提供的简单实例演示了一个完整的循环逻辑,它能动态刷新视图,在每一次迭代中根据程序实际进展更新屏幕上的表现形式,同时保持界面美观性和易读性。并且提到由于不同的终端可能有不同的兼容情况,脚本的跨环境行为可能存在细微差别。 适合人群:初学者至中级水平的技术爱好者或者软件开发者,尤其是希望深入掌握Linux环境下命令行工具使用者。 使用场景及目标:① 学习并理解Xshell脚本里涉及的ANSI转义码概念和技术点,从而增强对终端界面元素(如菜单、提示符等)的操作技能;② 掌握通过程序手段构造动态变化的CLI应用程序技巧,比如实时跟踪长时间任务的状态; 阅读建议:本文不仅包含了具体命令的学习,更展示了它们是如何组合起来创造复杂视觉反馈机制的案例研究。对于想进一步探索终端开发领域的程序员而言,这无疑提供了很好的入门指引材料。考虑到各种操作系统上支持度的问题,在测试代码之前应当确认自己的工作平台已经正确配置好。
内容概要:该文档详细探讨了针对达梦数据库的各种性能优化技术和处理方法。具体包括回表问题及其解决措施如覆盖索引和FAST POOL机制;变量窥探、统计数据收集优化方法,例如设置统计桶数量和采样子表数目;视图上拉、JOIN优化、EXISTS与NOT EXISTS子查询重写策略;分区裁剪和多KEY哈希等方面的深入探讨,提供了多个具体的优化技巧,旨在帮助用户有效提升SQL执行性能,并解决了多种可能导致性能下降的关键因素。 适合人群:数据库管理员、运维工程师及具有一定经验的数据开发人员等,尤其是负责使用和维护基于达梦数据库系统的技术团队成员。 使用场景及目标:适用于希望通过改善查询速度来提高系统响应时间的专业人士;需要处理大型数据库或复杂查询的任务;或是正在寻找改进现有数据库架构的方法的机构。它还特别针对那些希望确保最优硬件资源利用率的人群。 其他说明:本文档不仅介绍了理论性的背景知识和技术细节,还包括了大量的实际案例演示和参数调整建议,方便读者理解和实践这些优化方法。此外,针对每种优化策略提供了详细的指导,使得即使是对某些高级特性较为陌生的读者也能顺利掌握关键技能。
54 -营销部经理绩效考核表1
外贸部绩效考核表格
选择使用如下方法,增加系统盘自由空间。最简模式:完成2、4②,即可全面清除电脑垃圾、痕迹。 1、将“桌面”、“我的文档”以及系统盘的其它地方保存的个人文件资料,转移到别的盘保存。 2、双击桌面“计算机”,“系统磁盘”右键--属性--常规/工具: