- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试在我的项目中使用 IndoorAtlas。我创建了 Activity
this例如,但是当我启动 Activity
时,我什么也没看到, map 没有加载到 ImageView
中,并且 LogCat 仅显示几行。请帮忙。
我的 LogCat 带有“IndoorAtlas”过滤器:
D/IndoorAtlasActivity: onCreate/ requestLocationUpdates() called
D/IndoorAtlasActivity: onResume/ requestLocationUpdates() called
D/IACore: IndoorAtlas Android SDK
SDK : 2.0.2-beta-9999
Android: 4.2.1-17
Date : Sat, 20 Feb 2016 22:14:41 GMT
我的XML
:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<include
android:id="@+id/toolbar"
layout="@layout/toolbar" />
<ImageView
android:id="@+id/image"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@id/toolbar" />
</RelativeLayout>
我的 Activity
:
public class IndoorAtlasActivity extends AppCompatActivity {
private static final String TAG = "IndoorAtlasActivity";
private IALocationManager mIALocationManager;
private IAResourceManager mResourceManager;
private ImageView mImageView;
private IATask<IAFloorPlan> mPendingAsyncResult = null;
private IAResourceManager mFloorPlanManager;
private IAFloorPlan mFloorPlan;
private long mDownloadId;
private DownloadManager mDownloadManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_indooratlas);
mIALocationManager = IALocationManager.create(this);
mImageView = (ImageView) findViewById(R.id.image);
mIALocationManager.registerRegionListener(mRegionListener);
mIALocationManager.requestLocationUpdates(IALocationRequest.create(), mLocationListener);
Log.d(TAG, "onCreate/ requestLocationUpdates() called");
mDownloadManager = (DownloadManager) getSystemService(Context.DOWNLOAD_SERVICE);
mIALocationManager = IALocationManager.create(this);
mFloorPlanManager = IAResourceManager.create(this);
/* optional setup of floor plan id
if setLocation is not called, then location manager tries to find
location automatically */
final String floorPlanId = "my_floor_plan_id";
if (!TextUtils.isEmpty(floorPlanId)) {
final IALocation location = IALocation.from(IARegion.floorPlan(floorPlanId));
mIALocationManager.setLocation(location);
}
}
@Override
protected void onResume() {
super.onResume();
mIALocationManager.requestLocationUpdates(IALocationRequest.create(), mLocationListener);
mIALocationManager.registerRegionListener(mRegionListener);
registerReceiver(onComplete, new IntentFilter(DownloadManager.ACTION_DOWNLOAD_COMPLETE));
Log.d(TAG, "onResume/ requestLocationUpdates() called");
}
@Override
protected void onPause() {
super.onPause();
mIALocationManager.removeLocationUpdates(mLocationListener);
mIALocationManager.unregisterRegionListener(mRegionListener);
unregisterReceiver(onComplete);
Log.d(TAG, "onPause/ removing requestLocationUpdates()");
}
@Override
protected void onDestroy() {
mIALocationManager.destroy();
Log.d(TAG, "onDestroy/ destroying mIALocationManager");
super.onDestroy();
}
private IALocationListener mLocationListener = new IALocationListenerSupport() {
@Override
public void onLocationChanged(IALocation location) {
Log.d(TAG, "location is: " + location.getLatitude() + "," + location.getLongitude());
}
};
private IARegion.Listener mRegionListener = new IARegion.Listener() {
@Override
public void onEnterRegion(IARegion region) {
if (region.getType() == IARegion.TYPE_FLOOR_PLAN) {
String id = region.getId();
Log.d(TAG, "floorPlan changed to " + id);
Toast.makeText(IndoorAtlasActivity.this, id, Toast.LENGTH_SHORT).show();
fetchFloorPlan(id);
}
}
@Override
public void onExitRegion(IARegion region) {
// leaving a previously entered region
}
};
/* Broadcast receiver for floor plan image download */
private BroadcastReceiver onComplete = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
long id = intent.getLongExtra(DownloadManager.EXTRA_DOWNLOAD_ID, 0L);
if (id != mDownloadId) {
Log.w(TAG, "Ignore unrelated download");
return;
}
Log.w(TAG, "Image download completed");
Bundle extras = intent.getExtras();
DownloadManager.Query q = new DownloadManager.Query();
q.setFilterById(extras.getLong(DownloadManager.EXTRA_DOWNLOAD_ID));
Cursor c = mDownloadManager.query(q);
if (c.moveToFirst()) {
int status = c.getInt(c.getColumnIndex(DownloadManager.COLUMN_STATUS));
if (status == DownloadManager.STATUS_SUCCESSFUL) {
// process download
String filePath = c.getString(c.getColumnIndex(
DownloadManager.COLUMN_LOCAL_FILENAME));
showFloorPlanImage(filePath);
}
}
c.close();
}
};
private void showFloorPlanImage(String filePath) {
Log.w(TAG, "showFloorPlanImage: " + filePath);
Picasso.with(this)
.load(filePath)
.into(mImageView);
}
/**
* Fetches floor plan data from IndoorAtlas server. Some room for cleaning up!!
*/
private void fetchFloorPlan(String id) {
cancelPendingNetworkCalls();
final IATask<IAFloorPlan> asyncResult = mFloorPlanManager.fetchFloorPlanWithId(id);
mPendingAsyncResult = asyncResult;
if (mPendingAsyncResult != null) {
mPendingAsyncResult.setCallback(new IAResultCallback<IAFloorPlan>() {
@Override
public void onResult(IAResult<IAFloorPlan> result) {
Log.d(TAG, "fetch floor plan result:" + result);
if (result.isSuccess() && result.getResult() != null) {
mFloorPlan = result.getResult();
String fileName = mFloorPlan.getId() + ".img";
String filePath = Environment.getExternalStorageDirectory() + "/"
+ Environment.DIRECTORY_DOWNLOADS + "/" + fileName;
File file = new File(filePath);
if (!file.exists()) {
DownloadManager.Request request =
new DownloadManager.Request(Uri.parse(mFloorPlan.getUrl()));
request.setDescription("IndoorAtlas floor plan");
request.setTitle("Floor plan");
// requires android 3.2 or later to compile
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
request.allowScanningByMediaScanner();
request.setNotificationVisibility(DownloadManager.
Request.VISIBILITY_HIDDEN);
}
request.setDestinationInExternalPublicDir(Environment.
DIRECTORY_DOWNLOADS, fileName);
mDownloadId = mDownloadManager.enqueue(request);
} else {
showFloorPlanImage(filePath);
}
} else {
// do something with error
if (!asyncResult.isCancelled()) {
Toast.makeText(IndoorAtlasActivity.this,
(result.getError() != null
? "error loading floor plan: " + result.getError()
: "access to floor plan denied"), Toast.LENGTH_LONG)
.show();
}
}
}
}, Looper.getMainLooper()); // deliver callbacks in main thread
}
}
private void cancelPendingNetworkCalls() {
if (mPendingAsyncResult != null && !mPendingAsyncResult.isCancelled()) {
mPendingAsyncResult.cancel();
}
}
}
最佳答案
您不需要 ImageView 来加载和显示平面图。您需要一个名为“BlueDotView”的类,您可以从此链接找到它:BlueDotView class 。如果您正确地浏览ImageViewActivity类(从创建 Activity 的位置),您将看到没有需要使用的此类 ImageView 。 ImageViewActivity 类具有以下内容:
private BlueDotView mImageView;。
为了正确加载平面图,请执行以下步骤。
1. 使用 ImageViewActivity 正确交叉检查您的 Activity 。
2. 您必须将 BlueDotView 类作为单独的类。
3. 在您的activity_indooratlas XML 文件中,您应该有如下内容,这些内容来自 SDK 2.0 的 github 存储库,而不是 XML 文件中的内容:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<com.indooratlas.android.sdk.examples.imageview.BlueDotView
android:id="@+id/imageView"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</LinearLayout>
关于java - IndoorAtlas SDK 2.0 map 未加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35529802/
我找到了 this excellent question and answer它以 x/y(加上 center x/y 和 degrees/radians)开始并计算旋转- 到 x'/y'。这个计算很
全部: 我已经创建了一个 Windows 窗体和一个按钮。在另一个线程中,我试图更改按钮的文本,但它崩溃了;但是如果我尝试更改按钮的颜色,它肯定会成功。我认为如果您更改任何 Windows 窗体控件属
本网站的另一个问题已证实,C 中没有缩写的字面后缀,并且可以执行以下操作: short Number = (short)1; 但是转换它和不这样做有什么区别: short Number = 1; 您使
我有下表: ID (int) EMAIL (varchar(50)) CAMPAIGNID (int) isSubscribe (bit) isActionByUser (bit) 此表存储了用户对事
也就是说,无需触发Javascript事件即可改变的属性,如何保留我手动选中或取消选中的复选框的状态,然后复制到另一个地方? 运行下面的代码片段并选中或取消选中其中的一些,然后点击“复制”: $('#
我在网上找到的所有关于递增指针导致段错误的示例都涉及指针的取消引用 - 如果我只想递增它(例如在 for 循环的末尾)并且我不在乎它是否最终进入无效内存,因为我不会再使用它。例如,在这个程序中,每次迭
我有一个 Spring MVC REST 服务,它使用 XStream 将消息与 XML 相互转换。 有什么方法可以将请求和响应中的 xml(即正文)打印到普通的 log4j 记录器? 在 Contr
做我的任务有一个很大的挑战,那就是做相互依赖的任务我在这张照片中说的。假设我们有两个任务 A 和 B,执行子任务 A1、A2 和 B1、B2,假设任务 B 依赖于 A。 要理想地执行任务 B,您应该执
通过阅读该网站上的几个答案,我了解到 CoInitialize(Ex) should be called by the creator of a thread 。然后,在该线程中运行的任何代码都可以使
这个问题已经困扰我一段时间了。我以前从未真正使用过 ListViews,也没有使用过 FirebaseListAdapters。我想做的就是通过显示 id 和用户位置来启动列表的基础,但由于某种原因,
我很难解释这两个(看似简单)句子的含义: “受检异常由编译器在编译时检查” 这是什么意思?编译器检查是否捕获了所有已检查的异常(在代码中抛出)? “未经检查的异常在运行时检查,而不是编译时” 这句话中
我有一个包含排除子字符串的文本文件,我想迭代该文件以检查并返回不带排除子字符串的输入项。 这里我使用 python 2.4,因此下面的代码可以实现此目的,因为 with open 和 any 不起作用
Spring 的缓存框架能否了解请求上下文的身份验证状态,或者更容易推出自己的缓存解决方案? 最佳答案 尽管我发现这个用例 super 奇怪,但您可以为几乎任何与 SpEL 配合使用的内容设置缓存条件
我有以下函数模板: template HeldAs* duplicate(MostDerived *original, HeldAs *held) { // error checking omi
如果我的应用程序具有设备管理员/设备所有者权限(未获得 root 权限),我如何才能从我的应用程序中终止(或阻止启动)另一个应用程序? 最佳答案 设备所有者可以阻止应用程序: DevicePolicy
非常简单的问题,但我似乎无法让它正常工作。 我有一个组件,其中有一些 XSLT(用于导航)。它通过 XSLT TBB 使用 XSLT Mediator 发布。 发布后
我正在将一个对象拖动到一个可拖放的对象内,该对象也是可拖动的。放置对象后,它会嵌套在可放置对象内。同样,如果我将对象拖到可放置的外部,它就不再嵌套。 但是,如果我经常拖入和拖出可放置对象,则可拖动对象
我正在尝试为按钮和弹出窗口等多个指令实现“取消选择”功能。也就是说,我希望当用户单击不属于指令模板一部分的元素时触发我的函数。目前,我正在使用以下 JQuery 代码: $('body').click
我从 this question 得到了下面的代码,该脚本用于在 Google tasks 上更改 iframe[src="about:blank"] 内的 CSS使用 Chrome 扩展 Tempe
我有一些 @Mock 对象,但没有指定在该对象上调用方法的返回值。该方法返回 int (不是 Integer)。我很惊讶地发现 Mockito 没有抛出 NPE 并返回 0。这是预期的行为吗? 例如:
我是一名优秀的程序员,十分优秀!