还是比较简单的,然后进入到MapWeatherActivity
ImageView ivSearch;//搜索图标
@BindView(R.id.ed_search)
EditText edSearch;//搜索输入框
@BindView(R.id.iv_close)
ImageView ivClose;//关闭图标
@BindView(R.id.lay_search)
RelativeLayout laySearch;//搜索布局
定义一个控制变量
private AutoTransition autoTransition;//过渡动画
private Animation bigShowAnim;//放大显示
private Animation smallHideAnim;//缩小隐藏
private int width;//屏幕宽度
private boolean isOpen = false;//顶部搜索布局的状态
然后在点击方法中增加需求点击的控件id
因为展开之后是不能设置固定的宽度,所以需要获取屏幕的宽度,在initView方法中写入
//获取屏幕宽高
WindowManager manager = getWindowManager();
DisplayMetrics metrics = new DisplayMetrics();
manager.getDefaultDisplay().getMetrics(metrics);
width = metrics.widthPixels; //获取屏幕的宽度 像素
而屏幕的宽度是px又需要转换为dip,所以要写转换的方法;
// dp 转成 px
private int dip2px(float dpVale) {
final float scale = getResources().getDisplayMetrics().density;
return (int) (dpVale * scale + 0.5f);
}
// px 转成 dp
private int px2dip(float pxValue) {
final float scale = context.getResources().getDisplayMetrics().density;
return (int) (pxValue / scale + 0.5f);
}
然后写一个过渡动画的方法,会在展开和收缩的方法中调用
//过渡动画
@TargetApi(Build.VERSION_CODES.KITKAT)
private void beginDelayedTransition(ViewGroup view) {
autoTransition = new AutoTransition();
autoTransition.setDuration(500);
TransitionManager.beginDelayedTransition(view,autoTransition);
}
现在可以来写具体的关于点击展开和收缩的方法了。
/**
- 展开
*/
public void initExpand() {
isOpen = true;
edSearch.setVisibility(View.VISIBLE);//显示输入框
ivClose.setVisibility(View.VISIBLE);//显示关闭按钮
LinearLayout.LayoutParams LayoutParams =