ListView(列表效果)
第一步:构建初始化
data:image/s3,"s3://crabby-images/61aab/61aab6edd770cd5d9d0044c6c33feaae10d088a1" alt="在这里插入图片描述"
第二步:创建listItem格式
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OLs29f5s-1650984462765)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220425235414969.png)]](https://img-blog.csdnimg.cn/78e2a1585ff749d7a415f94192b7bd8f.png)
第三步:创建准备得测试类
data:image/s3,"s3://crabby-images/a21da/a21dadf584dde60f443872318ee2ce87eec4fc06" alt="在这里插入图片描述"
第四步:创建视图与数据得桥梁MyAdpater并继承BaseAdapter
public class MyAdpater extends BaseAdapter {
private List<Test> testList;
private Context context;
@Override
public int getCount() {
return testList.size();
}
@Override
public Object getItem(int i) {
return null;
}
@Override
public long getItemId(int i) {
return i;
}
@Override
public View getView(int i, View view, ViewGroup viewGroup) {
ViewHolder viewHolder;
if (view == null){
viewHolder = new ViewHolder();
view= LayoutInflater.from(context).inflate(R.layout.list_item,viewGroup,false);
viewHolder.textView=view.findViewById(R.id.listItem);
view.setTag(viewHolder);
}else{
viewHolder=(ViewHolder) view.getTag();
}
viewHolder.textView.setText(testList.get(i).getName());
return view;
}
public MyAdpater(List<Test> testList, Context context) {
this.testList = testList;
this.context = context;
}
private final class ViewHolder{
TextView textView;
}
}
效果图:
data:image/s3,"s3://crabby-images/74195/74195ec0e367c186860041a7af5c547c596db34e" alt="在这里插入图片描述"
RecyclerView(灵活列表效果)
整体架构
data:image/s3,"s3://crabby-images/4ddd7/4ddd785e2df2b94df2f057a00cf46a4a31844a41" alt="在这里插入图片描述"
item代码
data:image/s3,"s3://crabby-images/ed292/ed2921faae606ca06dc65ec418e47a762bc64ecf" alt="在这里插入图片描述"
MainActivity中代码
data:image/s3,"s3://crabby-images/a0cf5/a0cf533eb1e61cc664e5f0d26733e58ff44cf18d" alt="在这里插入图片描述"
此处监听Item被点击与ListView有所差别,MyAdpater中代码
public class MyAdpater extends RecyclerView.Adapter<MyAdpater.MyViewHolder> {
private List<Test> testList;
private Context context;
@NonNull
@Override
public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view=View.inflate(context,R.layout.recyclerview_item,null);
return new MyViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
holder.tv.setText(testList.get(position).getName());
}
@Override
public int getItemCount() {
return testList == null? 0 : testList.size();
}
public class MyViewHolder extends RecyclerView.ViewHolder {
private TextView tv;
public MyViewHolder(@NonNull View itemView) {
super(itemView);
tv=itemView.findViewById(R.id.listItem);
itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (mOnItemClickListener !=null ){
mOnItemClickListener.onRecyclerItemClick(getAdapterPosition());
}
}
});
}
}
public MyAdpater(List<Test> testList, Context context) {
this.testList = testList;
this.context = context;
}
private OnRcyclerItemClickListener mOnItemClickListener;
public void setRecyclerItemClickListener(OnRcyclerItemClickListener listener){
mOnItemClickListener =listener;
}
public interface OnRcyclerItemClickListener{
void onRecyclerItemClick(int postion);
}
}
动画类型
- 逐帧动画(frame-by-frame animation)
- 补间动画(tweened animation)
- 属性动画(property animation)
逐帧动画
animation-list
data:image/s3,"s3://crabby-images/dfb03/dfb0356da0fc6b8962add7da5427cfb51d8a1adc" alt="在这里插入图片描述"
动画的启动和停止
//获取动画的Drawable资源
AnimationDrawable anim=(AnimationDrawable)relativeLayout.getBackground();
//启动动画
anim.start();
//停止动画
anim.stop;
data:image/s3,"s3://crabby-images/fa6c5/fa6c5087330d7bda6e0c1df1225bd47e2106ec8e" alt="在这里插入图片描述"
补间动画
- alpha 透明度
- rotate 旋转
- scale 缩放
- translate 平移
透明 data:image/s3,"s3://crabby-images/8d411/8d411dba0543483fb82639e5f2ea40b453ef5bb0" alt="在这里插入图片描述"
旋转
data:image/s3,"s3://crabby-images/e6e2d/e6e2de158bdd036de8657de582edc5a501c4fa73" alt="在这里插入图片描述"
缩放 data:image/s3,"s3://crabby-images/9703a/9703a07a67866463444ca10b1360315781237fb1" alt="在这里插入图片描述"
平移
data:image/s3,"s3://crabby-images/2f606/2f606c786ce508e490d79b5be988cb8a9dcd0b6d" alt="在这里插入图片描述"
activtiy
data:image/s3,"s3://crabby-images/5c950/5c9505b12ae43eb09b329ca0806d8b6c62b3a504" alt="在这里插入图片描述"
最终效果
data:image/s3,"s3://crabby-images/2bcae/2bcae7bfcdecea3e05b72dffedea9dc8ebe1de5b" alt="在这里插入图片描述"
属性动画
ValueAnimator
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-T03V17on-1650984462770)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220426222707424.png)]](https://img-blog.csdnimg.cn/e482c4c7d2114e2e9dceb8a91045a21c.png)
ObjectAnimator
data:image/s3,"s3://crabby-images/65f3b/65f3b0e9ac021ee6cc7f9e6a90773170a14f0c36" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/fa543/fa54314bbf93d4ee6af3053df88344667953df8c" alt="在这里插入图片描述"
监听器
onAnimationStart()动画开始的时候调用
onAnimationEnd()动画结束的时候调用
onAnimationCancel()动画被取消的时候调用
onAnimationRepeat()动画重复执行的时候调用
data:image/s3,"s3://crabby-images/4aec0/4aec06c2f1377f0d3d5ca153e999173cf099a8f5" alt="在这里插入图片描述" 此处主要效果就是字体渐渐显示出来,由透明转显示
|