Pregunta

Estoy trabajando con NumberField y NumberFormat. ¿Cómo puedo cambiar NumberConstants.decimalSeparator valor de () sin cambiar mi local? Por ejemplo, yo quiero tener "" o "" como separadores decimales para todas las configuraciones regionales. ¿Es posible crear archivos personalizados NumberConstants_bla.properties propiedad y forzar GXT usarlo en lugar de NumberConstants_ru_RU.properties o NumberConstants_en_US.properties estándar (dependiendo de la localización actual)? ¿Dónde debo colocar este archivo?

¿Fue útil?

Solución

En Java se puede establecer el separador decimal usando DecimalFormatSymbols .

// default symbols for the locale
DecimalFormatSymbols decimalFormatSymbols = DecimalFormatSymbols.getInstance();
// set your required separator
decimalFormatSymbols.setDecimalSeparator(',');
// create a decimal format and set your symbols
DecimalFormat format = new DecimalFormat();
format.setDecimalFormatSymbols(decimalFormatSymbols);

Otros consejos

Usted puede crear sus propios NumberConstants (en el cual pone el separador decimal que desee) y luego utilizarlo para crear su propio NumberFormat.

Ejemplo de mis propios NumberConstants:

import com.google.gwt.i18n.client.constants.NumberConstants;

public class MyNumberConstants implements NumberConstants {
  @Override
  public String notANumber() {
    return "NaN";
  }

  @Override
  public String currencyPattern() {
    return "#,##0.00\\u00A0\\u00A4";
  }

  @Override
  public String decimalPattern() {
    return "#,##0.###";
  }

  @Override
  public String decimalSeparator() {
    return ".";
  }

  @Override
  public String defCurrencyCode() {
    return "EUR";
  }

  @Override
  public String exponentialSymbol() {
    return "e";
  }

  @Override
  public String globalCurrencyPattern() {
    return "#,##0.00\\u00A0\\u00A4";
  }

  @Override
  public String groupingSeparator() {
    return "\\u00A0";
  }

  @Override
  public String infinity() {
    return "\u221E";
  }

  @Override
  public String minusSign() {
    return "-";
  }

  @Override
  public String monetaryGroupingSeparator() {
    return ",";
  }

  @Override
  public String monetarySeparator() {
    return "\\u00A0";
  }

  @Override
  public String percent() {
    return "%";
  }

  @Override
  public String percentPattern() {
    return "#,##0\\u00A0%";
  }

  @Override
  public String perMill() {
    return "\\u2030";
  }

  @Override
  public String plusSign() {
    return "+";
  }

  @Override
  public String scientificPattern() {
    return "#E0";
  }

  @Override
  public String simpleCurrencyPattern() {
    return "#,##0.00\\u00A0\\u00A4";
  }

  @Override
  public String zeroDigit() {
    return "0";
  }
}

Ejemplo de MiFormato:

public class MyFormat extends NumberFormat{

  public MyFormat(){
    super(new MyNumberConstants(),"0.0", CurrencyList.get().getDefault(),true);
  }
}

Advertencia: esta es una solución fea y podría causar problemas para i18n. Yo lo uso sólo para dar formato a una dimensión que supongo que se mostrará de la misma manera para todos.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top