【发布时间】:2014-07-13 00:57:45
【问题描述】:
如何将双精度放入文本编辑对象中?我想在屏幕上包含尽可能多的数字而不排除科学计数法和四舍五入。例如:
1000900E13 --> 10009E13
1000090E13 --> 10001E13
1000009E13 --> 1E13
我意识到如果我可以计算出适合文本编辑的字符数,我可以解决这个问题,但是字符宽度是可变的。
编辑:好的,我现在已经实现了逻辑,但是当我点击界面上的等号时出现以下错误:
fatal signal 6 (SIGBART) at 0x000001b0 (code=0)
//This error happens when I call the function, and it not a bug inside the function itself
这是我的计算器的“=”按钮
equal.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
double result;
result = evaluateString.evaluate(string);
string = formatDouble.fmt(result); //omits redundant zeros and decimal point
Typeface tface = disp.getTypeface();
float fsize = disp.getTextSize();
float field_width = disp.getWidth();
//this function is the problem
String show = fillScreen.getLength(fsize, tface, field_width, string);
disp.setText(show);
}
});
这是将双精度填充到文本编辑中的实现。
public class fillScreen {
//find proper length
public static String getLength(float fsize, Typeface tface, float field_width, String string) {
int len = 1;
Paint paint = new Paint();
Rect rect = new Rect();
MainActivity.disp.setText("error");
while (true) {
paint.setTypeface(tface);
paint.setTextSize(fsize);
paint.getTextBounds(string, 0, string.length(), rect);
if (rect.width() > field_width)
break;
len++;
}
len = len - 1;
String numbersigns="0.";
for (int i =0; i<len;i++){
numbersigns=numbersigns+"#";
}
numbersigns=numbersigns+"E0";
NumberFormat formatter = new DecimalFormat(numbersigns);
return (formatter.format(Double.parseDouble(string)));
}
}
将 6 除以 6 并按 uequals 后的堆栈跟踪
07-12 17:12:42.432: I/System.out(6500): string is : 6/6
07-12 17:12:42.436: I/System.out(6500): strings is : 6/6
07-12 17:12:42.436: I/System.out(6500): strings RVP : 66/
07-12 17:12:45.519: D/AudioHardware(154): AudioHardware pcm playback is going to standby.
07-12 17:12:45.519: V/AudioHardware(154): closeMixer_l() mMixerOpenCnt: 1
07-12 17:12:45.519: D/AudioHardware(154): closePcmOut_l() mPcmOpenCnt: 1
07-12 17:12:47.309: D/lights(432): set_light_buttons: color=0xff000000, tlc=0.
07-12 17:13:12.310: I/PowerManagerService(432): Going to sleep due to screen timeout...
07-12 17:13:13.064: D/dalvikvm(432): GC_FOR_ALLOC freed 2400K, 30% free 12448K/17712K, paused 126ms, total 131ms
07-12 17:13:13.067: D/SurfaceFlinger(149): Screen released, type=0 flinger=0x2a007478
07-12 17:13:13.174: I/WindowManager(432): Screenshot Window{4230d070 u0 com.example.test/com.example.test.MainActivity} was all black! mSurfaceLayer=21040 minLayer=21040 maxLayer=21040
07-12 17:13:13.240: D/AccelerometerListener(744): enable(false)
07-12 17:13:13.677: W/ActivityManager(432): Activity pause timeout for ActivityRecord{420b2be8 u0 com.example.test/.MainActivity}
07-12 17:13:18.144: W/ActivityManager(432): Sleep timeout! Sleeping now.
07-12 17:13:18.507: D/dalvikvm(432): GC_FOR_ALLOC freed 1165K, 25% free 13326K/17712K, paused 152ms, total 153ms
07-12 17:13:18.507: I/ActivityManager(432): Start proc com.cyanogenmod.lockclock for broadcast com.cyanogenmod.lockclock/.ClockWidgetProvider: pid=6753 uid=10029 gids={50029, 3003}
07-12 17:13:18.627: I/ActivityManager(432): Start proc com.andrew.apollo for broadcast com.andrew.apollo/.appwidgets.AppWidgetSmall: pid=6767 uid=10000 gids={50000, 1015, 3003, 1028}
07-12 17:13:18.901: I/ActivityManager(432): No longer want net.cactii.flash2 (pid 6395): empty #17
07-12 17:13:18.937: I/ActivityManager(432): Start proc com.google.android.gsf.login for service com.google.android.gsf.login/com.google.android.gsf.loginservice.GoogleLoginService: pid=6781 uid=10052 gids={50052, 3003, 1007, 1028, 1015, 1006, 3002, 3001, 2001, 3006}
07-12 17:13:18.947: V/KeyguardHostView(432): hide transport, gen:3
07-12 17:13:18.947: V/KeyguardHostView(432): music state changed: 0
07-12 17:13:19.117: D/PhoneStatusBar(583): disable: < EXPAND* icons alerts TICKER* system_info back home RECENT* clock search >
07-12 17:13:19.167: V/TAG(432): bug 7643792: fitSystemWindows([0,38][0,0])
07-12 17:13:19.214: D/PhoneStatusBar(583): disable: < EXPAND icons alerts TICKER system_info BACK* HOME* RECENT CLOCK* search >
07-12 17:13:19.377: I/ActivityManager(432): No longer want com.android.defcontainer (pid 6462): empty #17
07-12 17:13:19.674: I/ActivityManager(432): No longer want com.android.keychain (pid 6549): empty #17
07-12 17:13:23.678: W/ActivityManager(432): Activity stop timeout for ActivityRecord{420b2be8 u0 com.example.test/.MainActivity}
【问题讨论】:
-
不使用选框?
-
请提供堆栈跟踪
-
你的while循环也永远不会结束。这个想法是增加“字符串”的大小,直到它不适合为止。您使用的是相同的“字符串”。
-
@OlegGryb,我想知道为什么如果程序到达 while 循环,为什么 MainActivity.disp.setText("error");不工作?
-
因为无限循环阻塞了主 UI 线程。即使在循环之前调用了 setText,文本也不会显示 - 这可能是因为在 setText 尝试更改字段时,UI 线程已经被阻塞。
标签: android