最近公司项目中一直在搞地图开发,今天产品经理就给我布置了一些(无法想象)任务,其中一个就是实现地点搜索输入框的自动输入提示功能。拿到任务肯定想讨价还价一番,但是想到以前也写过,就不再负隅顽抗了。
以前在学校的时候实现过类似功能,是使用高德自带的InputtipsListener来实现的,想了解可以看看:文章传送点,这里就不详细介绍了。作为一名头脑发热的开发者,肯定不能安于现状,这里主要介绍其他两种方式 - poi实现和http请求接口实现,不管能不能成功,试了再说,撸起袖子就是干。先看看最终的效果:
做之前先分析一下功能需求,首先输入框中要添加内容清除的icon,当输入框有文字时,需要显示,为空时隐藏;接着,需要实现地址搜索功能并通过listview展示结果;最后需要实现展示搜索历史的功能。好的,那么下面我们来一步步实现。
其实,实现效果中的输入框并不难,只需要三个东西就够了:LinearLayout,EditText,ImageView。直接上代码吧,上了代码你就知道它到底有多简单了:
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="36dp"
android:layout_weight="1"
android:layout_marginLeft="20dp"
android:background="@drawable/search_view_bg"
android:orientation="horizontal"
android:gravity="center_vertical">
<EditText
android:id="@+id/search_edit_text"
android:layout_width="wrap_content"
android:layout_height="36dp"
android:hint="@string/input_cross_location"
android:textColorHint="#9B9B9B"
android:textSize="12sp"
android:maxLines="1"
android:layout_weight="1"
android:paddingBottom="10dp"
android:paddingTop="10dp"
android:paddingLeft="10dp"
android:background="@drawable/search_edit_bg"
android:drawableLeft="@mipmap/icon_edit_search"
android:drawablePadding="16dp"/>
<ImageView
android:id="@+id/search_edit_delete"
android:layout_width="12dp"
android:layout_height="12dp"
android:layout_marginLeft="5dp"
android:layout_marginRight="8dp"
android:visibility="gone"
android:src="@mipmap/iocn_search_cancel"/>
</LinearLayout>
没错,这里为EditText父容器LinearLayout设置背景,然后EditText设置同样的背景,只不过需要将右边的圆角效果去掉,达到预期效果。也即是说,我们的输入框相当于是LinearLayout,里面包含了edittext和删除图标imageview,来看看drawable的代码吧:
search_view_bg:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_window_focused="false">
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<!--<solid android:color="#F4F4F4" />-->
<corners android:radius="3dp"/>
<solid android:color="#F3F3F3"/>
<!--<stroke android:color="#ffececec" android:width="1dp"/>-->
</shape>
</item>
<item android:state_window_focused="true">
<shape>
<corners android:radius="3dp"/>
<!--<stroke android:color="#ececec" android:width="1dp" />-->
<solid android:color="#F3F3F3"/>
<!--<solid android:color="#F4F4F4" />-->
</shape>
</item>
</selector>
search_edit_bg:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_window_focused="false">
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<!--<solid android:color="#F4F4F4" />-->
<corners
android:topLeftRadius="3dp"
android:bottomLeftRadius="3dp"/>
<solid android:color="#F3F3F3"/>
<!--<stroke android:color="#ffececec" android:width="1dp"/>-->
</shape>
</item>
<item