gpt4 book ai didi

android - 获取 Android Activity 以运行非 Activity 代码

转载 作者:行者123 更新时间:2023-11-29 22:22:16 24 4
gpt4 key购买 nike

我有一个基本上只是在 map 上绘制点的 Android 应用程序。这些 map 是由完全不同的类别确定的。我最初将此类作为自己的程序编写(它读取 CSV 文件并挑选出点并在数组中返回它们的经度和纬度)。

因此,我所做的就是将此类添加到我的 Android 应用程序中。我希望应用程序在某个时候调用将生成数组的类方法,返回它,并使用这个新数组在 map 上绘制点。至于抓取数组并精确定位它们的每个纬度和经度,我可以做到。

但是,在我的 Android 应用程序的主类中,我声明:

String[][] bump = ReadCsv.getArray(fileToUse);

,我的程序将强制关闭。 (ReadCsv是我在程序中放入的类名——类中唯一方法中的getArray,它返回一个array[][])。

有没有人认为他们看到我这里的问题是什么?也许有替代解决方案?

LogCat如下图所示:

07-27 15:19:25.105: ERROR/AndroidRuntime(12214): FATAL EXCEPTION: main 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): java.lang.RuntimeException: Unable to start activity ComponentInfo{net.learn2develop.GoogleMaps/net.learn2develop.GoogleMaps.MapsActivity}: java.lang.NullPointerException 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.app.ActivityThread.access$2300(ActivityThread.java:125) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.os.Handler.dispatchMessage(Handler.java:99) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.os.Looper.loop(Looper.java:123) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.app.ActivityThread.main(ActivityThread.java:4627) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at java.lang.reflect.Method.invokeNative(Native Method) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at java.lang.reflect.Method.invoke(Method.java:521) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at dalvik.system.NativeStart.main(Native Method) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): Caused by: java.lang.NullPointerException 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at net.learn2develop.GoogleMaps.MapsActivity.onCreate(MapsActivity.java:86) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 07-27 15:19:25.105: ERROR/AndroidRuntime(12214): ... 11 more

我的代码是:

package net.learn2develop.GoogleMaps;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.util.List;
import java.util.StringTokenizer;

import com.google.android.maps.GeoPoint;
import com.google.android.maps.MapActivity;
import com.google.android.maps.MapController;
import com.google.android.maps.MapView;
import com.google.android.maps.Overlay;
import com.google.android.maps.MapView.LayoutParams;

import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Point;
import android.os.Bundle;
import android.view.View;
import android.widget.LinearLayout;


public class MapsActivity extends MapActivity
{
MapView mapView;
MapController mc;
GeoPoint p;
GeoPoint p2;
GeoPoint p99;

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

mapView = (MapView) findViewById(R.id.mapView);
LinearLayout zoomLayout = (LinearLayout)findViewById(R.id.zoom);
@SuppressWarnings("deprecation")
View zoomView = mapView.getZoomControls();

mapView.setSatellite(true);

zoomLayout.addView(zoomView,
new LinearLayout.LayoutParams(
LayoutParams.WRAP_CONTENT,
LayoutParams.WRAP_CONTENT));
mapView.displayZoomControls(true);

mc = mapView.getController();
String coordinates[] = {"42.30936432", "-71.12162781"};
double lat = Double.parseDouble(coordinates[0]);
double lng = Double.parseDouble(coordinates[1]);

p = new GeoPoint(
(int) (lat * 1E6),
(int) (lng * 1E6));

mc.animateTo(p);
mc.setZoom(8);

//---Add a location marker---
MapOverlay mapOverlay = new MapOverlay();
List<Overlay> listOfOverlays = mapView.getOverlays();
//listOfOverlays.clear();
listOfOverlays.add(mapOverlay);

// -- my own point ---
String coordinates2[] = {"42.20", "-71.20"};
double lat2 = Double.parseDouble(coordinates2[0]);
double lng2 = Double.parseDouble(coordinates2[1]);
p2 = new GeoPoint(
(int) (lat2 * 1E6),
(int) (lng2 * 1E6));
MapOverlay mapOverlay2 = new MapOverlay();
List<Overlay> listOfOverlays2 = mapView.getOverlays();
listOfOverlays2.add(mapOverlay2);

// Add points from ReadCsv.java
File fileToUse = new File("/Users/csrobot/Desktop/Training4.csv");
String[][] bump = ReadCsv.getArray(fileToUse);
for(int i = 0; i < bump.length; i++) {
String coordinates99[] = {bump[i][0], bump[i][1]};
double lat99 = Double.parseDouble(coordinates99[0]);
double lng99 = Double.parseDouble(coordinates99[1]);
p99 = new GeoPoint(
(int) (lat99 * 1E6),
(int) (lng99 * 1E6));
MapOverlay mapOverlay99 = new MapOverlay();
List<Overlay> listOfOverlays99 = mapView.getOverlays();
listOfOverlays99.add(mapOverlay99);
}

mapView.invalidate();
}

class MapOverlay extends com.google.android.maps.Overlay
{
@Override
public boolean draw(Canvas canvas, MapView mapView,
boolean shadow, long when)
{
super.draw(canvas, mapView, shadow);

//---translate the GeoPoint to screen pixels---
Point screenPts = new Point();
mapView.getProjection().toPixels(p, screenPts);

//---add the marker---
Bitmap bmp = BitmapFactory.decodeResource(
getResources(), R.drawable.redpin);
canvas.drawBitmap(bmp, screenPts.x, screenPts.y-44, null);


// --make my own point---
Point screenPts2 = new Point();
mapView.getProjection().toPixels(p2, screenPts2);
Bitmap bmp2 = BitmapFactory.decodeResource(
getResources(), R.drawable.redpin);
canvas.drawBitmap(bmp2, screenPts2.x, screenPts2.y-44, null);


return true;
}
}

static class ReadCsv {

public static String[][] getArray(File file) {

try {
//
// Code That I know Works is Here
//
return arrayOfBumps;

} catch (FileNotFoundException e) {
e.printStackTrace();
} catch(Exception e) {
// System.out.println("The following error occurred "+e);
}
return null;

}
}

@Override
protected boolean isRouteDisplayed() {
return false;
}
}

编辑:对于 Ravi Bhatt

private class MapPoint extends AsyncTask <String[][], String, String> {

@Override
protected String doInBackground(String[][]... <<What goes here...? >>) {

String << what am i making to return? >> = null;
try {
InputStream is = getAssets().open("Training4.csv");
BufferedReader reader = new BufferedReader(new InputStreamReader(is));
bump = getArray(reader);
if(bump == null){
setContentView(R.layout.deleteme);
} else {
for(int i = 0; i < bump.length; i++) {
String coordinates99[] = {bump[i][0], bump[i][1]};
double lat99 = Double.parseDouble(coordinates99[0]);
double lng99 = Double.parseDouble(coordinates99[1]);
p99 = new GeoPoint(
(int) (lat99 * 1E6),
(int) (lng99 * 1E6));
MapOverlay mapOverlay99 = new MapOverlay();
List<Overlay> listOfOverlays99 = mapView.getOverlays();
listOfOverlays99.add(mapOverlay99);
}
}
} catch (IOException e) {
e.printStackTrace();
}

return << do I really need to return something? if so, what? >>;
}

@Override
protected void onPostExecute(String result) {
super.onPostExecute(result);
mapView.refreshDrawableState();

}

}

最佳答案

最适合您需求的想法是 AsyncTask。使用此链接 http://developer.android.com/reference/android/os/AsyncTask.html

您可以在doInBackground() 方法中传递参数。参数可以是纬度和经度的列表。

-- 进行地理定位

-- 创建overlayitem

-- 将其添加到逐项叠加层中

onPostExectute() 方法执行以下操作。

-- 将其添加到 mapoverlay 即叠加列表。-- 之后你可以使用 refreshdrawablestate() 方法。

要从非 Activity 类放置该叠加层,您可以使用 mapactivity 的引用或上下文并将其用于添加叠加层。

编辑:

例如,考虑来自链接 http://developer.android.com/resources/tutorials/views/hello-mapview.html 的示例 map View

当使用 AsncTask 时,因为您有坐标数组,所以将此数组作为参数传递到 AsyncTask 中,例如 AsyncTask。

然后 doInBackGround() 方法使用 doInBackGroud < String[][]...varName > 因为您有字符串数组。将导出坐标和 Geopoint 的 for 循环逻辑放在 doInBackGround 方法中。

--添加您从 itemizedOverlay 中的坐标获得的每个叠加项(根据 hello mapview 的链接)。

--在onPostExecute() 方法中将逐项叠加层添加到 map 列表中并使用mapview.refreshdrawablestate()。您可以将 onPostExecute 与类似 onPostExecute(Void result)

的声明一起使用

理解并完成上述步骤!!! :)

关于android - 获取 Android Activity 以运行非 Activity 代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6847370/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com