- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在我的应用程序中实现了 PlacePicker.IntentBuilder UI。在最长的时间内它没有问题,但现在一旦 UI 出现,它就会关闭,我不确定为什么。疯狂的事情是查看 logcat 它不会崩溃或导致任何异常所以我不知道问题是什么。这是创建和调用它的类。
package com.example.apthagreat.faf;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.os.AsyncTask;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import com.google.android.gms.common.GooglePlayServicesNotAvailableException;
import com.google.android.gms.common.GooglePlayServicesRepairableException;
import com.google.android.gms.location.places.Place;
import com.google.android.gms.location.places.ui.PlacePicker;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.LatLngBounds;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.StatusLine;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
public class DetermineSearchCoordinatesScreen extends ActionBarActivity
{
//Instance Variables
int PLACE_PICKER_REQUEST = 1;
int SELECTED_PLACE_REQUEST = 2;
LatLng southWestBounds;
LatLng northEastBounds;
String zipCodeString;
String zipCodeURL;
String user;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_determine_search_coordinates_screen);
final EditText zipCode = (EditText) findViewById(R.id.enterZip);
final Button findZip = (Button) findViewById(R.id.findZipButton);
user = getIntent().getExtras().getString("username");
//Find button is used when user enters a zip code and not the device's GPS
findZip.setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
if (findZip.getText().equals("FIND!"))
{
//build the URL to be passed to determine coordinates for given zip code
zipCodeURL = "http://maps.googleapis.com/maps/api/geocode/json?address=";
zipCodeString = zipCode.getText().toString();
if (zipCodeString.length() == 5)
{
//Fetch to go get GPS coordinates for zip code
zipCodeURL += zipCodeString;
GetZipCoordinates task = new GetZipCoordinates(southWestBounds, northEastBounds);
task.execute(zipCodeURL);
findZip.setText("PUSH TO SEE PLACES");
}
else
{
Toast.makeText(getApplicationContext(), "Must enter a valid 5 digit zip code", Toast.LENGTH_SHORT).show();
}
}
else if (findZip.getText().equals("PUSH TO SEE PLACES"))
{
//AsyncTask was successful in finding coordinates and now we can pass the coordinates in and display places to user
PlacePicker.IntentBuilder builder = new PlacePicker.IntentBuilder();
LatLngBounds llb = new LatLngBounds(southWestBounds, northEastBounds);
builder.setLatLngBounds(llb);
findZip.setText("FIND!");
try
{
startActivityForResult(builder.build(DetermineSearchCoordinatesScreen.this), PLACE_PICKER_REQUEST);
}
catch (GooglePlayServicesRepairableException e)
{
e.printStackTrace();
}
catch (GooglePlayServicesNotAvailableException e)
{
e.printStackTrace();
}
catch(NullPointerException npe)
{
Toast.makeText(getBaseContext(),"Retrieval of coordinates is not yet complete! Try Again.", Toast.LENGTH_LONG).show();
}
}
}
});
//Here we will use the device's GPS coordinates and display nearby places
Button currentSpot = (Button) findViewById(R.id.currentLocationButton);
currentSpot.setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
PlacePicker.IntentBuilder builder = new PlacePicker.IntentBuilder();
try
{
startActivityForResult(builder.build(DetermineSearchCoordinatesScreen.this), PLACE_PICKER_REQUEST);
}
catch (GooglePlayServicesRepairableException e)
{
e.printStackTrace();
}
catch (GooglePlayServicesNotAvailableException e)
{
e.printStackTrace();
}
}
});
}
@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_search_category_location_screen, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item)
{
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings)
{
return true;
}
return super.onOptionsItemSelected(item);
}
public void setNorthEastBounds(LatLng northEastBounds)
{
this.northEastBounds = northEastBounds;
}
public void setSouthWestBounds(LatLng southWestBounds)
{
this.southWestBounds = southWestBounds;
}
/*
Once the user selects a place, a dialog will appear prompting the user if they would like
to create an activity at this place
*/
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == PLACE_PICKER_REQUEST)
{
if (resultCode == RESULT_OK)
{
//The place the user selected
final Place place = PlacePicker.getPlace(data, this);
//The dialog that will prompt the user to create an activity when a place is selected
AlertDialog.Builder createActivity = new AlertDialog.Builder(this);
createActivity.setMessage("Would you like to create an activity at this location?");
createActivity.setPositiveButton("YES", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
//Here the user will be directed to the create activity screen and the name and address of selected place will be passed along with it
Intent create = new Intent(getApplicationContext(), CreateActivityScreen.class);
create.putExtra("username", user);
create.putExtra("placeName", place.getName());
create.putExtra("placeAddress", place.getAddress());
startActivityForResult(create, SELECTED_PLACE_REQUEST);
finish();
}
});
createActivity.setNegativeButton("NO", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
//If the user doesn't want to create an activity nothing will happen
}
});
createActivity.show();
}
}
}
/*
The class that is taking the URL and fetching to the internet to find
the GPS coordinates for the user given zip code.
Parses the data into a JSON object and converts it into Latitude and Longitude
coordinates.
The coordinates are given in the form of the Southwest bound coordinates and
Northeast bound coordinates around the zip code.
*/
private class GetZipCoordinates extends AsyncTask<String, Void, String>
{
LatLng sw;
LatLng ne;
public GetZipCoordinates(LatLng sw, LatLng ne)
{
this.sw = sw;
this.ne = ne;
}
@Override
protected String doInBackground(String... placesURL)
{
//fetch places
StringBuilder placesBuilder = new StringBuilder();
//process search parameter string(s)
for (String placeSearchURL : placesURL)
{
//execute search
HttpClient placesClient = new DefaultHttpClient();
try
{
//try to fetch the data
HttpGet placesGet = new HttpGet(placeSearchURL);
HttpResponse placesResponse = placesClient.execute(placesGet);
StatusLine placeSearchStatus = placesResponse.getStatusLine();
//System.err.println(placeSearchStatus);
if (placeSearchStatus.getStatusCode() == 200)
{
//we have an OK response
HttpEntity placesEntity = placesResponse.getEntity();
InputStream placesContent = placesEntity.getContent();
InputStreamReader placesInput = new InputStreamReader(placesContent);
BufferedReader placesReader = new BufferedReader(placesInput);
String lineIn;
while ((lineIn = placesReader.readLine()) != null)
{
placesBuilder.append(lineIn);
}
}
}
catch (Exception e)
{
System.err.println("The website is never executed");
}
}
return placesBuilder.toString();
}
//Take the results from the URL, separate it, and get the Southwest and Northeast bound coordinates
protected void onPostExecute(String result)
{
LatLng SWBounds = null;
LatLng NEBounds = null;
try
{
JSONObject resultObject = new JSONObject(result);
JSONArray placesArray = resultObject.getJSONArray("results");
try
{
JSONObject placeObject = placesArray.getJSONObject(0);
JSONObject southWestLoc = placeObject.getJSONObject("geometry").getJSONObject("bounds").getJSONObject("southwest");
JSONObject northEastLoc = placeObject.getJSONObject("geometry").getJSONObject("bounds").getJSONObject("northeast");
SWBounds = new LatLng(Double.valueOf(southWestLoc.getString("lat")), Double.valueOf(southWestLoc.getString("lng")));
NEBounds = new LatLng(Double.valueOf(northEastLoc.getString("lat")), Double.valueOf(northEastLoc.getString("lng")));
setSouthWestBounds(SWBounds);
setNorthEastBounds(NEBounds);
}
catch (JSONException jse)
{
System.err.println("The bounds were not computed");
}
}
catch (Exception e)
{
System.err.println("The JSON object was never read");
}
}
}
@Override
public void onPause()
{
super.onPause();
//Blank the URL after the Map is displayed
zipCodeURL = null;
}
@Override
public void onResume()
{
super.onResume();
//For safe measures, set to blank when activity reappears
zipCodeURL = "";
}
}
这是我进入此类并按下调用 PlacePlace.IntentBuilder 的按钮时的 logcat
04-16 21:19:24.513 7650-7650/com.example.apthagreat.faf D/Activity﹕ performCreate Call debug elastic valuetrue
04-16 21:19:24.683 7650-7671/com.example.apthagreat.faf D/OpenGLRenderer﹕ endAllStagingAnimators on 0x9d2dd000 (RippleDrawable) with handle 0xb4ad4d60
04-16 21:19:24.703 7650-7650/com.example.apthagreat.faf I/Timeline﹕ Timeline: Activity_idle id: android.os.BinderProxy@24ce418b time:4496690
04-16 21:19:24.973 7650-7650/com.example.apthagreat.faf V/ActivityThread﹕ updateVisibility : ActivityRecord{26aa4d14 token=android.os.BinderProxy@1b7217fa {com.example.apthagreat.faf/com.example.apthagreat.faf.ActivityListScreen}} show : false
04-16 21:19:26.633 7650-7650/com.example.apthagreat.faf D/ViewRootImpl﹕ ViewPostImeInputStage ACTION_DOWN
04-16 21:19:26.813 7650-7671/com.example.apthagreat.faf D/OpenGLRenderer﹕ endAllStagingAnimators on 0x9d2e9600 (RippleDrawable) with handle 0x9f64add0
04-16 21:19:27.543 7650-7650/com.example.apthagreat.faf W/IInputConnectionWrapper﹕ showStatusIcon on inactive InputConnection
04-16 21:19:28.143 7650-7650/com.example.apthagreat.faf I/Timeline﹕ Timeline: Activity_idle id: android.os.BinderProxy@24ce418b time:4500135
谁能帮我解决这个问题。
最佳答案
我遇到了同样的问题。确保在 Developer Console 中启用“Android 版 Places API” 而不仅仅是 “Places API” . “Places API for Android” 不会出现在“APIs & Auth/APIs”下,因为它还不是一个流行的 API(目前)。您必须使用 API 搜索框进行搜索。
关于android - PlacePicker.IntentBuilder 打开后立即关闭,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29688642/
我正在使用的网站上有一个非 Canvas 导航。关闭 Canvas 导航的默认状态是关闭的,这在移动网站上运行良好,因为您可以打开它并选择您的链接,但在桌面上关闭它并打开它会隐藏用户的信息,我希望它是
我有一个 NSViewController 是这样连接的: 在底部 viewController 中,我尝试使用 self.dismiss(self) 关闭它,但是,它会产生此错误: [General
我昨天制作了一个扩展的 JQuery 搜索框,它的作用就像一个魅力!但是,我在创建一个脚本时遇到问题,当用户单击搜索框时,它会关闭。 这是我的 JQuery: function expandSearc
我一辈子都无法在 API V3 中一次只显示一个信息窗口。我需要一个在下一次开放之前关闭。还希望在 map 上的任何地方关闭 infoWindow onclick。这是否在初始化函数中? 这是我的完整
关闭和清理套接字的正确方法是什么? 我在辅助线程中运行 io_service,我需要关闭与主线程的连接: void closeConnection() { ioc.post([&socket]
我的 Selenium 测试看起来像这样:客户选择金融产品,填写一些必要的数据,并在打印预览中显示条款/协议(protocol)文档(根据本地法律的要求)。打印/关闭打印预览对话框后,客户输入更多数据
我目前正在从 android 网站了解 Navigation Drawer,我正在使用他们的示例 http://developer.android.com/training/implementing-
尝试通过 expo 在模拟器上运行 react-native 应用程序时出现此错误。 Couldn't start project on Android: Error running adb: adb
方法一 function transform(ar) { var alStr = []; for(var i=0; i
我想按以下方式自定义我的抽屉导航: 我希望在抽屉打开时显示一个图标,在抽屉关闭时显示另一个图标,而不是将菜单图标稍微向左滑动的当前默认动画。 关于我在哪里可以找到类似内容的任何想法/线索? 我做了一些
我们刚刚从 0.6.2 或 0.7 升级了我们的 dropwizard 版本,发现 .yml 文件中的很多配置都发生了变化。尽管我们能够弄清楚其中的大部分,但我们无法弄清楚如何关闭“requestLo
从 celery 2.4.5 升级后,我开始让 celery 随机关闭。 我在 centOS 机器上使用 celery 3.0.12、boto 2.6 和 amazon sqs 和 django 1.
我试图包含一些语句来指导用户更多地了解文件无法打开或关闭的原因。文件在写入模式下无法打开的一些可能情况是什么?无法关闭怎么办? FILE *fp; if(!(fp = fopen("testing",
我有一个DLL,可以访问数据库并从存储在配置文件中的应用程序设置中读取连接字符串。然后,引用此DLL的应用程序将需要在其配置文件中为此配置设置设置值。 我遇到的问题是,生成的配置代码会通过Defaul
我将 UIDatePicker 添加为 UITextField 的输入 View UIDatePicker *oBirth; NSDateFormatter *dateFormat; _edit
我有以下代码: SecondViewController *secondView = [[SecondViewController alloc] initWithNibName:@"SecondVie
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
通常,按下 option 键关闭窗口会关闭应用程序中的所有窗口。在我的应用程序中,我希望它仅关闭与用户正在关闭的窗口相关的窗口。我怎样才能做到这一点?我可以为所有窗口实现 windowShouldCl
我有一个 NSWindow,它托管一个已连接到脚本处理程序的 WebView。 现在,当用户单击 WebView 上的控件上的按钮时,它会调用我的对象上的 Objective C 方法。 在这种特定情
我想根据 MBP 上的相机使用情况自动化个人工作流程。 基本上我想知道是否任何 的摄像头(内置或 USB)已打开或关闭,因此我可以运行我将创建的程序或脚本。 我认为如果我需要轮询相机状态也可以,但基于
我是一名优秀的程序员,十分优秀!