package bw.com.test_all.demo05;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import java.util.ArrayList;
import java.util.List;
import bw.com.test_all.R;
/**
* 1, (25分) 实现ViewPager + Fragment ,切换页面, 3个Fragment;
2, (25分) 第一个Fragment中, 通过xUtils 获取网络数据, 展示到RecyclerView
地址: http://www.qubaobei.com/ios/cf/dish_list.php?stage_id=1&limit=20&page=1
解析字段: title , pic
3, (25分) 第二个Fragment 中, 属性动画, 实现机器人的: 缩放X , 移动Y , 渐 变, 旋转, 集合的效果
4, (25分) 第三个Fragment 中, 通过自定义组合控件, 实现TitleView 的效果,如 下图所示
点击按钮, 弹出吐司
*/
public class Test05Activity extends AppCompatActivity {
private ViewPager mVp;//控件
private List<Fragment> data;
private MyAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_test05);
mVp = (ViewPager) findViewById(R.id.view_pager_id);
//构建ViewPager的数据源
data = new ArrayList<>();
data.add(new TestFragment_01());
data.add(new TestFragment_02());
data.add(new TestFragment_03());
//设置适配器
adapter = new MyAdapter(getSupportFragmentManager());
mVp.setAdapter(adapter);
}
//自定义的适配器
class MyAdapter extends FragmentPagerAdapter
{
public MyAdapter(FragmentManager fm) {
super(fm);
}
@Override
public Fragment getItem(int position) {
return data.get(position);
}
@Override
public int getCount() {
return data.size();
}
}
}
package bw.com.test_all.demo05;
import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import org.xutils.x;
import java.util.List;
import bw.com.test_all.R;
/**
* RecyclerView 适配器
* Created by Administrator on 2017/12/2.
*/
public class RvAdapter extends RecyclerView.Adapter<RvAdapter.ViewHolder> {
private List<CookBook.DataBean> data;
private Context context;
public RvAdapter(Context context,List<CookBook.DataBean> data)
{
this.context = context;
this.data = data;
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//加载每个条目显示的页面
View view = LayoutInflater.from(context).inflate(R.layout.item_rv,parent,false);
ViewHolder viewHolder = new ViewHolder(view);
return viewHolder;
}
@Override
public void onBindViewHolder(ViewHolder holder, int position) {
//赋值的操作
holder.tv.setText(data.get(position).getTitle());
//加载网络的图片
// ImageOptions options = new ImageOptions.Builder()
// .setFailureDrawableId(R.mipmap.ic_launcher)
// .setLoadingDrawableId(R.mipmap.ic_launcher)
// .setCircular(true)
// .setUseMemCache(true)
// .build();
// x.image().bind(holder.iv,data.get(position).getPic(),options);
x.image().bind(holder.iv,data.get(position).getPic());//图片没有任何的要求
}
@Override
public int getItemCount() {
return data.size();
}
class ViewHolder extends RecyclerView.ViewHolder
{
private ImageView iv;
private TextView tv;
public ViewHolder(View itemView) {
super(itemView);
this.iv = (ImageView) itemView.findViewById(R.id.iv_id);
this.tv = (TextView) itemView.findViewById(R.id.tv_id);
}
}
}
package bw.com.test_all.demo05;
import android.content.Context;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;
import bw.com.test_all.R;
/**
* Created by Administrator on 2017/12/2.
*/
public class CustomView extends LinearLayout {
private ImageView iv;
private TextView tv;
private Button but;
public CustomView(Context context) {
super(context);
}
public CustomView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
//引入页面, 和当前的View 绑定在一起 -- this
LayoutInflater.from(getContext()).inflate(R.layout.custom_view,this);
//从引入的页面中, 得到控件
iv = (ImageView) findViewById(R.id.iv_id);
tv = (TextView) findViewById(R.id.tv_id);
but = (Button) findViewById(R.id.but_id);
//为控件设置监听器
but.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(getContext(),"你点击了按钮",Toast.LENGTH_LONG).show();
}
});
}
//如果需要在调用者中设置监听器, 则需要向外提供一个公共的方法, 把当前的对象外放出去
// public Button getButton()
// {
// return this.but;
// }
}
package bw.com.test_all.demo05;
import java.util.List;
/**
* Created by Administrator on 2017/12/2.
*/
public class CookBook {
/**
* ret : 1
* data : [{"id":"8289","title":"油焖大虾","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/9/8289.jpg","collect_num":"1646","food_str":"大虾 葱 生姜 植物油 料酒","num":1646},{"id":"2127","title":"四川回锅肉","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/3/2127.jpg","collect_num":"1581","food_str":"猪肉 青蒜 青椒 红椒 姜片","num":1581},{"id":"30630","title":"超简单芒果布丁","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/31/30630.jpg","collect_num":"1514","food_str":"QQ糖 牛奶 芒果","num":1514},{"id":"9073","title":"家常红烧鱼","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/10/9073.jpg","collect_num":"1416","food_str":"鲜鱼 姜 葱 蒜 花椒","num":1416},{"id":"10097","title":"家常煎豆腐","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/11/10097.jpg","collect_num":"1400","food_str":"豆腐 新鲜红椒 青椒 葱花 油","num":1400},{"id":"10509","title":"水煮肉片","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/11/10509.jpg","collect_num":"1334","food_str":"瘦猪肉 生菜 豆瓣酱 干辣椒 花椒","num":1334},{"id":"46968","title":"红糖苹果银耳汤","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/47/46968.jpg","collect_num":"1240","food_str":"银耳 苹果 红糖","num":1240},{"id":"10191","title":"麻婆豆腐","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/11/10191.jpg","collect_num":"1208","food_str":"豆腐 肉末 生抽 白糖 芝麻油","num":1208},{"id":"2372","title":"皮蛋瘦肉粥","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/3/2372.jpg","collect_num":"1138","food_str":"大米 皮蛋 猪肉 油条 香葱","num":1138},{"id":"2166","title":"蚂蚁上树","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/3/2166.jpg","collect_num":"1134","food_str":"红薯粉 肉 姜 蒜 花椒","num":1134},{"id":"2262","title":"糖醋肉","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/3/2262.jpg","collect_num":"1070","food_str":"猪肉 红椒 黄椒 洋葱 蛋清","num":1070},{"id":"9971","title":"鱼香豆腐","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/10/9971.jpg","collect_num":"1001","food_str":"豆腐 木耳 胡萝卜 香葱 番茄酱","num":1001},{"id":"10172","title":"干煸四季豆","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/11/10172.jpg","collect_num":"986","food_str":"四季豆 干辣椒 蒜头 酱油 糖","num":986},{"id":"2685","title":"胡萝卜肉末蒸蛋","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/3/2685.jpg","collect_num":"906","food_str":"胡萝卜 肉 蛋 生抽 盐","num":906},{"id":"9972","title":"虎皮青椒","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/10/9972.jpg","collect_num":"885","food_str":"青辣椒 大蒜 香醋 白糖 生抽","num":885},{"id":"10437","title":"叉烧排骨","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/11/10437.jpg","collect_num":"792","food_str":"排骨 李锦记叉烧酱 植物油 清水 油菜","num":792},{"id":"2892","title":"\u201c五行\u201d彩蔬汤","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/3/2892.jpg","collect_num":"755","food_str":"黑木耳 玉米 牛蒡 胡萝卜 西兰花","num":755},{"id":"2348","title":"麻辣肉丝面","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/3/2348.jpg","collect_num":"751","food_str":"面条 肉丝 淀粉 酱油 辣椒","num":751},{"id":"33783","title":"美人豆浆","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/34/33783.jpg","collect_num":"750","food_str":"黄豆 红豆 绿豆 黑豆 黑米","num":750},{"id":"10044","title":"土豆炖翅根","pic":"http://www.qubaobei.com/ios/cf/uploadfile/132/11/10044.jpg","collect_num":"749","food_str":"土豆 翅根 葱 姜 料酒","num":749}]
*/
private int ret;
private List<DataBean> data;
public int getRet() {
return ret;
}
public void setRet(int ret) {
this.ret = ret;
}
public List<DataBean> getData() {
return data;
}
public void setData(List<DataBean> data) {
this.data = data;
}
public static class DataBean {
/**
* id : 8289
* title : 油焖大虾
* pic : http://www.qubaobei.com/ios/cf/uploadfile/132/9/8289.jpg
* collect_num : 1646
* food_str : 大虾 葱 生姜 植物油 料酒
* num : 1646
*/
private String id;
private String title;
private String pic;
private String collect_num;
private String food_str;
private int num;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getPic() {
return pic;
}
public void setPic(String pic) {
this.pic = pic;
}
public String getCollect_num() {
return collect_num;
}
public void setCollect_num(String collect_num) {
this.collect_num = collect_num;
}
public String getFood_str() {
return food_str;
}
public void setFood_str(String food_str) {
this.food_str = food_str;
}
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
}
}
package bw.com.test_all.demo05;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import com.google.gson.Gson;
import org.xutils.common.Callback;
import org.xutils.http.RequestParams;
import org.xutils.x;
import java.util.List;
import bw.com.test_all.R;
public class TestFragment_01 extends Fragment {
private String url = "http://www.qubaobei.com/ios/cf/dish_list.php?stage_id=1&limit=20&page=1";//地址
private RecyclerView mRv;//控件
@Override
public View onCreateView(LayoutInflater inflater, final ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_test_fragment_01, container, false);
//初始化控件
mRv = (RecyclerView) view.findViewById(R.id.recycle_view_id);
//设置RecyclerView显示的模式 -- 必须设置 (如果不设置, 看不到内容)
LinearLayoutManager manager = new LinearLayoutManager(getContext(),LinearLayoutManager.VERTICAL,false);
mRv.setLayoutManager(manager);
//通过xUtils 获取网络数据, 展示到RecycleView中
/**
* 1, 导入依赖
* 2, 在清单文件中设置权限: 网络权限, 读写sd卡的权限
* 3, 自定义Applcation 的子类, 初始化xUtils, 并且在清单文件的<applicaion adnroid:name=""/>
*/
RequestParams params = new RequestParams(url);//设置请求的参数
x.http().get(params, new Callback.CommonCallback<String>() {
@Override
public void onSuccess(String s){
//解析数据, 得到数据源
CookBook cookBook = new Gson().fromJson(s,CookBook.class);
List<CookBook.DataBean> dataBean = cookBook.getData();
//定义适配器, 显示数据
RvAdapter adapter = new RvAdapter(getContext(),dataBean);
mRv.setAdapter(adapter);
}
@Override
public void onError(Throwable throwable, boolean b) { }
@Override
public void onCancelled(CancelledException e) {}
@Override
public void onFinished() {}
});
return view;
}
}
package bw.com.test_all.demo05;
import android.animation.AnimatorSet;
import android.animation.ObjectAnimator;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.AccelerateDecelerateInterpolator;
import android.widget.Button;
import android.widget.ImageView;
import bw.com.test_all.R;
public class TestFragment_02 extends Fragment implements View.OnClickListener {
private Button but_01;
private Button but_02;
private Button but_03;
private Button but_04;
private Button but_05;
private ImageView iv_id;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_test_fragment_02, container, false);
initView(view);
return view;
}
private void initView(View view) {
but_01 = (Button) view.findViewById(R.id.but_01);
but_02 = (Button) view.findViewById(R.id.but_02);
but_03 = (Button) view.findViewById(R.id.but_03);
but_04 = (Button) view.findViewById(R.id.but_04);
but_05 = (Button) view.findViewById(R.id.but_05);
iv_id = (ImageView) view.findViewById(R.id.iv_id);
but_01.setOnClickListener(this);
but_02.setOnClickListener(this);
but_03.setOnClickListener(this);
but_04.setOnClickListener(this);
but_05.setOnClickListener(this);
}
@Override
//点击按钮, 切换动画
public void onClick(View view) {
switch (view.getId())
{
case R.id.but_01:
//透明度的改变 -- 渐变
//1, 定义动画 -- 指明显为那个控件设置动画
//执行该动画的对象, 动画的属性名称, 动画的属性值
ObjectAnimator animator1 = ObjectAnimator.ofFloat(iv_id,"alpha",1.0f,0.0f);
//2, 设置持续时间
animator1.setDuration(3000);
//3, 启动动画
animator1.start();
break;
case R.id.but_02:
//缩放
ObjectAnimator animator2 = ObjectAnimator.ofFloat(iv_id,"scaleX",0,4);
animator2.setDuration(5000);
animator2.start();
break;
case R.id.but_03:
//旋转
ObjectAnimator animator3 = ObjectAnimator.ofFloat(iv_id,"rotation",0,720);
animator3.setDuration(5000);
animator3.start();
break;
case R.id.but_04:
ObjectAnimator animator4 = ObjectAnimator.ofFloat(iv_id,"translationY",0,500);
animator4.setDuration(10000);
animator4.start();
break;
case R.id.but_05:
//1, 得到属性动画集合
AnimatorSet animatorSet = new AnimatorSet();
//2, 创建要加入的动画
ObjectAnimator animator5 = ObjectAnimator.ofFloat(iv_id,"translationY",0,500,800,600,700);
ObjectAnimator animator6 = ObjectAnimator.ofFloat(iv_id,"rotation",0,720);
//3, 把动画加入集合中
//第一种方式:
// List<Animator> list = new ArrayList<>();
// list.add(animator5);
// list.add(animator6);
// animatorSet.playTogether(list);//一起执行
// animatorSet.playSequentially(list);//依次执行
//第二种方式 --- 注意: 同一个动画, 只能使用一次
//播放, 在...之前, 在...之后, 一起
animatorSet.play(animator5).with(animator6);
animatorSet.setDuration(5000);//设置持续时间
//https://www.2cto.com/kf/201703/611844.html
animatorSet.setInterpolator(new AccelerateDecelerateInterpolator());//设置插值器-- 先慢后快
//4, 启动动画
animatorSet.start();
break;
}
}
}
package bw.com.test_all.demo05;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import bw.com.test_all.R;
public class TestFragment_03 extends Fragment {
private CustomView mCv;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_test_fragment_03, container, false);
//设置监听器的第二种方法
// mCv = (CustomView) view.findViewById(R.id.cv_id);
// mCv.getButton().setOnClickListener(new View.OnClickListener() {
// @Override
// public void onClick(View v) {
//
// }
// });
return view;
}
}