【问题标题】:Values not passed between Intent Service and ClassIntent Service 和 Class 之间未传递的值
【发布时间】:2015-10-23 09:37:56
【问题描述】:

解释: 我在一个用于检查 Internet 连接的新类 (connectionchecker.java) 中创建了这个意图服务。 现在在我的主类(First.java)中,没有收到值,因为 if() 从未执行过。 我的应用不会崩溃,问题是 TextView 卡在“CONNECTION:”而不是“CONNECTION:You are not connected to the internet”上。或“”连接:您没有连接到互联网。”。

代码: First.java

package com.lofty.lofti;

import com.lofty.lofti.util.SystemUiHider;

import android.annotation.TargetApi;
import android.app.Activity;
import android.app.SearchManager;
import android.content.Context;
import android.content.Intent;
import android.inputmethodservice.Keyboard;
import android.inputmethodservice.KeyboardView.OnKeyboardActionListener;
import android.view.KeyEvent;
import android.view.View.OnKeyListener;
import android.inputmethodservice.KeyboardView;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.view.MotionEvent;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import android.content.BroadcastReceiver;

/**
 * An example full-screen activity that shows and hides the system UI (i.e.
 * status bar and navigation/system bar) with user interaction.
 *
 * @see SystemUiHider
 */
public class First extends Activity {
    /**
     * Whether or not the system UI should be auto-hidden after
     * {@link #AUTO_HIDE_DELAY_MILLIS} milliseconds.
     */
    private static final boolean AUTO_HIDE = true;

    /**
     * If {@link #AUTO_HIDE} is set, the number of milliseconds to wait after
     * user interaction before hiding the system UI.
     */
    private static final int AUTO_HIDE_DELAY_MILLIS = 3000;

    /**
     * If set, will toggle the system UI visibility upon interaction. Otherwise,
     * will show the system UI visibility upon interaction.
     */
    private static final boolean TOGGLE_ON_CLICK = true;

    /**
     * The flags to pass to {@link SystemUiHider#getInstance}.
     */
    private static final int HIDER_FLAGS = SystemUiHider.FLAG_HIDE_NAVIGATION;

    /**
     * The instance of the {@link SystemUiHider} for this activity.
     */
    private SystemUiHider mSystemUiHider;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        getActionBar().hide(); // HIDE ACTION BAR.
        setContentView(R.layout.activity_first);




        EditText enter = (EditText) findViewById(R.id.searchbox);
        enter.setOnKeyListener(new OnKeyListener() {
            @Override
            public boolean onKey(View v, int keyCode, KeyEvent event) {
                if (keyCode == KeyEvent.KEYCODE_ENTER) {
                    EditText searchbox = (EditText) findViewById(R.id.searchbox);
                    String search = searchbox.getText().toString();
                    Intent open = new Intent(Intent.ACTION_WEB_SEARCH);
                    open.putExtra(SearchManager.QUERY, search);
                    startActivity(open);
                    return true;
                }
                else
                {
                    return false;
                }
            }
        });
    }

    public class Connection extends BroadcastReceiver
    {
        @Override
        public void onReceive(Context context, Intent intent) {
            Integer connectionn = intent.getIntExtra("connection",0);
            TextView connectiontext = (TextView) findViewById(R.id.connectiontext);

            if(connectionn==1)
            {
                    connectiontext.setText("CONNECTION:You are not connected to the internet.");
            }
            if(connectionn==0)
            {
                    connectiontext.setText("CONNECTION:You are not connected to the internet.");

            }
        }
    }

    public void exit(View view)
     {
         finish();
         System.exit(0);
     }

    public void usernameclick (View view)
    {
        EditText searchbox = (EditText) findViewById(R.id.searchbox);
        String search = searchbox.getText().toString();
        Intent open = new Intent(Intent.ACTION_WEB_SEARCH);
        open.putExtra(SearchManager.QUERY, search);
        startActivity(open);

    }


}

connectionchecker.java

package com.lofty.lofti;

import android.app.IntentService;
import android.content.Context;
import android.content.Intent;
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
import android.widget.EditText;

public class connectionchecker extends IntentService
{
    public static final int connection =0;

    public connectionchecker() {
        super("connectionchecker");

    }

    @Override
    protected void onHandleIntent(Intent intent) {
        ConnectivityManager connectivityManager = (ConnectivityManager)getSystemService(Context.CONNECTIVITY_SERVICE);
        if(connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_MOBILE).getState() == NetworkInfo.State.CONNECTED || connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI).getState() == NetworkInfo.State.CONNECTED|| connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_ETHERNET).getState()== NetworkInfo.State.CONNECTED)

        {

            Intent data = new Intent(this, First.class);
            data.putExtra("connection",1);
            sendBroadcast(data);
        }
        else
        {
            Intent data = new Intent(this, First.class);
            data.putExtra("connection", 0 );
            sendBroadcast(data);
        }
    }
}

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.lofty.lofti" >
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >

        <activity
            android:name=".First"
            android:configChanges="orientation|keyboardHidden|screenSize"
            android:label="@string/app_name"
            android:theme="@style/FullscreenTheme" >

            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <service android:name=".connectionchecker"/>
        <receiver android:name=".First$Connection"/>
    </application>


</manifest>

谢谢你,祝你有美好的一天。

Logcat:

10-23 16:01:25.765    2175-2175/com.lofty.lofti E/Zygote﹕ MountEmulatedStorage()
10-23 16:01:25.765    2175-2175/com.lofty.lofti E/Zygote﹕ v2
10-23 16:01:25.775    2175-2175/com.lofty.lofti I/SELinux﹕ Function: selinux_compare_spd_ram, SPD-policy is existed. and_ver=SEPF_GT-I9505_5.0.1 ver=27
10-23 16:01:25.775    2175-2175/com.lofty.lofti I/SELinux﹕ Function: selinux_compare_spd_ram , priority [2] , priority version is VE=SEPF_GT-I9505_5.0.1-1_0032
10-23 16:01:25.775    2175-2175/com.lofty.lofti E/SELinux﹕ [DEBUG] get_category: variable seinfo: default sensitivity: NULL, cateogry: NULL
10-23 16:01:25.775    2175-2175/com.lofty.lofti I/art﹕ Late-enabling -Xcheck:jni
10-23 16:01:25.955    2175-2175/com.lofty.lofti D/ResourcesManager﹕ creating new AssetManager and set to /data/app/com.lofty.lofti-2/base.apk
10-23 16:01:26.185    2175-2175/com.lofty.lofti D/AndroidRuntime﹕ Shutting down VM
10-23 16:01:26.195    2175-2175/com.lofty.lofti E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: com.lofty.lofti, PID: 2175
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.lofty.lofti/com.lofty.lofti.First}: java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with this activity.
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2693)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2758)
            at android.app.ActivityThread.access$900(ActivityThread.java:177)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1448)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:145)
            at android.app.ActivityThread.main(ActivityThread.java:5942)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1400)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1195)
     Caused by: java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with this activity.
            at android.support.v7.app.AppCompatDelegateImplV7.createSubDecor(AppCompatDelegateImplV7.java:309)
            at android.support.v7.app.AppCompatDelegateImplV7.ensureSubDecor(AppCompatDelegateImplV7.java:278)
            at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:252)
            at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:109)
            at com.lofty.lofti.First.onCreate(First.java:68)
            at android.app.Activity.performCreate(Activity.java:6289)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1119)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2646)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2758)
            at android.app.ActivityThread.access$900(ActivityThread.java:177)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1448)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:145)
            at android.app.ActivityThread.main(ActivityThread.java:5942)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1400)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1195)
10-23 16:06:26.538    2175-2175/? I/Process﹕ Sending signal. PID: 2175 SIG: 9

【问题讨论】:

    标签: java android android-intent service handler


    【解决方案1】:

    我只是按照 Lars http://www.vogella.com/tutorials/AndroidBroadcastReceiver/article.html 的教程更新你的代码

    1. 您必须先注册广播接收器才能接收任何内容。 看看这个问题。 https://stackoverflow.com/a/4806091/2733216

      IntentFilter filter = new IntentFilter(Connection.ACTION_RESP);
      registerReceiver(mConnection, filter);
      
    2. 您的服务未启动(至少在您提供的代码中)

      在您的活动“onCreate”中

      // Start your Service
      Intent msgIntent = new Intent(this, ConnectionChecker.class);
      startService(msgIntent);
      
    3. 您没有实例化您的广播接收器

      // Instanciate your BCR
      mConnection = new Connection();
      
    4. 定义消息:

      public static final String ACTION_RESP = "intent.action.MESSAGE_PROCESSED";
      
    5. 给 Intent 定义消息

      data.setAction(MainActivity.Connection.ACTION_RESP);
      
    6. 使用从服务发送的默认意图构造函数

      Intent data = new Intent();
      

    最后,整个代码:

    1. 活动

      公共类 MainActivity 扩展 AppCompatActivity {

      private Connection mConnection;
      
      @Override
      protected void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.activity_main);
      
      
      
          EditText enter = (EditText) findViewById(R.id.searchbox);
          enter.setOnKeyListener(new View.OnKeyListener() {
              @Override
              public boolean onKey(View v, int keyCode, KeyEvent event) {
                  if (keyCode == KeyEvent.KEYCODE_ENTER) {
                      EditText searchbox = (EditText) findViewById(R.id.searchbox);
                      String search = searchbox.getText().toString();
                      Intent open = new Intent(Intent.ACTION_WEB_SEARCH);
                      open.putExtra(SearchManager.QUERY, search);
                      startActivity(open);
                      return true;
                  } else {
                      return false;
                  }
              }
          });
      
          // Start your Service
          Intent msgIntent = new Intent(this, ConnectionChecker.class);
          startService(msgIntent);
      
          // Instanciate BCR
          mConnection = new Connection();
          // Register BCR
          IntentFilter filter = new IntentFilter(Connection.ACTION_RESP);
          registerReceiver(mConnection, filter);
      
      }
      
      public class Connection extends BroadcastReceiver {
          public static final String ACTION_RESP = "intent.action.MESSAGE_PROCESSED";
      
          @Override
          public void onReceive(Context context, Intent intent) {
              Integer connectionn = intent.getIntExtra("connection", 0);
              TextView connectiontext = (TextView) findViewById(R.id.connectiontext);
      
              if (connectionn == 1)
                  connectiontext.setText("CONNECTION:You are not connected to the internet.");
              else
                  connectiontext.setText("CONNECTION:You are not connected to the internet.");
      
          }
      }
      
      public void exit(View view) {
          finish();
          System.exit(0);
      }
      
      public void usernameclick(View view) {
          EditText searchbox = (EditText) findViewById(R.id.searchbox);
          String search = searchbox.getText().toString();
          Intent open = new Intent(Intent.ACTION_WEB_SEARCH);
          open.putExtra(SearchManager.QUERY, search);
          startActivity(open);
      
      }
      

      }

    2. 服务

      公共类 ConnectionChecker 扩展 IntentService { 公共静态最终 int 连接 =0;

      public ConnectionChecker() {
          super("connectionchecker");
      
      }
      
      @Override
      protected void onHandleIntent(Intent intent) {
          ConnectivityManager connectivityManager = (ConnectivityManager)getSystemService(Context.CONNECTIVITY_SERVICE);
          if(connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_MOBILE).getState() == NetworkInfo.State.CONNECTED || connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI).getState() == NetworkInfo.State.CONNECTED|| connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_ETHERNET).getState()== NetworkInfo.State.CONNECTED)
      
          {
      
              Intent data = new Intent();
              data.setAction(MainActivity.Connection.ACTION_RESP);
              data.putExtra("connection", 1);
              sendBroadcast(data);
      
      
          }
          else
          {
              Intent data = new Intent();
              data.setAction(MainActivity.Connection.ACTION_RESP);
              data.putExtra("connection", 0 );
              sendBroadcast(data);
          }
      }
      

      }

    【讨论】:

    • 我多次阅读该页面,但对我来说还不够清楚:/如果您有我的问题的代码答案,请发布它,我会尽力理解
    • 我检查了您提供给我的代码并将其放入 android studio,编译时没有错误,但应用程序现在在 启动时崩溃。这是logcat:pastebin.com/39RRmYsdFirst.java:pastebin.com/xtgJMKQKconnectionchecker.java:pastebin.com/8RMrTrBK我已经把代码放在那里,因为你不能在这里添加它们,太多的字符
    • 好的,我把它添加到我的第一篇文章中。
    • 这只是一个主题问题,只是从 Activity 扩展而来,而不是从 AppCompActivity 扩展
    • 将此@Override protected void onStop() { unregisterReceiver(mConnection); super.onStop(); }添加到您的活动中
    【解决方案2】:

    没有收到值是因为 if() 从未执行过

    Intent 传递一个动作,而不是像这样使用:

    Intent data = new Intent(this, First.class);
    

    但是,你应该:

    Intent data = new Intent("ACTION_NAME");
    

    并确保您已将该操作注册到清单:

    <receiver android:name=".First$Connection">
        <intent-filter>
            <action android:name="ACTION_NAME" />
        </intent-filter>
    </receiver>
    

    问题是 TextView 卡住了

    connectiontext创建一个实例变量:

    public class First extends Activity {
    
        ...
        private TextView connectiontext;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_first);
            getActionBar().hide(); // HIDE ACTION BAR.
            connectiontext = (TextView) findViewById(R.id.connectiontext);
            ...
        }
    ...
    }
    

    【讨论】:

    • 我应该使用哪个操作? ACTION_RESP ?
    • @JamesJackson,动作名称由您决定。你不需要使用ACTION_RESP。但请记住,您必须提供与我上面描述的相同的名称。
    • 好吧,我照你说的做了,TextView 仍然是 "Connection:" :/ First.java pastebin.com/xjXTsVm4 connectionchecker.java: pastebin.com/S87CFxwG AndroidManifest.xml: pastebin.com/mUUf8FRa Do you want logcat 也是?
    • @JamesJackson,为什么不使用boolean connected = intent.getBooleanExtra("connection", false); 并通过data.putExtra("connection", true); 发送?另外,使用Intent data = new Intent("ACTION_NAME");
    • 好吧,我做了你说的一切,但 textview 仍然没有改变,我在 onCreate 中添加了一个 Intent 来启动现在导致应用程序崩溃的服务。
    猜你喜欢
    • 1970-01-01
    • 2021-09-08
    • 1970-01-01
    • 2013-07-17
    • 2017-01-10
    • 1970-01-01
    • 1970-01-01
    • 2011-03-18
    • 2021-03-19
    相关资源
    最近更新 更多