2

배터리 세이버를 사용하여 기기 잠금을 해제하면 새로운 Android 버전에서 인터넷 연결을 올바르게 관리하는 데 문제가 있습니다.활성화 된 배터리 세이버를 사용하여 Android Nougat 또는 Android Oreo에서 인터넷 연결을 관리하십시오.

android.permission.INTERNET android.permission.ACCESS_NETWORK_STATE 권한이 매니페스트 파일에 추가됩니다.

I는 활동이 시작되면 ConnectivityManager.CONNECTIVITY_ACTION을 청취하고 수신되면 브로드 캐스트를 등록하고 중지 될 때 등록을 취소합니다. Wi-FI 또는 셀룰러 연결을 수동으로 해제하거나 \ 사용 가능하게 설정하면 완벽하게 작동합니다.

또한 나는 연결을 확인하는 방법을 사용

private boolean isNetworkAvailable() { 
     ConnectivityManager conn = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); 
     NetworkInfo networkInfo = conn.getActiveNetworkInfo(); 
     return null != networkInfo && networkInfo.isConnected(); 
    } 

때마다 전화 잠금이 해제 내 응용 프로그램이 연결되어있는 전경 isNetworkAvailable() 메소드가 반환에 있지만이 없습니다.

나는 핑 논리 같은 것을 구현하지만 이후 누군가가 안드로이드 7 &에 연결을 처리하는 방법을 안드로이드 (8) 좋은 해결책을 알고 있나요

try { 
     InetAddress inetAddress = InetAddress.getByName("www.google.com"); 
     if (inetAddress.isReachable(1000)) { 
      // IS CONNECTED 
     } 
    } catch (IOException e) { 
     e.printStackTrace(); 
    } 
    // IS NOT CONNECTED 

비활성화 배터리 절약 모드까지 모든 시간을 연결되지 수신 전화의 잠금을 해제하려 ?

감사합니다 사전에

소스 코드 활동 :

public class MainActivity extends AppCompatActivity implements ConnectionManager.ConnectionStatusListener { 

private TextView textView; 

private ConnectionManager cm; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    textView = (TextView) findViewById(R.id.textView); 
    cm = new ConnectionManager(getBaseContext()); 
    //Show by default is disconnected 
    disconnected(); 
} 

@Override 
protected void onStart() { 
    super.onStart(); 
    cm.register(this); 
} 

@Override 
protected void onStop() { 
    super.onStop(); 
    cm.unregister(this); 
} 


// ConnectionManager.ConnectionStatusListener implementation 
@Override 
public void connected() { 
    textView.setText("Connected"); 
    textView.setTextColor(Color.GREEN); 
} 

@Override 
public void disconnected() { 
    textView.setText("Disconnected"); 
    textView.setTextColor(Color.RED); 
} 
} 

연결 관리자의 내 구현 :

class ConnectionManager { 
private final Context context; 
private final Object syncObj = new Object(); 
private final LinkedList<ConnectionStatusListener> listeners = new LinkedList<>(); 
private final Handler uiHandler; 
private final Handler ioHandler; 


private final BroadcastReceiver connectivityActionBR = new BroadcastReceiver() { 
    @Override 
    public void onReceive(Context context, Intent intent) { 
     updateConnStatus(); 
    } 
}; 
private final Runnable pingRunnable = new Runnable() { 
    @Override 
    public void run() { 
     try { 
      InetAddress inetAddress = InetAddress.getByName("www.google.com"); 
      if (!inetAddress.isReachable(1000)) { 
       notifyListeners(false); 
       startPingServerDelayed(500); 
      } else { 
       notifyListeners(true); 
      } 
     } catch (IOException e) { 
      e.printStackTrace(); 
     } 
    } 
}; 

public ConnectionManager(Context context) { 
    this.context = context; 

    uiHandler = new Handler(); 

    HandlerThread handlerThread = new HandlerThread("checkInternetConnectionThread"); 
    handlerThread.start(); 
    ioHandler = new Handler(handlerThread.getLooper()); 
    // TODO: 9/18/17 add destroy to stop threadHandler 
} 


public void register(ConnectionStatusListener listener) { 
    synchronized (syncObj) { 
     if (!listeners.contains(listener)) { 
      listeners.add(listener); 
     } 

     registerBR(); 
    } 
} 

public void unregister(ConnectionStatusListener listener) { 
    synchronized (syncObj) { 
     listeners.remove(listener); 
    } 

    unregisterBR(); 
    stopPingServer(); 
} 


private void registerBR() { 
    context.registerReceiver(connectivityActionBR, new IntentFilter(ConnectivityManager.CONNECTIVITY_ACTION)); 
} 

private void unregisterBR() { 
    context.unregisterReceiver(connectivityActionBR); 
} 

private void notifyListeners(final boolean isConnected) { 
    Log.e("---", "isConnected=" + isConnected); 
    uiHandler.post(new Runnable() { 
     @Override 
     public void run() { 
      synchronized (syncObj) { 
       for(ConnectionStatusListener listener : listeners) { 
        if (isConnected) { 
         listener.connected(); 
        } else { 
         listener.disconnected(); 
        } 
       } 
      } 
     } 
    }); 

} 

private void updateConnStatus() { 
    if (!isNetworkAvailable()) { 
     stopPingServer(); 
     notifyListeners(false); 
    } 

    startPingServerNow(); 
} 

private void startPingServerDelayed(long millis) { 
    ioHandler.postDelayed(pingRunnable, millis); 
} 
private void startPingServerNow() { 
    ioHandler.post(pingRunnable); 
} 

private void stopPingServer() { 
    ioHandler.removeCallbacks(pingRunnable); 
} 

private boolean isNetworkAvailable() { 
    ConnectivityManager conn = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); 
    NetworkInfo networkInfo = conn.getActiveNetworkInfo(); 
    return null != networkInfo && networkInfo.isConnectedOrConnecting(); 
} 


public interface ConnectionStatusListener { 
    void connected(); 

    void disconnected(); 
} 
} 

답변

0

가에서 onCreate (에 방송을 등록) 및들의 OnDestroy에서 등록을 취소 (). 네가 가진 것은 일해야한다.

+0

onCreate()에서 BR을 등록 할 때 onReceive() 호출이 한 번만 호출되었으므로 도움이되지 않습니다. – Dimaslviv

+0

제안 사항이 있습니까? – Dimaslviv

+0

동일한 코드가 있습니다. 그리고 내가 말한대로 onCreate에 내 BR을 등록했지만 테스트를 위해 사용하고있는 장치 일 수도 있습니다. 다른 장치에서 시도해 보셨습니까? 당신이 그것을 거기에 놓아야 만하는 이유는 당신이 당신의 활동을 창조하고 그것이 적어도 당신이 그것을 죽이면 항상 존재하기 때문입니다. –