}
现在可以来写具体的关于点击展开和收缩的方法了。
/**
- 展开
*/
public void initExpand() {
isOpen = true;
edSearch.setVisibility(View.VISIBLE);//显示输入框
ivClose.setVisibility(View.VISIBLE);//显示关闭按钮
LinearLayout.LayoutParams LayoutParams = (LinearLayout.LayoutParams) laySearch.getLayoutParams();
LayoutParams.width = dip2px(px2dip(width) - 24);//设置展开的宽度
LayoutParams.setMargins(dip2px(0), dip2px(0), dip2px(0), dip2px(0));
laySearch.setPadding(14, 0, 14, 0);
laySearch.setLayoutParams(LayoutParams);
//开始动画
beginDelayedTransition(laySearch);
if (markerLatitude != 0) {//手动定位时
btnAutoLocation.hide();//隐藏自动定位按钮
}
}
这里做一下简单的说明LayoutParams.width = dip2px(px2dip(width) - 24);//设置展开的宽度这里我先将屏幕的宽由px转dp,然后剪去24,24就是屏幕左右各12的边距,然后再转成px赋值给LayoutParams.width,这样LayoutParams就知道我这个控件到时候要展开多大了。而我在开始动画的时候也加了一个对于定位按钮的判断,因为这个控件和定位按钮在同一水平线上,又因为底层的布局用的是FrameLayout,所以会出现覆盖的情况,这并不是我想要的,所以我加了一个控制,如果展开的时候处于手动定位则隐藏自动定位按钮,当然我也在收缩的方法里面做了相应的处理,下面来看收缩的方法。
/**
- 收缩
*/
private void initClose() {
isOpen = false;
edSearch.setVisibility(View.GONE);
edSearch.setText(“”);
ivClose.setVisibility(View.GONE);
LinearLayout.LayoutParams LayoutParams = (LinearLayout.LayoutParams) laySearch.getLayoutParams();
LayoutParams.width = dip2px(48);
LayoutParams.height = dip2px(48);
LayoutParams.setMargins(dip2px(0), dip2px(0), dip2px(0), dip2px(0));
laySearch.setLayoutParams(LayoutParams);
//隐藏键盘
InputMethodManager inputMethodManager = (InputMethodManager) this.getSystemService(Context.INPUT_METHOD_SERVICE);
inputMethodManager.hideSoftInputFromWindow(this.getWindow().getDecorView().getWindowToken(), 0);
//开始动画
beginDelayedTransition(laySearch);
if (markerLatitude != 0) {//自动定位
btnAutoLocation.show();//隐藏自动定位按钮
}
}
当然我们需要在点击的时候调用这两个方法
收缩的方法比较的简单一些,加了收缩时关闭键盘的动作。下面演示一下
重点注意看上边的效果。下面要对输入框做一下简单的控制,
在initView中增加
/**
- 输入法键盘的搜索监听
*/
edSearch.setOnEditorActionListener(new TextView.OnEditorActionListener() {
@Override
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
if (actionId == EditorInfo.IME_ACTION_SEARCH) {
String city = edSearch.getText().toString();
if (!TextUtils.isEmpty(city)) {
//得到输入的内容
} else {
ToastUtils.showShortToast(context, “请输入城市名称”);
}
}
return false;
}
});
这里其实就是对输入法简单的回车按钮的监听,这也是现在很多app的通用做法,不需要再自己去写一个搜索按钮来控制,而使用