0

Whenever i click on Submit button, i get an error "Unfortunately, Application has stopped working." Please can you help me out.

Code-

    public void onClick(View v) {
            TextView t = (TextView) findViewById(R.id.textView4);   
            if(from == to)
            {
                Toast.makeText(getApplicationContext(), "Invalid", 4000).show();

            }


            else
            {                                       
                  try {
                     s = getJson("URL");                        
                    JSONObject jObj;
                    jObj = new JSONObject(s);
                    String exResult = jObj.getJSONObject("query").getJSONObject("results").getJSONObject("rate").getString("Rate");
                    t.setText(exResult);
                    } catch (JSONException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                    catch (ClientProtocolException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }                                                    
                }   

            }                               
    });
}

LogCat -

03-15 12:06:17.508: E/AndroidRuntime(877): FATAL EXCEPTION: main 03-15 12:06:17.508: E/AndroidRuntime(877): android.os.NetworkOnMainThreadException 03-15 12:06:17.508: E/AndroidRuntime(877): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117) 03-15 12:06:17.508: E/AndroidRuntime(877): at java.net.InetAddress.lookupHostByName(InetAddress.java:385) 03-15 12:06:17.508: E/AndroidRuntime(877): at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236) 03-15 12:06:17.508: E/AndroidRuntime(877): at java.net.InetAddress.getAllByName(InetAddress.java:214) 03-15 12:06:17.508: E/AndroidRuntime(877): at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137) 03-15 12:06:17.508: E/AndroidRuntime(877): at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 03-15 12:06:17.508: E/AndroidRuntime(877): at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 03-15 12:06:17.508: E/AndroidRuntime(877): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360) 03-15 12:06:17.508: E/AndroidRuntime(877): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 03-15 12:06:17.508: E/AndroidRuntime(877): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 03-15 12:06:17.508: E/AndroidRuntime(877): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 03-15 12:06:17.508: E/AndroidRuntime(877): at myandroid.myfirstmodule.sconverter.getJson(sconverter.java:163) 03-15 12:06:17.508: E/AndroidRuntime(877): at myandroid.myfirstmodule.sconverter$1.onClick(sconverter.java:96) 03-15 12:06:17.508: E/AndroidRuntime(877): at android.view.View.performClick(View.java:4084) 03-15 12:06:17.508: E/AndroidRuntime(877): at android.view.View$PerformClick.run(View.java:16966) 03-15 12:06:17.508: E/AndroidRuntime(877): at android.os.Handler.handleCallback(Handler.java:615) 03-15 12:06:17.508: E/AndroidRuntime(877): at android.os.Handler.dispatchMessage(Handler.java:92) 03-15 12:06:17.508: E/AndroidRuntime(877): at android.os.Looper.loop(Looper.java:137) 03-15 12:06:17.508: E/AndroidRuntime(877): at android.app.ActivityThread.main(ActivityThread.java:4745) 03-15 12:06:17.508: E/AndroidRuntime(877): at java.lang.reflect.Method.invokeNative(Native Method) 03-15 12:06:17.508: E/AndroidRuntime(877): at java.lang.reflect.Method.invoke(Method.java:511) 03-15 12:06:17.508: E/AndroidRuntime(877): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 03-15 12:06:17.508: E/AndroidRuntime(877): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 03-15 12:06:17.508: E/AndroidRuntime(877): at dalvik.system.NativeStart.main(Native Method)

4

3 回答 3

0

为什么不在这样的布局中实现 onclickevent:

<Button
    android:id="@+id/button2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Click Here"
    android:onClick="btnClicked" />

然后定义方法btnClicked()。我认为这样你就可以通过自定义方法使用这个 onClickListener。您甚至可以对 button1 使用相同的方法,并在其中确定调用了哪个按钮。

于 2013-03-06T09:14:28.650 回答
0

我不确定您在代码中的目标到底是什么。但我不认为将 submitfinal 的 onClick 放在按钮 b 的 onCLick 内是正确的做法。您需要单独处理它们。如果你想在一个 onClickListener 中这样做,你可以这样做:

  int x, y, product; 
  public OnClickListener buttonClickListener = new OnClickListener() {
        @Override
        public void onClick(View v) {
                switch (v.getId()) {

            case <button b id>: 
                //fetch values of x and y
                                    x = Integer.parseInt(yourtextbox1.getText().toString());
                                    y = Integer.parseInt(yourtextbox2.getText().toString());
            break;
            case <button submit final id>: 
                //multiply x and y
                       product = x*y;
                    //display the product
                       yourtextbox3.setText(product);
            break;
            }
     };

 b.setOnClickListener(buttonClickListener);
 submitFinal.setOnClickListener(buttonClickListener);

编辑:

在您当前的代码中,移动以下行:

 t = (TextView) findViewById(R.id.textView4);    
 displayfinal = (TextView) findViewById(R.id.textView3);

在您的 onclick 侦听器之外。

希望有帮助。

于 2013-03-06T09:23:45.423 回答
0

您可能会尝试将第二个按钮的侦听器从 else 块中移出。我认为将侦听器放在另一个侦听器中不是一个好习惯

于 2013-03-06T10:06:58.413 回答