Cambio NumberConstants.decimalSeparator) valor (
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?
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.