Android 绘制自定义室内地图和位置之间的链接。对于每个位置x,y坐标已经知道会显示在屏幕上

Android 绘制自定义室内地图和位置之间的链接。对于每个位置x,y坐标已经知道会显示在屏幕上,android,Android,我必须画一张这样的地图,还可以像谷歌地图一样,在点击任何pin时显示覆盖图。我能够在画布上绘制视图以及单击侦听器,但是单击侦听器操作是通过单击屏幕上的任何位置来执行的,并且它仅适用于最后绘制的视图。因此,如果有任何解决方案,请让我知道。提前谢谢。你听说过土工围栏吗?唯一的问题是它是根据圆的原理工作的。但这应该没那么糟糕,因为你可以用两个圆圈覆盖入口,一个圆圈覆盖房间的呼吸,包括入口门,另一个圆圈包含在更大的圆圈中,只覆盖门 看看A4,我画了两个圆圈,很抱歉画得很难看 如果用户进入一个较小的圆圈



我必须画一张这样的地图,还可以像谷歌地图一样,在点击任何pin时显示覆盖图。我能够在画布上绘制视图以及单击侦听器,但是单击侦听器操作是通过单击屏幕上的任何位置来执行的,并且它仅适用于最后绘制的视图。因此,如果有任何解决方案,请让我知道。提前谢谢。

你听说过土工围栏吗?唯一的问题是它是根据圆的原理工作的。但这应该没那么糟糕,因为你可以用两个圆圈覆盖入口,一个圆圈覆盖房间的呼吸,包括入口门,另一个圆圈包含在更大的圆圈中,只覆盖门

看看A4,我画了两个圆圈,很抱歉画得很难看

如果用户进入一个较小的圆圈和一个较大的圆圈,则用户仍在房间内。如果他进入较小的圆圈并存在(并且没有进入较大的圆圈),他就已经离开了房间

Twisted,但将使用最少的编码。读一下地理围栏


另请注意,地理围栏现在与LocationClient API合并,后者的电池消耗比LocationManager少8倍。那就去做吧。

你听说过土工围栏吗?唯一的问题是它是根据圆的原理工作的。但这应该没那么糟糕,因为你可以用两个圆圈覆盖入口,一个圆圈覆盖房间的呼吸,包括入口门,另一个圆圈包含在更大的圆圈中,只覆盖门

看看A4,我画了两个圆圈,很抱歉画得很难看

如果用户进入一个较小的圆圈和一个较大的圆圈,则用户仍在房间内。如果他进入较小的圆圈并存在(并且没有进入较大的圆圈),他就已经离开了房间

Twisted,但将使用最少的编码。读一下地理围栏

另请注意,地理围栏现在与LocationClient API合并,后者的电池消耗比LocationManager少8倍。所以去做吧

package com.smallfan.museumexhibition.views;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.drawable.Drawable;
import android.view.View;
import android.widget.Toast;

public class CustomDrawableView extends View implements View.OnClickListener {

    Drawable drawable;
     Paint paint;
     String myText;
     int x1,y1;
     Context context;

    public CustomDrawableView(Context context, Drawable mydrawable, int x, int y, String text) {
        super(context);

        this.myText=text;
        this.x1=x;
        this.y1=y;
        this.paint = new Paint();
        this.context=context;

        drawable=mydrawable;

        drawable.setBounds(x, y, x + drawable.getMinimumWidth(), y + drawable.getMinimumHeight());

        setOnClickListener(this);
    }

    protected void onDraw(Canvas canvas) {
        drawable.draw(canvas);
    }

    @Override
    public void onClick(View v)
    { 
        v.setTag(myText);
        Toast.makeText(context, "View clicked. "+"  tag  "+ v.getTag(), Toast.LENGTH_SHORT).show();

    }
}

///////////////////////////////////////////////////

package com.smallfan.museumexhibition;

import java.io.InputStream;

import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.RelativeLayout;


public class MapInActivity extends Fragment
{

    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        Log.v("MapInActivity", "onCreate()");
    }

    DrawView drawView;

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
    {
        Log.v("MapInActivity", "onCreateView()");

        View v = LayoutInflater.from(getActivity()).inflate(R.layout.indoormap_layout, null);
        RelativeLayout maplayout=(RelativeLayout)v.findViewById(R.id.maplayout);


        CustomDrawableView   mCustomDrawableView = new CustomDrawableView(getActivity(),getResources().getDrawable(R.drawable.ic_launcher),10,10,"Item 1");
        maplayout.addView(mCustomDrawableView);

        CustomDrawableView   mCustomDrawableView1 = new CustomDrawableView(getActivity(),getResources().getDrawable(R.drawable.ic_launcher),50,50,"Item 2");
        maplayout.addView(mCustomDrawableView1);

        return v;
    }

    @Override
    public void onActivityCreated(Bundle savedInstanceState)
    {
        super.onActivityCreated(savedInstanceState);
        Log.v("MapInActivity", "onActivityCreated().");
    }
    //

}