- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在此 AddRestaurantActivity 上遇到此错误
这是我的 AddRestaurantActivity.java
文件。这是更新数据库并创建一个带有 goggle geo place 纬度和经度的新餐厅的 Activity 代码。在模拟器中,当我按“创建”按钮创建餐厅时,应用程序死掉了(不幸的是,餐厅查找器已停止)。并且在下面发现了logcat中的错误
package admin;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONException;
import org.json.JSONObject;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.ProgressDialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.location.Address;
import android.location.Geocoder;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import com.mad.restaurantfinderrm.R;
import com.mad.restaurantfinderrm.library.DatabaseHandler;
import com.mad.restaurantfinderrm.library.JSONParser;
import com.mad.restaurantfinderrm.library.UserFunctions;
public class AddRestaurantActivity extends Activity {
UserFunctions userFunctions;
// Progress Dialog
private ProgressDialog pDialog;
JSONParser jsonParser = new JSONParser();
EditText inputName;
EditText inputType;
EditText inputBio;
EditText inputAddressLine1;
EditText inputAddressLine2;
EditText inputAddressLine3;
EditText inputContactNum;
EditText inputEmail;
EditText inputMenuUrl;
// url to create new Restaurant
// private static String url_create_restaurant =
// "http://192.168.0.10/~robertmcnamara/RestaurantFinderAPI/createRestaurant.php";
private static String url_create_restaurant = "http://askme- jobs.com/api/createRestaurant.php";
// JSON Node names
private static final String TAG_SUCCESS = "success";
static Double lat;
static Double lng;
// DB
private SQLiteDatabase mDb;
private Cursor mCursor;
String user_id;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_add_restaurant);
userFunctions = new UserFunctions();
// getting user_id
DatabaseHandler mh = new DatabaseHandler(getApplicationContext());
mDb = mh.getWritableDatabase();
mCursor = mDb.query("login", null, null, null, null, null, null);
if (mCursor != null && mCursor.getCount() > 0) {
mCursor.moveToFirst();
user_id = mCursor.getString(mCursor.getColumnIndex("uid"));
}
// Edit Text
inputName = (EditText) findViewById(R.id.inputName);
inputType = (EditText) findViewById(R.id.inputType);
inputBio = (EditText) findViewById(R.id.inputBio);
inputAddressLine1 = (EditText) findViewById(R.id.inputAddress1);
inputAddressLine2 = (EditText) findViewById(R.id.inputAddress2);
inputAddressLine3 = (EditText) findViewById(R.id.inputAddress3);
inputContactNum = (EditText) findViewById(R.id.inputContactNum);
inputEmail = (EditText) findViewById(R.id.inputEmail);
inputMenuUrl = (EditText) findViewById(R.id.inputMenuUrl);
// Create button
Button btnCreateRestaurant = (Button) findViewById(R.id.btnCreateRestaurant);
// button click event
btnCreateRestaurant.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (inputName.getText().toString().trim().contentEquals("")
|| inputType.getText().toString().trim()
.contentEquals("")
|| inputBio.getText().toString().trim()
.contentEquals("")
|| inputAddressLine1.getText().toString().trim()
.contentEquals("")
|| inputAddressLine2.getText().toString().trim()
.contentEquals("")
|| inputContactNum.getText().toString().trim()
.contentEquals("")
|| inputEmail.getText().toString().trim()
.contentEquals("")
|| inputMenuUrl.getText().toString().trim()
.contentEquals("")) {
AlertDialog.Builder alertDialog = new AlertDialog.Builder(
AddRestaurantActivity.this);
// Setting Dialog Title
alertDialog.setTitle("Input validation");
// Setting Dialog Message
alertDialog
.setMessage("Please enter all details again,\nmaking sure they are correct");
// Setting Icon to Dialog
// alertDialog.setIcon(android.R.drawable.delete);
// Setting Positive "Yes" Button
alertDialog.setPositiveButton("OK",
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
dialog.cancel();
}
});
// Showing Alert Message
alertDialog.show();
} else {
// creating new product in background thread
new CreateNewRestaurant().execute();
}
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu, menu);
return true;
}
/*
* Event Handling for Individual menu item selected Identify single menu
* item by it's id
*/
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menu_logout:
// logout user
// TODO check Internet here?
userFunctions.logoutUser(getApplicationContext());
Intent login = new Intent(getApplicationContext(),
LoginActivity.class);
login.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
startActivity(login);
overridePendingTransition(R.anim.fade_in, R.anim.fade_out);
// Closing dashboard screen
finish();
return true;
default:
return super.onOptionsItemSelected(item);
}
}
/**
* Background Async Task to Create new Restaurant
* */
class CreateNewRestaurant extends AsyncTask<String, String, String> {
/**
* Before starting background thread Show Progress Dialog
* */
@Override
protected void onPreExecute() {
super.onPreExecute();
pDialog = new ProgressDialog(AddRestaurantActivity.this);
pDialog.setMessage("Creating Restaurant..");
pDialog.setIndeterminate(false);
pDialog.setCancelable(true);
pDialog.show();
}
/**
* Creating Restaurant
* */
protected String doInBackground(String... args) {
String name = inputName.getText().toString();
String type = inputType.getText().toString();
String bio = inputBio.getText().toString();
String addressLine1 = inputAddressLine1.getText().toString();
String addressLine2 = inputAddressLine2.getText().toString();
String addressLine3 = inputAddressLine3.getText().toString();
String phoneNum = inputContactNum.getText().toString();
String email = inputEmail.getText().toString();
String menuUrl = inputMenuUrl.getText().toString();
// img
// String img = "";
String fullAddress = name + ", " + addressLine1 + ", "
+ addressLine2 + ", " + addressLine3;
Geocoder geoCoder = new Geocoder(getApplicationContext());
List<Address> addressList;
try {
addressList = geoCoder.getFromLocationName(fullAddress, 1);
Address address = addressList.get(0);
if (address.hasLatitude() && address.hasLongitude()) {
lat = address.getLatitude();
lng = address.getLongitude();
}
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
Log.v("LAT", lat.toString());
Log.v("LNG", lng.toString());
// Building Parameters
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("name", name));
params.add(new BasicNameValuePair("type", type));
params.add(new BasicNameValuePair("bio", bio));
params.add(new BasicNameValuePair("addressLine1", addressLine1));
params.add(new BasicNameValuePair("addressLine2", addressLine2));
params.add(new BasicNameValuePair("addressLine3", addressLine3));
params.add(new BasicNameValuePair("contactNumber", phoneNum));
params.add(new BasicNameValuePair("email", email));
params.add(new BasicNameValuePair("lat", lat.toString()));
params.add(new BasicNameValuePair("lng", lng.toString()));
params.add(new BasicNameValuePair("url", menuUrl));
params.add(new BasicNameValuePair("user_id", user_id));
// getting JSON Object
// Note that create product url accepts POST method
JSONObject json = jsonParser.makeHttpRequest(url_create_restaurant,
"POST", params);
// check for success tag
try {
int success = json.getInt(TAG_SUCCESS);
if (success == 1) {
// successfully created product
Intent i = new Intent(getApplicationContext(),
ViewRestaurantActivity.class);
i.putExtra("MESSAGE", "add");
i.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
startActivity(i);
overridePendingTransition(R.anim.slide_in_top,
R.anim.slide_out_bottom);
finish();
} else {
// failed to create product
}
} catch (JSONException e) {
e.printStackTrace();
}
return null;
}
/**
* After completing background task Dismiss the progress dialog
* **/
protected void onPostExecute(String file_url) {
// dismiss the dialog once done
pDialog.dismiss();
}
}
}
logcat 错误:
01-22 07:50:28.381: E/WindowManager(924): Activity com.mad.restaurantfinderrm.TabsViewPagerFragmentActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{41891c88 V.E..... R.....I. 0,0-240,147} that was originally added here
01-22 07:50:28.381: E/WindowManager(924): android.view.WindowLeaked: Activity com.mad.restaurantfinderrm.TabsViewPagerFragmentActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{41891c88 V.E..... R.....I. 0,0-240,147} that was originally added here
01-22 07:50:28.381: E/WindowManager(924): at android.view.ViewRootImpl.<init>(ViewRootImpl.java:345)
01-22 07:50:28.381: E/WindowManager(924): at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:239)
01-22 07:50:28.381: E/WindowManager(924): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69)
01-22 07:50:28.381: E/WindowManager(924): at android.app.Dialog.show(Dialog.java:281)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment.error(Tab2Fragment.java:248)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment.displayDeals(Tab2Fragment.java:324)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment$LoadDeals$1.run(Tab2Fragment.java:209)
01-22 07:50:28.381: E/WindowManager(924): at android.app.Activity.runOnUiThread(Activity.java:4673)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment$LoadDeals.onPostExecute(Tab2Fragment.java:183)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment$LoadDeals.onPostExecute(Tab2Fragment.java:1)
01-22 07:50:28.381: E/WindowManager(924): at android.os.AsyncTask.finish(AsyncTask.java:631)
01-22 07:50:28.381: E/WindowManager(924): at android.os.AsyncTask.access$600(AsyncTask.java:177)
01-22 07:50:28.381: E/WindowManager(924): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
01-22 07:50:28.381: E/WindowManager(924): at android.os.Handler.dispatchMessage(Handler.java:99)
01-22 07:50:28.381: E/WindowManager(924): at android.os.Looper.loop(Looper.java:137)
01-22 07:50:28.381: E/WindowManager(924): at android.app.ActivityThread.main(ActivityThread.java:5103)
01-22 07:50:28.381: E/WindowManager(924): at java.lang.reflect.Method.invokeNative(Native Method)
01-22 07:50:28.381: E/WindowManager(924): at java.lang.reflect.Method.invoke(Method.java:525)
01-22 07:50:28.381: E/WindowManager(924): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
01-22 07:50:28.381: E/WindowManager(924): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
01-22 07:50:28.381: E/WindowManager(924): at dalvik.system.NativeStart.main(Native Method)
最佳答案
您在调用 onPostExecute
之前调用 finish()
。我认为这会泄露你的pDialog
。尝试在关闭 pDialog
onPostExecute
中移动
finish()
关于java - Activity 泄漏了窗口 com.android.internal.policy.impl.PhoneWindow$DecorView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21284047/
我想实现一个转换特性,涵盖支持现有转换的所有类型。我认为这可以通过以下方式完成: impl Into for T where T: Into, { fn into(self) -> B {
看来我不能在 Rust 中调用相同结构的方法,或者我不明白: struct St1 { aa: String } impl St1 { pub fn method1() -> String {
我正在使用 pimpl idiom在我的代码中有很多,主要是为了减少编译时间。 我遇到了调用 C 库的情况。我有一个 C++ 包装器类,它有它的接口(interface),血淋淋的细节都在 impl
我有以下代码: use std::ops::Div; use std::ops::Mul; #[derive(Debug)] struct Foo { bar: T, } impl Foo w
从 Rust 1.34 开始,我们可以通过实现 TryFrom 来编写类型之间的易错转换。特征: struct Foo(i32); struct Bar; impl TryFrom for Foo {
我开始了一个非常小的程序来玩 Rust 中的解析器组合器,很快就遇到了一个我觉得很奇怪的错误: trait Parser { fn parse(&self, input: &'a [u8])
这个问题在这里已经有了答案: NoSuchMethodError: org.slf4j.impl.StaticLoggerBinder.getSingleton() (4 个答案) 关闭 5 年前。
在扩展其他 crate 中定义的 trait 时,似乎有两种方法可以默认实现新的 trait。 特征的原始定义是 pub trait Trait1 { fn f1(&self); } 为了扩展
我通过扩展 AbstractEntryProcessor 创建了用于更新 map 条目的自定义条目处理器。当我的应用程序在两个实例上的集群中运行并且执行入口处理器时,我收到以下异常: com.haze
我的本地环境:OSX 10.9.2,java1.6 我使用 java api 连接 hbase 和 maven 来管理我的项目,我将 Hbase-0.94.17 和 Hadoop-core-1.0
包装一些生成的类,我使用 classImpl 绑定(bind),但生成的类中的集合返回生成的类型而不是 classImpl 中的类型,我当然想要一个 classImpl 列表...... 我的 xsd
我正在编写一个守护程序来获取某些游戏的服务器统计信息。 在编译中我收到一条消息: cannot access org.apache.commons.pool2.impl.GenericObjectPo
我最近将旧应用程序的后台服务迁移到 WorkManager .在最近的设备上(低至 sdk 22 包括 )它看起来不错,运行重复的工作单元并按预期在设备重新启动时安排它们。 问题是当我测试旧版本时(旧
这个问题在这里已经有了答案: Xerces error: org.apache.xerces.impl.dv.dtd.DTDDVFactoryImpl (2 个答案) 关闭 5 年前。 我正在使用
如果我有一个需要Default实现的结构,如果所有字段的类型都有Default实现的themsevles,那么我可以使用derive 宏,否则我需要手动实现 Default。但是,在某些情况下,我有一
我看到 Rust 代码库中经常出现以下模式,但我找不到解释为什么要使用它。 将 impl ... for 用于什么目的? build ? 伪代码: impl Handler { pub fn
我用 Angular js 编写了一些小代码。它有效,但我收到一些错误“无法读取未定义的属性'impl'”。有人知道那是什么吗? 这是我的 html:
我正在尝试创建一个通用实现,用于根据不同的字段类型生成 From/Into。 Link to Playground 我发现了以下问题: error[E0425]: cannot find value
在下面传递一个trait作为参数的例子中,在函数签名中发送impl需要什么? 我知道 traits 是更通用的类型而不是具体类型,但是由于 Rust 编译器不允许跨结构和 traits 共享名称,为什
我有一个带有两个通用 typenum 参数的实现。当参数相同时,impl 的函数应该返回不同的类型。 (不同类型是一种更紧凑的表示,只有当类型参数相同时才能实现。)是否可以使用基于类型相等性的不同实现
我是一名优秀的程序员,十分优秀!