⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 std2of5modulefactory.java

📁 这是个国外JAVA爱好者写的条形码生成器
💻 JAVA
字号:
/***********************************************************************************************************************
 * Copyright (c) 2004, International Barcode Consortium
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without modification,
 * are permitted provided that the following conditions are met:
 *
 * Redistributions of source code must retain the above copyright notice, this list of
 * conditions and the following disclaimer.
 * Redistributions in binary form must reproduce the above copyright notice, this list of
 * conditions and the following disclaimer in the documentation and/or other materials
 * provided with the distribution.
 * Neither the name of the International Barcode Consortium nor the names of any contributors may be used to endorse
 * or promote products derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 ***********************************************************************************************************************/

package net.sourceforge.barbecue.linear.twoOfFive;

import net.sourceforge.barbecue.Module;

import java.util.Map;
import java.util.HashMap;

/**
 * Standard 2 of 5 barcode module definitions.
 *
 * @author <a href="mailto:james@metalskin.com">James Jenner</a>
 */
class Std2of5ModuleFactory {
    protected static final Map SET = new HashMap();
    
    public static final Module START_CHAR = new Module(new int[] {3, 1, 3, 1, 1, 1});
    public static final Module END_CHAR = new Module(new int[] {3, 1, 1, 1, 3, 1});
    
    private final static int CHECKSUM_WEIGHT_EVEN = 1;
    private final static int CHECKSUM_WEIGHT_ODD = 3;
    
    static {
        init();
    }
    
    /**
     * No public access.
     */
    protected Std2of5ModuleFactory() {
    }
    
    /**
     * Initialise the module definitions.
     */
    private static void init() {
        SET.put("0", new int[] {1, 1, 3, 3, 1});
        SET.put("1", new int[] {3, 1, 1, 1, 3});
        SET.put("2", new int[] {1, 3, 1, 1, 3});
        SET.put("3", new int[] {3, 3, 1, 1, 1});
        SET.put("4", new int[] {1, 1, 3, 1, 3});
        SET.put("5", new int[] {3, 1, 3, 1, 1});
        SET.put("6", new int[] {1, 3, 3, 1, 1});
        SET.put("7", new int[] {1, 1, 1, 3, 3});
        SET.put("8", new int[] {3, 1, 1, 3, 1});
        SET.put("9", new int[] {1, 3, 1, 3, 1});
    }
    
    /**
     * Returns the module that represents the specified character.
     * @param key The data character to get the encoding module for
     * @return The module that encodes the given char
     */
    public static Module getModule(String key) {
        /*
        Module module = null;
        module = (Module) SET.get(key);
        module.setSymbol(key);
        return module;
         */
        Module module = null;
        int[] bar = null;
        bar = (int[])SET.get(key);
        
        // this should always be true, but best to check just in case...
        if(bar != null && bar.length == 5) {
            
            // create the new module based on the selected bar val with the space as 1
            module = new Module(new int[] {
                bar[0], 1,
                bar[1], 1,
                bar[2], 1,
                bar[3], 1,
                bar[4], 1
            });

            module.setSymbol(key);
        }
        
        return module;
        
    }
    
    /**
     * Indicates whether the given character is valid for this barcode or not.
     * This basically just checks to see whether the key is in the list of
     * encoded characters.
     * @param key The key to check for validity
     * @return True if the key is valid, false otherwise
     */
    public static boolean isValid(String key) {
        return SET.containsKey(key);
    }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -