- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我制作了一个简单的 FragmentActivity 来显示谷歌地图并使用标记来显示当前位置和附近的地点。但现在我需要在另一个应用程序中使用该代码,我遇到了这个问题。
这是 Activity
private void updatePlaces(JSONArray jDestinationArray) throws JSONException{
locMan = (LocationManager)getSystemService(Context.LOCATION_SERVICE);
Location lastLoc = locMan.getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
double lat = lastLoc.getLatitude();
double lng = lastLoc.getLongitude();
lastLatLng = new LatLng(lat, lng);
Display display = getWindowManager().getDefaultDisplay();
Point size = new Point();
display.getSize(size);
int width = size.x;
int height = size.y;
Builder boundsBuilder = new LatLngBounds.Builder();
boundsBuilder.include(lastLatLng);
markers = new HashMap<Marker,Object>();
userMarker = map.addMarker(new MarkerOptions()
.position(lastLatLng)
.title("You are here")
.icon(BitmapDescriptorFactory.fromResource(userIcon))
.snippet("This is your last recorded location"));
markers.put(userMarker, lastLatLng);
for(int i=0; i<jDestinationArray.length(); i++){
JSONObject destinationObject = jDestinationArray.getJSONObject(i);
LatLng latlng = new LatLng(destinationObject.getDouble("latitude"), destinationObject.getDouble("longitude"));
Marker destinationMarker=
map.addMarker(new MarkerOptions()
.position(latlng)
.title(destinationObject.getString("name"))
.icon(BitmapDescriptorFactory.fromResource(destinationIcon))
.snippet(destinationObject.getString("street"))
);
markers.put(destinationMarker, latlng);
boundsBuilder.include(latlng);
}
// pan to see all markers on map:
LatLngBounds bounds = boundsBuilder.build();
map.moveCamera(CameraUpdateFactory.newLatLngBounds(bounds, width, height, 30));
//map.animateCamera(CameraUpdateFactory.newLatLng(lastLatLng), 3000, null);
}
还有日志,当我打开 map 时:
06-27 14:18:28.530: D/dalvikvm(3545): GC_CONCURRENT freed 755K, 10% free 10520K/11655K, paused 13ms+4ms, total 50ms
06-27 14:18:28.530: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 33ms
06-27 14:18:28.580: D/dalvikvm(3545): GC_FOR_ALLOC freed 756K, 11% free 10396K/11655K, paused 26ms, total 26ms
06-27 14:18:28.680: D/dalvikvm(3545): GC_CONCURRENT freed 690K, 11% free 10437K/11655K, paused 2ms+14ms, total 56ms
06-27 14:18:28.680: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 21ms
06-27 14:18:28.710: W/ResourceType(3545): No package identifier when getting value for resource number 0x00000000
06-27 14:18:28.710: D/AndroidRuntime(3545): Shutting down VM
06-27 14:18:28.710: W/dalvikvm(3545): threadid=1: thread exiting with uncaught exception (group=0x40c42318)
06-27 14:18:28.730: E/AndroidRuntime(3545): FATAL EXCEPTION: main
06-27 14:18:28.730: E/AndroidRuntime(3545): java.lang.NullPointerException
06-27 14:18:28.730: E/AndroidRuntime(3545): at maps.aj.bk.a(Unknown Source)
06-27 14:18:28.730: E/AndroidRuntime(3545): at maps.aj.bk.a(Unknown Source)
06-27 14:18:28.730: E/AndroidRuntime(3545): at maps.aj.al.a(Unknown Source)
06-27 14:18:28.730: E/AndroidRuntime(3545): at bcn.onTransact(SourceFile:167)
06-27 14:18:28.730: E/AndroidRuntime(3545): at android.os.Binder.transact(Binder.java:326)
06-27 14:18:28.730: E/AndroidRuntime(3545): at com.google.android.gms.maps.internal.IGoogleMapDelegate$a$a.addMarker(Unknown Source)
06-27 14:18:28.730: E/AndroidRuntime(3545): at com.google.android.gms.maps.GoogleMap.addMarker(Unknown Source)
06-27 14:18:28.730: E/AndroidRuntime(3545): at com.example.foodexp03a.MainActivity.updatePlaces(MainActivity.java:330)
06-27 14:18:28.730: E/AndroidRuntime(3545): at com.example.foodexp03a.MainActivity.access$1(MainActivity.java:312)
06-27 14:18:28.730: E/AndroidRuntime(3545): at com.example.foodexp03a.MainActivity$LongRunningGetIO.onPostExecute(MainActivity.java:394)
06-27 14:18:28.730: E/AndroidRuntime(3545): at com.example.foodexp03a.MainActivity$LongRunningGetIO.onPostExecute(MainActivity.java:1)
06-27 14:18:28.730: E/AndroidRuntime(3545): at android.os.AsyncTask.finish(AsyncTask.java:631)
06-27 14:18:28.730: E/AndroidRuntime(3545): at android.os.AsyncTask.access$600(AsyncTask.java:177)
06-27 14:18:28.730: E/AndroidRuntime(3545): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
06-27 14:18:28.730: E/AndroidRuntime(3545): at android.os.Handler.dispatchMessage(Handler.java:99)
06-27 14:18:28.730: E/AndroidRuntime(3545): at android.os.Looper.loop(Looper.java:137)
06-27 14:18:28.730: E/AndroidRuntime(3545): at android.app.ActivityThread.main(ActivityThread.java:4744)
06-27 14:18:28.730: E/AndroidRuntime(3545): at java.lang.reflect.Method.invokeNative(Native Method)
06-27 14:18:28.730: E/AndroidRuntime(3545): at java.lang.reflect.Method.invoke(Method.java:511)
06-27 14:18:28.730: E/AndroidRuntime(3545): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
06-27 14:18:28.730: E/AndroidRuntime(3545): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
06-27 14:18:28.730: E/AndroidRuntime(3545): at dalvik.system.NativeStart.main(Native Method)
06-27 14:18:28.900: D/dalvikvm(3545): GC_FOR_ALLOC freed 274K, 7% free 10937K/11655K, paused 62ms, total 62ms
06-27 14:18:28.980: D/dalvikvm(3545): GC_CONCURRENT freed 65K, 7% free 10945K/11655K, paused 12ms+14ms, total 82ms
06-27 14:18:28.980: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 1ms
06-27 14:18:29.010: D/dalvikvm(3545): GC_FOR_ALLOC freed 26K, 7% free 10918K/11655K, paused 31ms, total 31ms
06-27 14:18:29.020: I/dalvikvm-heap(3545): Grow heap (frag case) to 11.700MB for 1048592-byte allocation
06-27 14:18:29.050: D/dalvikvm(3545): GC_FOR_ALLOC freed <1K, 7% free 11942K/12743K, paused 30ms, total 30ms
06-27 14:18:29.110: D/dalvikvm(3545): GC_CONCURRENT freed <1K, 6% free 11981K/12743K, paused 2ms+23ms, total 57ms
06-27 14:18:29.201: D/dalvikvm(3545): GC_FOR_ALLOC freed 1219K, 15% free 10945K/12743K, paused 38ms, total 38ms
06-27 14:18:29.211: I/dalvikvm-heap(3545): Grow heap (frag case) to 11.725MB for 1048592-byte allocation
06-27 14:18:29.231: D/dalvikvm(3545): GC_FOR_ALLOC freed 1K, 7% free 11967K/12743K, paused 28ms, total 28ms
06-27 14:18:29.321: D/dalvikvm(3545): GC_CONCURRENT freed 1136K, 12% free 11290K/12743K, paused 13ms+20ms, total 82ms
06-27 14:18:29.461: D/dalvikvm(3545): GC_CONCURRENT freed 48K, 4% free 12305K/12743K, paused 27ms+14ms, total 93ms
06-27 14:18:29.461: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 33ms
06-27 14:18:29.641: D/dalvikvm(3545): GC_FOR_ALLOC freed 2623K, 22% free 10873K/13831K, paused 31ms, total 32ms
06-27 14:18:29.641: I/dalvikvm-heap(3545): Grow heap (frag case) to 11.656MB for 1048592-byte allocation
06-27 14:18:29.671: D/dalvikvm(3545): GC_FOR_ALLOC freed 1K, 15% free 11895K/13831K, paused 37ms, total 37ms
06-27 14:18:29.721: D/dalvikvm(3545): GC_CONCURRENT freed 75K, 14% free 11898K/13831K, paused 2ms+4ms, total 45ms
06-27 14:18:29.801: D/dalvikvm(3545): GC_FOR_ALLOC freed 2113K, 22% free 10892K/13831K, paused 26ms, total 26ms
06-27 14:18:29.801: I/dalvikvm-heap(3545): Grow heap (frag case) to 11.674MB for 1048592-byte allocation
06-27 14:18:29.831: D/dalvikvm(3545): GC_FOR_ALLOC freed 4K, 14% free 11912K/13831K, paused 26ms, total 26ms
06-27 14:18:29.891: D/dalvikvm(3545): GC_CONCURRENT freed 21K, 14% free 11917K/13831K, paused 13ms+7ms, total 63ms
06-27 14:18:30.021: D/dalvikvm(3545): GC_CONCURRENT freed 2261K, 21% free 10952K/13831K, paused 12ms+8ms, total 66ms
06-27 14:18:30.021: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 1ms
06-27 14:18:31.443: I/Process(3545): Sending signal. PID: 3545 SIG: 9
Activity 布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<fragment android:name="com.example.foodexp03a.HomeFragment"
android:id="@+id/homeFragment"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<fragment android:name="com.example.foodexp03a.LoginFragment"
android:id="@+id/loginFragment"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<fragment android:name="com.example.foodexp03a.SettingsFragment"
android:id="@+id/settingsFragment"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<fragment android:name="com.example.foodexp03a.DestinationFragment"
android:id="@+id/destinationFragment"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<fragment
android:id="@+id/mapFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:name="com.google.android.gms.maps.SupportMapFragment"/>
</LinearLayout>
最佳答案
我没有看到您在哪里为 userIcon
分配任何值,因此 BitmapDescriptorFactory.fromResource(userIcon)
可能会返回 null
作为结果.
关于java - Android谷歌地图添加标记时出现空指针异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17343408/
我刚接触 C 语言几周,所以对它还很陌生。 我见过这样的事情 * (variable-name) = -* (variable-name) 在讲义中,但它到底会做什么?它会否定所指向的值吗? 最佳答案
我有一个指向内存地址的void 指针。然后,我做 int 指针 = void 指针 float 指针 = void 指针 然后,取消引用它们以获取值。 { int x = 25; vo
我正在与计算机控制的泵进行一些串行端口通信,我用来通信的 createfile 函数需要将 com 端口名称解析为 wchar_t 指针。 我也在使用 QT 创建一个表单并获取 com 端口名称作为
#include "stdio.h" #include "malloc.h" int main() { char*x=(char*)malloc(1024); *(x+2)=3; --
#include #include main() { int an_int; void *void_pointer = &an_int; double *double_ptr = void
对于每个时间步长,我都有一个二维矩阵 a[ix][iz],ix 从 0 到 nx-1 和 iz 从 0 到 nz-1。 为了组装所有时间步长的矩阵,我定义了一个长度为 nx*nz*nt 的 3D 指针
我有一个函数,它接受一个指向 char ** 的指针并用字符串填充它(我猜是一个字符串数组)。 *list_of_strings* 在函数内部分配内存。 char * *list_of_strings
我试图了解当涉及到字符和字符串时,内存分配是如何工作的。 我知道声明的数组的名称就像指向数组第一个元素的指针,但该数组将驻留在内存的堆栈中。 另一方面,当我们想要使用内存堆时,我们使用 malloc,
我有一个 C 语言的 .DLL 文件。该 DLL 中所有函数所需的主要结构具有以下形式。 typedef struct { char *snsAccessID; char *
指针, C语言的精髓 莫队先咕几天, 容我先讲完树剖 (因为后面树上的东西好多都要用树剖求 LCA). 什么是指针 保存变量地址的变量叫做指针. 这是大概的定义, 但是Defad认为
我得到了以下数组: let arr = [ { children: [ { children: [], current: tru
#include int main(void) { int i; int *ptr = (int *) malloc(5 * sizeof(int)); for (i=0;
我正在编写一个程序,它接受一个三位数整数并将其分成两个整数。 224 将变为 220 和 4。 114 将变为 110 和 4。 基本上,您可以使用模数来完成。我写了我认为应该工作的东西,编译器一直说
好吧,我对 C++ 很陌生,我确定这个问题已经在某个地方得到了回答,而且也很简单,但我似乎找不到答案.... 我有一个自定义数组类,我将其用作练习来尝试了解其工作原理,其定义如下: 标题: class
1) this 指针与其他指针有何不同?据我了解,指针指向堆中的内存。如果有指向它们的指针,这是否意味着对象总是在堆中构造? 2)我们可以在 move 构造函数或 move 赋值中窃取this指针吗?
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: C : pointer to struct in the struct definition 在我的初学者类
我有两个指向指针的结构指针 typedef struct Square { ... ... }Square; Square **s1; //Representing 2D array of say,
变量在内存中是如何定位的?我有这个代码 int w=1; int x=1; int y=1; int z=1; int main(int argc, char** argv) { printf
#include #include main() { char *q[]={"black","white","red"}; printf("%s",*q+3); getch()
我在“C”类中有以下函数 class C { template void Func1(int x); template void Func2(int x); }; template void
我是一名优秀的程序员,十分优秀!