- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
预期输出:单击 start_service 按钮后,将向 www.google.com 发送一个请求,根据请求是否成功,应显示带有适当消息的 AlertDialog。
当前输出: 第一次点击 start_service 按钮后,它会显示一个 AlertDialog“NO INTERNET ACCESS”。然而,从第二次点击开始,它会显示一个 AlertDialog“互联网”。
我做错了什么?
服务等级
public class RealService extends Service{
private static final String TAG="RealService";
private boolean isRunning=false;
private IBinder mBinder=new MyBinder();
private boolean intenetAccess=false;
Context context=this;
private RequestQueue reQueue=null;;
private final String url="http://www.google.com";
public boolean SendRequest()
{
reQueue=Volley.newRequestQueue(this);
StringRequest request=new StringRequest(com.android.volley.Request.Method.GET,
url,
new Response.Listener<String>() {
@Override
public void onResponse(
String response) {
intenetAccess=true;
Log.i(TAG,"intenetAccess=true");
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(
VolleyError error) {
intenetAccess=false;
}
});
try{
reQueue.add(request);
}
catch(Exception e){}
return intenetAccess;
}
@Override
public void onCreate() {
super.onCreate();
Log.i(TAG, "Service onCreate");
isRunning=true;
}
@Override
public IBinder onBind(Intent intent) {
Log.i(TAG, "Service onBind");
return mBinder;
}
@Override
public void onRebind(Intent intent) {
Log.i(TAG, "Service onRebind");
super.onRebind(intent);
}
@Override
public boolean onUnbind(Intent intent) {
Log.i(TAG, "Service onUnBind");
return true;
}
@Override
public void onDestroy() {
isRunning=false;
intenetAccess=false;
Log.i(TAG, "Service onDestroy");
super.onDestroy();
}
public class MyBinder extends Binder
{
RealService getService()
{
return RealService.this;
}
}
}
主 Activity 类
public class MainActivity extends AppCompatActivity{
private Button checkbtn;
private Button start_service_btn;
private Button stop_service_btn;
RealService realService=new RealService();
boolean serviceBound=false;
boolean internetPresent=false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
start_service_btn=(Button) findViewById(R.id.start_service_btn);
start_service_btn.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
internetPresent= realService.SendRequest();
if(internetPresent)
{
showAlertDialog(MainActivity.this, "INTERNET ACCESS", "You have internet access");
}
else
{
showAlertDialog(MainActivity.this, "NO INTERNET ACCESS", "You do not have internet access");
}
}
});
stop_service_btn=(Button) findViewById(R.id.stop_service_btn);
stop_service_btn.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
Intent intent=new Intent(MainActivity.this,RealService.class);
stopService(intent);
internetPresent=false;
}
});
public void showAlertDialog(Context context, String title,String message) {
AlertDialog alertDialog=new AlertDialog.Builder(context).create();
alertDialog.setTitle(title);
alertDialog.setMessage(message);
alertDialog.show();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
@Override
protected void onStart() {
super.onStart();
Intent intent=new Intent(this,RealService.class);
startService(intent);
bindService(intent, realServiceConnection, Context.BIND_AUTO_CREATE);
}
@Override
protected void onStop() {
super.onStop();
if(serviceBound)
{
unbindService(realServiceConnection);
serviceBound=false;
}
}
private ServiceConnection realServiceConnection=new ServiceConnection()
{
@Override
public void onServiceDisconnected(ComponentName name) {
serviceBound=false;
}
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
MyBinder myBinder=(MyBinder) service;
realService=myBinder.getService();
serviceBound=true;
}
};
}
最佳答案
您正在返回 bool 值:
return intenetAccess;
在请求完成之前。当您的 onResponse 监听器被调用并将 bool 值更改为 true 时,您已经返回了默认值 false。
那么你能做些什么来解决这个问题呢?一种方法是将监听器传递给 realService.SendRequest,并从您的 onResponse 和 onErrorResponse 触发监听器。
关于安卓服务不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32333770/
我想将 EditText 始终设置为 LTR,我该怎么做?android:textDirection 似乎确实是答案,我无法让项目使用该指令进行编译 最佳答案 为 editText 使用引力 andr
我希望我的应用在每次打开时都显示登录屏幕。使用 android:clearTaskOnLaunch="true" 一切正常。但是有一个错误,只有在手机关机并且应用程序首先使用小部件启动时才会发生。 I
实际上我的要求是我想将动态文件加载到像图像一样的网页中。视频,音频等,它来自 Assets 或应用程序自己的文件目录,这不是问题。 我尝试使用以下两种方式。 方式一 这是我的 html 文件在 ass
我正在触发一个 DatePickerDialog,在 api 22 (Android 5.1) 之前它一直在工作并显示良好,我在上面设置混合和最大日期(最小 = 当前日期,最大 = 从当前日期开始的
我有一个 ListView ,我在其中将标题 View 添加到该列表。一切都很好,但是当滚动列表 headerview 也随着列表移动时,所以我想避免 headerview 滚动,我的意思是当我列表到
虽然我在android上做过一些app,但我还是一头雾水。是否可以使用 SDK 4.0 中的功能,并在 android 2.1 或更低版本上运行该应用程序? 我尝试了你们提到的方法,但出现错误 - F
您好,我正在开发小型 android 应用程序,我想在其中显示带有一些元素的简单 gridview。它工作正常。唯一的问题是即使有空间,它也总是只显示两列。它平均将屏幕分成 2 列并仅显示两个元素。如
我正在使用 Android 2.3.3 API 构建一个应用程序。我需要识别方向的变化并执行一些操作。所以我在 Android Manifest 中添加了以下内容, android:configCha
我正在尝试在“点击”包含特定 MIME 类型的 nfc 标签时开始一项 Activity 。我制作了一个 mime 类型为“text/plain”的标签,并将其添加到 list 中:
我可以将一些数据保存到文件中 val byteArrayOutputStream = ByteArrayOutputStream() byteArrayOutputStream.wri
我正在尝试解析一个包含复杂阿拉伯字母的 XML 文件.. 当我在 android 2.3.7 上测试时,并不是所有的阿拉伯字母都被支持,仍然有一些复杂的显示为方 block .. 但是在 androi
我需要编写一个方法来确定设备是平板电脑还是手机。我不需要根据这个显示不同的用户界面。我只需要有关设备的信息,以便将来我可以将其发送到指标。 在互联网上,我找到了很多方法来确定设备是否是平板电脑。我已经
我正在玩文字转语音,让我的测试应用程序更有趣。它适用于模拟器,但不适用于我的手机,因为我的默认语言环境不是英语。 但是,文本是英文的,所以 tts 当然应该使用英文。据我所知,我可以实现一个自动安装,
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
这个问题在这里已经有了答案: I lost my .keystore file? (12 个回答) 4年前关闭。 当我以前的操作系统损坏并安装新的(7 月 3 日)时,以前的 android_key_
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
在我的 v27\style.xml 中,我有以下代码来设置白色导航栏: @color/colorPrimary @color/colorPrimaryDark @color/
我想通过发送电子邮件 startActivity(Intent.createChooser(new Intent(android.content.Intent.ACTION_SEND))) 我知道要将
我实现了一个自定义 ListView ,它看起来像 Twitter 时间线。 adapter = new MyClickableListAdapter(this, R.layout.timeline,
我有一个显示启动画面的自定义对话框; mSplashDialog = new Dialog(MyActivity.this,R.layout.splash); mSplashDialog.setCon
我是一名优秀的程序员,十分优秀!