android 自定义gridview(导航)
最近又重新做回安卓,做了个小项目。下绝心使用android studio,通过这一回实战,终于用上了。综合了前人的经验,搞了个自己满意的导航界面,用的是gridview。

代码:
package com.cquni.control; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.Rect; import android.graphics.RectF; import android.util.AttributeSet; import android.widget.AbsListView; import android.widget.GridView; import com.cquni.smartwcs.R; /* 用来做导航的自定义GridView */ public class NavigateGridView extends GridView { private Bitmap background; private int img_Id = R.drawable.gridbg; public NavigateGridView(Context context) { super(context); background = BitmapFactory.decodeResource(getResources(), img_Id); } public NavigateGridView(Context context, AttributeSet attrs) { super(context, attrs); background = BitmapFactory.decodeResource(getResources(), img_Id); } public NavigateGridView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); background = BitmapFactory.decodeResource(getResources(), img_Id); } /* 高度实现自适应 */ @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { int heightSpec; if (getLayoutParams().height == AbsListView.LayoutParams.WRAP_CONTENT) { heightSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST); } else { heightSpec = heightMeasureSpec; } super.onMeasure(widthMeasureSpec, heightSpec); } /* 拉伸背景图 */ @Override protected void dispatchDraw(Canvas canvas) { int count = getChildCount(); int top = count > 0 ? getChildAt(0).getTop() : 0; int backgroundWidth = background.getWidth(); int backgroundHeight = background.getHeight(); int width = getWidth(); int height = getHeight(); final Rect src = new Rect(); src.left = 0; src.top = 0; src.right = backgroundWidth; src.bottom = backgroundHeight; for (int y = top; y < height; y += backgroundHeight) { RectF dst = new RectF(); dst.left = 0; dst.top = y; dst.right = width; dst.bottom = (y + backgroundHeight) / 2; canvas.drawBitmap(background, src, dst, null); } super.dispatchDraw(canvas); } }
gridview改进:
gv.setSelector(new ColorDrawable(Color.TRANSPARENT));
选中item时的动画
ImageView itemImg = arg1.findViewById(R.id.ItemImageView);
Animation animation = AnimationUtils.loadAnimation(MainActivity.this, R.anim.item_img);
itemImg.startAnimation(animation);
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <alpha android:fromAlpha="0.5" android:toAlpha="1.0" android:duration="50"/> </set>
 
作者:数据酷软件
出处:https://www.cnblogs.com/datacool/p/datac.html
关于作者:20年编程从业经验,持续关注MES/ERP/POS/WMS/工业自动化
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明。
联系方式: qq:71008973;wx:6857740733
基于人脸识别的考勤系统 地址: https://gitee.com/afeng124/viewface_attendance_ext
自己开发安卓应用框架 地址: https://gitee.com/afeng124/android-app-frame
WPOS(warehouse+pos) 后台演示地址: http://47.239.106.75:8080/

 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号