首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >减少重复和使用EDT

减少重复和使用EDT
EN

Code Review用户
提问于 2014-02-20 15:10:04
回答 3查看 132关注 0票数 6

我正在从事我迄今所从事的最大的Java程序,并且在我当前的代码实践中感到不确定。我认为我陈述并重复了一些不需要的事情,随着发展的进行,这些事情可能会成为一个令人头痛的问题。具体来说,在我的GridBag约束中。我以前使用过GridBagLayout,在没有声明仅为(1,1)的单元格的宽度和高度的情况下,我就得到了所需的东西,但是在这里我遇到了问题,所以我决定为每个单元定义我能想到的一切,我得到了我想要的,但是现在我可能有了不必要的代码。

我所关注的另一个问题,是有关利用电子数据交换系统的问题。我已经尽了我最大的努力去寻找关于这个主题的课程和视频,但是我仍然觉得我缺乏足够的理解。

FrontierMain.java:

代码语言:javascript
复制
public class FrontierMain  {

    public FrontierMain(){
        JFrame frame = new JFrame();
        frame.setTitle("Frontier Insulation Labor Record Tool");
        frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
        LaborRecordPanel recordPanel = new LaborRecordPanel();
        frame.add(recordPanel.scrollPane);
        frame.pack();
        frame.setLocationRelativeTo ( null );
        frame.setVisible(true);

    }

    public static void main(String[] args) {
        SwingUtilities.invokeLater(new Runnable(){
            public void run(){
                FrontierMain fm = new FrontierMain();   
            }
        });

        System.out.println("Hello, World");
    }

}

LaborRecordPanel.java:

代码语言:javascript
复制
public class LaborRecordPanel implements
Printable, ActionListener {

    private Color shade = new Color(201,201,201); // color for shaded cells

    private JLabel dateSpace[] = new JLabel[7]; 
    private JLabel grandTotalSpace = new JLabel();
    private JLabel locAndDescSpace = new JLabel();
    private JLabel personnelSpace[] = new JLabel[10]; //  empty cells
    private JLabel calendarGridLines[] = new JLabel[300]; //empty labels for gridlines

    private ImageIcon logoIcon = new ImageIcon("Images/fici_logo1.jpg");
    private JLabel logoLabel = new JLabel(logoIcon);

    private JLabel authorizedBy = new JLabel("AUTHORIZED BY:_____________________________________________________________");
    private JLabel toCertify = new JLabel("THIS IS TO CERTIFY THAT THE ABOVE LABOR HAS BEEN PERFORMED.");

    private JLabel laborRecordNO = new JLabel("NO.");
    private JLabel nameOfJob = new JLabel("NAME OF JOB:");
    private JLabel customerPO = new JLabel("CUSTOMER PO #:");
    private JLabel contractNO = new JLabel("CONTRACT NO.");
    private JLabel weekEnding = new JLabel("WEEK ENDING");

    private JLabel personnelList = new JLabel("<html>LIST SUPERVISION &<br> CRAFT LABOR BELOW:</html>");
    private JLabel locAndDescriptionLabel = new JLabel("LOCATION AND DESCRIPTION:");

    private JLabel personnelTitle = new JLabel("TITLE");

    private JLabel[] titleSpace= new JLabel[10];

    private JLabel calendarTitle = new JLabel("NUMBER OF HOURS WORKED @ SITE");
    private JLabel dayHeading = new JLabel("DAY");
    private JLabel dateHeading = new JLabel("DATE");
    private JLabel[] ot2 = new JLabel[10];
    private JLabel[] ot1 = new JLabel[10];
    private JLabel[] st = new JLabel[10];

    private JLabel mon = new JLabel("MON");
    private JLabel tues = new JLabel("TUES");
    private JLabel wed = new JLabel("WED");
    private JLabel thur = new JLabel("THUR");
    private JLabel fri = new JLabel("FRI");
    private JLabel sat = new JLabel("SAT");
    private JLabel sun = new JLabel("SUN");

    private JLabel totalHours = new JLabel("<html>TOTAL<br> HOURS</html>");
    private JLabel ratePerHour = new JLabel("<html>RATE<br> PER<br> HOUR</html>");
    private JLabel totalAmount = new JLabel("<html>TOTAL<br> AMOUNT</html>");
    private JLabel grandTotal = new JLabel("TOTAL");

    JButton printTest = new JButton("PrintTest");

    JPanel rp = new JPanel();
    JPanel outer = new JPanel();
    JPanel buttonPanel = new JPanel();
    JScrollPane scrollPane = new JScrollPane(outer);

    LaborRecordPanel(){

        outer.setLayout(new BoxLayout(outer,BoxLayout.Y_AXIS ));
        outer.add(rp);
        outer.add(buttonPanel);
        printTest.addActionListener(this);
        buttonPanel.add(printTest);
        rp.setBorder(null);
        rp.setPreferredSize(new Dimension(1295,1830 ));
        rp.setMinimumSize(new Dimension(1295,1830 ));
        rp.setMaximumSize(new Dimension(1295,1830 ));

        scrollPane.setPreferredSize(new Dimension(1295,800 ));

        scrollPane.getVerticalScrollBar().setUnitIncrement(50); //increase the scroll speed

        for (int i = 0; i <= 9; i++) titleSpace[i] = new JLabel(); // create mechanic labels

        for (int i = 0; i <= 9; i++) //create labels for work time
        {
            ot2[i] = new JLabel("OT-2");
            ot1[i] = new JLabel("OT-1");
            st[i] = new JLabel("S.T.");
        }
        //create empty labels for gridlines
        for (int i = 0; i <= 9; i++) personnelSpace[i] = new JLabel(); 
        for (int i = 0; i <= 6; i++) dateSpace[i] = new JLabel();
        for (int i = 0; i <= 299; i++) calendarGridLines[i] = new JLabel();

        GridBagLayout gridbag = new GridBagLayout();
        rp.setBackground(Color.WHITE);
        GridBagConstraints gbc = new GridBagConstraints();
        rp.setLayout(gridbag);

        //row 0////////////////////////////////////////////////////////////
        gbc.fill = GridBagConstraints.BOTH;
        gbc.gridx = 10;
        gbc.gridy = 0;
        gbc.weightx = 0;
        gbc.weighty = 1;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        laborRecordNO.setHorizontalAlignment(JLabel.CENTER);
        laborRecordNO.setFont(new Font("Dialog", Font.PLAIN, 18));
        gridbag.setConstraints(laborRecordNO, gbc);
        rp.add(laborRecordNO, gbc);

        //row 1////////////////////////////////////////////////////////////
        gbc.gridx = 0;
        gbc.gridy = 1;
        gbc.gridwidth = 13;
        gridbag.setConstraints(logoLabel, gbc);
        rp.add(logoLabel, gbc);

        //row 2////////////////////////////////////////////////////////////
        gbc.gridx = 0;
        gbc.gridy = 2;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        nameOfJob.setFont(nameOfJob.getFont().deriveFont(18.0f));
        gridbag.setConstraints(nameOfJob, gbc);
        rp.add(nameOfJob, gbc);

        gbc.gridx = 5;
        gbc.gridy = 2;
        gbc.gridheight = 1;
        gbc.gridwidth = 10;
        contractNO.setFont(contractNO.getFont().deriveFont(18.0f));
        gridbag.setConstraints(contractNO, gbc);
        rp.add(contractNO, gbc);

        //row 3////////////////////////////////////////////////////////////
        gbc.gridx = 0;
        gbc.gridy = 3;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        customerPO.setFont(customerPO.getFont().deriveFont(18.0f));
        gridbag.setConstraints(customerPO, gbc);
        rp.add(customerPO, gbc);

        gbc.gridx = 5;
        gbc.gridy = 3;
        gbc.gridheight = 1;
        gbc.gridwidth = 10;
        weekEnding.setFont(weekEnding.getFont().deriveFont(18.0f));
        gridbag.setConstraints(weekEnding, gbc);
        rp.add(weekEnding, gbc);

        //row 4////////////////////////////////////////////////////////////
        gbc.gridx = 0;
        gbc.gridy = 4;
        gbc.gridheight = 3;
        gbc.gridwidth = 1;
        gbc.weightx = .01;
        personnelList.setHorizontalAlignment(JLabel.CENTER);
        personnelList.setBorder(BorderFactory.createLineBorder(Color.BLACK, 1));
        personnelList.setFont(personnelList.getFont().deriveFont(18.0f));
        gridbag.setConstraints(personnelList, gbc);
        rp.add(personnelList, gbc);

        gbc.gridx = 1;
        gbc.gridy = 4;
        gbc.gridheight = 3;
        gbc.gridwidth = 1;
        gbc.weightx = .42;
        personnelTitle.setHorizontalAlignment(JLabel.CENTER);
        personnelTitle.setBorder(BorderFactory.createMatteBorder(1, 0, 1, 0, Color.BLACK));
        personnelTitle.setFont(personnelTitle.getFont().deriveFont(18.0f));
        gridbag.setConstraints(personnelTitle, gbc);
        rp.add(personnelTitle, gbc);

        gbc.gridx = 2;
        gbc.gridy = 4;
        gbc.gridwidth = 8;
        gbc.gridheight = 1;
        gbc.weightx = .5;
        calendarTitle.setHorizontalAlignment(JLabel.CENTER);
        calendarTitle.setBorder(BorderFactory.createMatteBorder(1, 1, 1, 0, Color.BLACK));
        calendarTitle.setFont(calendarTitle.getFont().deriveFont(18.0f));
        gridbag.setConstraints(calendarTitle, gbc);
        rp.add(calendarTitle, gbc);

        gbc.gridx = 10;
        gbc.gridy = 4;
        gbc.gridheight = 3;
        gbc.gridwidth = 1;
        gbc.weightx = .05;
        totalHours.setHorizontalAlignment(JLabel.CENTER);
        totalHours.setBorder(BorderFactory.createMatteBorder(1, 1, 1, 1, Color.BLACK));
        totalHours.setFont(totalHours.getFont().deriveFont(18.0f));
        gridbag.setConstraints(totalHours, gbc);
        rp.add(totalHours, gbc);

        gbc.gridx = 11;
        gbc.gridy = 4;
        gbc.gridheight = 3;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        ratePerHour.setHorizontalAlignment(JLabel.CENTER);
        ratePerHour.setBorder(BorderFactory.createMatteBorder(1, 0, 1, 0, Color.BLACK));
        ratePerHour.setFont(ratePerHour.getFont().deriveFont(18.0f));
        gridbag.setConstraints(ratePerHour, gbc);
        rp.add(ratePerHour, gbc);

        gbc.gridx = 12;
        gbc.gridy = 4;
        gbc.gridheight = 3;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        totalAmount.setHorizontalAlignment(JLabel.CENTER);
        totalAmount.setBorder(BorderFactory.createMatteBorder(1, 1, 1, 1, Color.BLACK));
        totalAmount.setFont(totalAmount.getFont().deriveFont(18.0f));
        gridbag.setConstraints(totalAmount, gbc);
        rp.add(totalAmount, gbc);

        //row 5//////////////////////////////////////////////////////////////////
        gbc.gridx = 2;
        gbc.gridy = 5;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        dayHeading.setHorizontalAlignment(JLabel.CENTER);
        dayHeading.setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
        dayHeading.setFont(dayHeading.getFont().deriveFont(18.0f));
        gridbag.setConstraints(dayHeading, gbc);
        rp.add(dayHeading, gbc);

        gbc.gridx = 3;
        gbc.gridy = 5;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        mon.setHorizontalAlignment(JLabel.CENTER);
        mon.setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.BLACK));
        mon.setFont(mon.getFont().deriveFont(18.0f));
        gridbag.setConstraints(mon, gbc);
        rp.add(mon, gbc);

        gbc.gridx = 4;
        gbc.gridy = 5;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        tues.setHorizontalAlignment(JLabel.CENTER);
        tues.setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
        tues.setFont(tues.getFont().deriveFont(18.0f));
        gridbag.setConstraints(tues, gbc);
        rp.add(tues, gbc);

        gbc.gridx = 5;
        gbc.gridy = 5;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        wed.setHorizontalAlignment(JLabel.CENTER);
        wed.setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.BLACK));
        wed.setFont(wed.getFont().deriveFont(18.0f));
        gridbag.setConstraints(wed, gbc);
        rp.add(wed, gbc);

        gbc.gridx = 6;
        gbc.gridy = 5;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        thur.setHorizontalAlignment(JLabel.CENTER);
        thur.setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
        thur.setFont(thur.getFont().deriveFont(18.0f));
        gridbag.setConstraints(thur, gbc);
        rp.add(thur, gbc);

        gbc.gridx = 7;
        gbc.gridy = 5;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = .09;
        fri.setHorizontalAlignment(JLabel.CENTER);
        fri.setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.BLACK));
        fri.setFont(fri.getFont().deriveFont(18.0f));
        gridbag.setConstraints(fri, gbc);
        rp.add(fri, gbc);

        gbc.gridx = 8;
        gbc.gridy = 5;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        sat.setHorizontalAlignment(JLabel.CENTER);
        sat.setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
        sat.setFont(sat.getFont().deriveFont(18.0f));
        gridbag.setConstraints(sat, gbc);
        rp.add(sat, gbc);

        gbc.gridx = 9;
        gbc.gridy = 5;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = .07;
        sun.setHorizontalAlignment(JLabel.CENTER);
        sun.setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.BLACK));
        sun.setFont(sun.getFont().deriveFont(18.0f));
        gridbag.setConstraints(sun, gbc);
        rp.add(sun, gbc);

        //row 6//////////////////////////////////////////////////////////////
        gbc.gridx = 2;
        gbc.gridy = 6;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        gbc.weightx = 0;
        dateHeading.setHorizontalAlignment(JLabel.CENTER);
        dateHeading.setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
        dateHeading.setFont(dateHeading.getFont().deriveFont(18.0f));
        gridbag.setConstraints(dateHeading, gbc);
        rp.add(dateHeading, gbc);   

        int dateSpaceIndex = 3;
        boolean flip = true;
        for (int k = 0; k <= 6; k++)//create gridlines for day area
        {
            gbc.gridx = dateSpaceIndex;
            gbc.gridy = 6;
            gbc.gridheight = 1;
            gbc.gridwidth = 1;
            if(flip) dateSpace[k].setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.BLACK));
            else dateSpace[k].setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
            gridbag.setConstraints(dateSpace[k], gbc);
            rp.add(dateSpace[k], gbc);
            dateSpaceIndex++;
            flip = !flip;
        }



        //row 13-36 plus 7-12 time worked labels//////////////////////////
        for (int r = 0; r <= 9; r++)
        {
            gbc.gridx = 1;
            gbc.gridy = 7 + (3*r);
            gbc.gridheight = 3;
            gbc.gridwidth = 1;
            titleSpace[r].setHorizontalAlignment(JLabel.CENTER);
            titleSpace[r].setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.BLACK));
            titleSpace[r].setFont(titleSpace[r].getFont().deriveFont(18.0f));
            gridbag.setConstraints(titleSpace[r], gbc);
            rp.add(titleSpace[r], gbc);
        }

        for (int c = 0; c <= 9; c++){
            gbc.gridx = 2;
            gbc.gridy = 7 + (3*c);
            gbc.gridheight = 1;
            gbc.gridwidth = 1;
            ot2[c].setHorizontalAlignment(JLabel.CENTER);
            ot2[c].setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
            ot2[c].setFont(ot2[c].getFont().deriveFont(18.0f));
            gridbag.setConstraints(ot2[c], gbc);
            rp.add(ot2[c], gbc);

            gbc.gridx = 2;
            gbc.gridy = 8 + (3*c);
            gbc.gridheight = 1;
            gbc.gridwidth = 1;
            ot1[c].setHorizontalAlignment(JLabel.CENTER);
            ot1[c].setOpaque(true);
            ot1[c].setBackground(shade);
            ot1[c].setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
            ot1[c].setFont(ot1[c].getFont().deriveFont(18.0f));
            gridbag.setConstraints(ot1[c], gbc);
            rp.add(ot1[c], gbc);

            gbc.gridx = 2;
            gbc.gridy = 9 + (3*c);
            gbc.gridheight = 1;
            gbc.gridwidth = 1;
            st[c].setHorizontalAlignment(JLabel.CENTER);
            st[c].setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
            st[c].setFont(st[c].getFont().deriveFont(18.0f));
            gridbag.setConstraints(st[c], gbc);
            rp.add(st[c], gbc);
        }
        //row 37/////////////////////////////////////////////////////////////////
        gbc.gridx = 0;
        gbc.gridy = 37;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        locAndDescriptionLabel.setFont(locAndDescriptionLabel.getFont().deriveFont(18.0f));
        gridbag.setConstraints(locAndDescriptionLabel, gbc);
        rp.add(locAndDescriptionLabel);

        gbc.gridx = 11;
        gbc.gridy = 37;
        gbc.gridheight = 1;
        gbc.gridwidth = 1;
        grandTotal.setHorizontalAlignment(JLabel.CENTER);
        grandTotal.setOpaque(true);
        grandTotal.setBackground(Color.BLACK);
        grandTotal.setForeground(Color.WHITE);
        grandTotal.setBorder(BorderFactory.createLineBorder(Color.BLACK,1));
        grandTotal.setFont(grandTotal.getFont().deriveFont(18.0f));
        gridbag.setConstraints(grandTotal, gbc);
        rp.add(grandTotal);

        gbc.gridx = 12;
        gbc.gridy = 37;
        gbc.gridwidth = 1;
        gbc.gridheight = 1;
        grandTotalSpace.setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
        gridbag.setConstraints(grandTotalSpace, gbc);
        rp.add(grandTotalSpace);

        //row 38////////////////////////////////////////////////////////////////
        gbc.gridx = 0;
        gbc.gridy = 38;
        gbc.gridwidth = 10;
        gbc.gridheight = 1;
        gbc.ipady = 80;
        locAndDescSpace.setBorder(BorderFactory.createLineBorder(Color.BLACK,1));
        gridbag.setConstraints(locAndDescSpace, gbc);
        rp.add(locAndDescSpace);

        //row 39////////////////////////////////////////////////////////////////
        gbc.ipady = 0; //reset to default
        gbc.gridx = 0;
        gbc.gridy = 39;
        gbc.gridheight = 1;
        gbc.gridwidth = 13;
        toCertify.setFont(toCertify.getFont().deriveFont(18.0f));
        gridbag.setConstraints(toCertify, gbc);
        rp.add(toCertify);

        //row 40///////////////////////////////////////////////////////////////
        gbc.gridx = 0;
        gbc.gridy = 40;
        gbc.gridheight = 1;
        gbc.gridwidth = 13;
        authorizedBy.setFont(authorizedBy.getFont().deriveFont(18.0f));
        gridbag.setConstraints(authorizedBy, gbc);
        rp.add(authorizedBy);


        for (int r = 0; r <= 9; r++)//gridlines for personnel space
        {
            gbc.gridx = 0;
            gbc.gridy = 7 + (3*r);
            gbc.gridheight = 3;
            gbc.gridwidth = 1;
            personnelSpace[r].setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
            gridbag.setConstraints(personnelSpace[r], gbc);
            rp.add(personnelSpace[r]);
        }
        //create calendar grid lines
        int yPointer = 7;
        int xPointer = 3;
        int shadePtr = 8;
        for (int j = 0; j <= 299; j++)
        {
            gbc.gridx = xPointer;
            gbc.gridy = yPointer;
            gbc.gridheight = 1;
            gbc.gridwidth = 1;
            calendarGridLines[j].setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.BLACK));
            if (yPointer == shadePtr){ //if row number = shadePtr then color the cell
                calendarGridLines[j].setOpaque(true);
                calendarGridLines[j].setBackground(shade);
            }
            gridbag.setConstraints(calendarGridLines[j], gbc);
            rp.add(calendarGridLines[j]);
            xPointer++; //go to next cell in row
            j++; //use the next jlabel
            gbc.gridx = xPointer;
            gbc.gridy = yPointer;
            gbc.gridheight = 1;
            gbc.gridwidth = 1;
            calendarGridLines[j].setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));
            if (yPointer == shadePtr){ //if row number = shadePtr then color the cell
                calendarGridLines[j].setOpaque(true);
                calendarGridLines[j].setBackground(shade);
            }
            gridbag.setConstraints(calendarGridLines[j], gbc);
            rp.add(calendarGridLines[j]);

            xPointer++; //go to next cell in row

            if(xPointer == 13) //if end of column then go to next row and reset column pointer to 3 and increment shade pointer by 3
            {
                yPointer++; //go down a row
                xPointer = 3;
                if((j % 3) == 0) {
                    shadePtr = yPointer;
                }
            }
        }

    }
    @Override
    public void actionPerformed(ActionEvent e) {
        PrinterJob printJob = PrinterJob.getPrinterJob();
        printJob.setPrintable(this);
        if (printJob.printDialog()){
            try{
                printJob.print();
            }
            catch(Exception ex){
                throw new RuntimeException(ex);
            }
        }

    }
    @Override
    public int print(Graphics g, PageFormat pf, int index)
            throws PrinterException {
        Graphics2D g2 = (Graphics2D)g;
        if (index >= 1){
            return Printable.NO_SUCH_PAGE;
        }
        else {
            AffineTransform originalTransform = g2.getTransform();

            double scaleX = pf.getImageableWidth() / rp.getWidth();
            double scaleY = pf.getImageableHeight() / rp.getHeight();
            // Maintain aspect ratio
            double scale = Math.min(scaleX, scaleY);
            g2.translate(pf.getImageableX(), pf.getImageableY());
            g2.scale(scale, scale);
            rp.printAll(g2);

            g2.setTransform(originalTransform);
            return Printable.PAGE_EXISTS;
        }
    }

}

编辑:图形用户界面的图像可能有帮助。上半部分和下半部分。

EN

回答 3

Code Review用户

回答已采纳

发布于 2014-02-20 16:59:26

方法提取--这是你做很多事情的关键.

请考虑以下代码:

//row 2//////////////////////////////////////////////////////////// gbc.gridx = 0; gbc.gridy = 2; gbc.gridheight = 1; gbc.gridwidth = 1; nameOfJob.setFont(nameOfJob.getFont().deriveFont(18.0f)); gridbag.setConstraints(nameOfJob, gbc); rp.add(nameOfJob, gbc); gbc.gridx = 5; gbc.gridy = 2; gbc.gridheight = 1; gbc.gridwidth = 10; contractNO.setFont(contractNO.getFont().deriveFont(18.0f)); gridbag.setConstraints(contractNO, gbc); rp.add(contractNO, gbc);

如果你有一个方法:

代码语言:javascript
复制
public static addGridComponent(JComponent container, JComponent component, 
                 GridBagLayout gridbag, GridBagConstraints gbc,
                 int x, int y, int height, int width, float font) {
    gbc.gridx = x;
    gbc.gridy = y;
    gbc.gridheight = height;
    gbc.gridwidth = width;
    component.setFont(component.getFont().deriveFont(18.0f));
    gridbag.setConstraints(component, gbc);
    container.add(component, gbc);
}

那么您的代码将变成:

代码语言:javascript
复制
//row 2////////////////////////////////////////////////////////////
addGridComponent(rp, nameOfJob,  gridbag, gbc, 0, 2, 1, 1,  18.0f);
addGridComponent(rp, contractNO, gridbag, gbc, 5, 2, 1, 10, 18.0f);

//row 3////////////////////////////////////////////////////////////
addGridComponent(rp, customerPO, gridbag, gbc, 0, 3, 1, 1,  18.0f);
addGridComponent(rp, weekEnding, gridbag, gbc, 5, 3, 1, 10, 18.0f)

这并不能解决神奇数字的问题,但Marc已经解决了这个问题。它解决的是大量的代码重复。

票数 4
EN

Code Review用户

发布于 2014-02-20 15:34:14

通过快速查看代码,我可以说您的构造函数太大了。我建议将构造函数重构为较小的函数,只需完成一项任务。对于每个元素的“区域”或“组”,我可能会有不同的方法。

代码中有很多神奇的数字。为什么是5?为什么不是6号?您可以在名称中使用变量,而不是直接使用数字。它将帮助您轻松理解使用5的原因(可能是理想行的大小,等等)。神奇数字的一个很好的例子是下面的代码:

代码语言:javascript
复制
private JLabel[] ot2 = new JLabel[10];
private JLabel[] ot1 = new JLabel[10];
private JLabel[] st = new JLabel[10];

你为什么用10?我猜是栏数之类的。但是,如果你需要把它改为11,会发生什么呢?您需要替换每次出现的10到11,但是10表示一个意思,它是列的数量,所以您可以使用private final int NUMBERS_OF_COLUMNS = 10。任何阅读您的代码的人都可以清楚地看到,您正在为每个列创建一个标签。

代码语言:javascript
复制
if(flip) dateSpace[k].setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.BLACK));
else dateSpace[k].setBorder(BorderFactory.createMatteBorder(0, 1, 1, 1, Color.BLACK));

乍一看,很难看出这里有“如果-其他”。您应该使用{}来帮助您一见钟情地看到有一个if语句。这将提高可读性,并将在很大程度上帮助处理未被怀疑的bug或稍后更改代码。

只使用一种格式设置样式。有时你用的是:

代码语言:javascript
复制
for (...)
{

}

我看到你也使用了这个变体:

代码语言:javascript
复制
for (...) {

}

只选择一个,并将其保存在所有代码中(这是IDE可以自动完成的事情)。

我可以给你最后一个提示,为你的变量找到相关的名字。对于大部分代码来说,您做得很好,但有时您使用的是没有多大帮助的收缩。例如:JPanel rp = new JPanel();,什么是rp?另一个例子:GridBagLayout gridbag = new GridBagLayout();。我们已经知道它是一个网格包,由类的声明。你可以用一些更有意义的东西。主容器或容器是否是周数据或其他数据的容器?只要读一下这个容器的名字,我就会发现知道它的用途更有帮助。

票数 6
EN

Code Review用户

发布于 2014-02-20 23:26:44

  1. 在这里,变量声明是不必要的: public void (){ FrontierMain fm =新FrontierMain();}下面的内容是相同的: public void (){();} (Eclipse还在行中放置了一个黄色感叹号)。
  2. 我认为你使用EDT是正确的。只需确保创建和每次访问(读取或修改) Swing组件都发生在EDT上。Swing调用EDT上的事件处理程序,包括actionPerformed()Printable.print()。如果您不确定是否可以始终检查一个方法是否运行在SwingUtilities.isEventDispatchThread()上。您可以为此创建一个自定义方法: public静态void verifyEventDispatchThread() { if (!SwingUtilities.isEventDispatchThread()) { Thread.dumpStack();}但还有其他已经存在的解决方案:Swing在运行时验证事件分派线程上的代码
票数 1
EN
页面原文内容由Code Review提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://codereview.stackexchange.com/questions/42309

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档