(本节过于简单,只是为了包吃连贯性,非小小白建议跳过!)

1.BB

入门教程在上一年的11月份就写完了,到现在也有差不多9个多月了,当时由于自己工作上的原因,没有写个实战的项目,很是遗憾 最近项目终于也差不多快收尾了,可能会稍微有时间,所以还是决定把这个遗憾给填补上 毕竟入门教程学了那么多东西,肯定要写个实战项目整合下,鉴于看入门系列的都是初学者和自己时间的关系,这个项目就设定为个简单的看妹子的应用DrySister(干妹子)之所以叫这个名字,请听娓娓道来妹子图片来源于Gank.io,Gank发音有"干客",简称干,本来想直接叫GanMeizi的,后来看到Github上已经有人用了,后来手多谷歌翻译了下干妹子,然后翻译的结果是DrySister,索性就用这个名字吧!没什么不对,是吧!

另外选这个作为实战项目的原因是看妹子养眼,比如的AS

背景插件是Sexy Editor

右面和Subline Text预览相似的插件是CodeGlance

AS的MD主题插件是Material Theme UI

别问怎么装插件这种问题

说回来这个实战项目想怎么搞法,关于用Gank.io接口做接口的小项目,在Github上面可以找到很多个,然后都是用很酷炫的框架Rx,Retrofit,Glide,Butterknife等等 也可以直接写个MVP模式BufferKnife + Dagger2 + Retrofit + Rx + retrolambda + Glide +Relam的项目,但是没太大意义,想从最简单的Handler开始,然后慢慢加东西,一点点优化,就好像个项目迭代一样,而不是写完就把这个项目丢到一边,这样就完了,其实优化和重构项目的时候会学到更多,真的 好吧,那就从Hello world!开始吧!

就问 嗨不嗨?

好吧,说笑,不过本节还是比较简单的,就写个简单的显示网络图片的雏形,后面再一点点迭代优化,什么乱七八糟的都会加上去的!另外,项目所有的代码都会托管到Github上,引入分支管理,master分支作为正式的大版本,develop作为日常的开发分支,加新东西在develop分支上开辟功能分支,编写完毕后合并回develop分支 大概就这样吧,具体的自己慢慢看!


1.创建github仓库

在AS上创建个新的项目,命名为DrySister,包名com.coderpig.drysister来到项目根目录下打开git bash,键入下述命令创建Git仓库git initGithub上创建个新的仓库,命名为DrySister,接着配置下远程仓库,键入命令git remote add origin git@github.com:coder-pig/DrySister.gitpull下master分支,然后add,commit,push到github仓库,在接着,对.gitignore文件进行了修改,创建了个新的develop分支,然后在该分支上提交,然后合并到master分支, 关于Git的准备工作就差不多了


2.开始编写程序

在本地开辟个develop分支,然后开始编写代码,布局很简单,个显示妹子图的ImageView和Button,activity_main.xml接着编写个简单的下载加载图片的类,PictureLoader.java逻辑很简单,线程将输入流转成字节数组,转换完毕 handler 里 decodeByteArray将字节数组解码成bitmap,然后显示~

public class PictureLoader {
    private ImageView loadImg;
    private String imgUrl;
    private byte[] picByte;
    Handler handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            super.handleMessage(msg);
            if (msg.what == 0x123) {
                if (picByte != null) {
                    Bitmap bitmap = BitmapFactory.decodeByteArray(picByte, 0, picByte.length);
                    loadImg.setImageBitmap(bitmap);
                }
            }
        }
    };
    public void load(ImageView loadImg, String imgUrl) {
        this.loadImg = loadImg;
        this.imgUrl = imgUrl;
        Drawable drawable = loadImg.getDrawable();
        if(drawable != null && drawable instanceof BitmapDrawable) {
            Bitmap bitmap = ((BitmapDrawable)drawable).getBitmap();
            if(bitmap != null && !bitmap.isRecycled()) {
                bitmap.recycle();
            }
        }
        new Thread(runnable).start();
    }
    Runnable runnable = new Runnable() {
        @Override
        public void run() {
            try {
                URL url = new URL(imgUrl);
                HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                conn.setRequestMethod("GET");
                conn.setReadTimeout(10000);
                if (conn.getResponseCode() == 200) {
                    InputStream in = conn.getInputStream();
                    ByteArrayOutputStream out = new ByteArrayOutputStream();
                    byte[] bytes = new byte[1024];
                    int length = -1;
                    while ((length = in.read(bytes)) != -1) {
                        out.write(bytes, 0, length);
                    }
                    picByte = out.toByteArray();
                    in.close();
                    out.close();
                    handler.sendEmptyMessage(0x123);
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    };
}

然后是MainActivity.java,也很简单,就不解释了

public class MainActivity extends AppCompatActivity implements View.OnClickListener {
    private Button showBtn;
    private ImageView showImg;
    private ArrayList<String> urls;
    private int curPos = 0;
    private PictureLoader loader;
    @Override protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        loader = new PictureLoader();
        initData();
        initUI();
    }
    private void initData() {
        urls = new ArrayList<>();
        urls.add("http://ww4.sinaimg.cn/large/610dc034jw1f6ipaai7wgj20dw0kugp4.jpg");
        urls.add("http://ww3.sinaimg.cn/large/610dc034jw1f6gcxc1t7vj20hs0hsgo1.jpg");
        urls.add("http://ww4.sinaimg.cn/large/610dc034jw1f6f5ktcyk0j20u011hacg.jpg");
        urls.add("http://ww1.sinaimg.cn/large/610dc034jw1f6e1f1qmg3j20u00u0djp.jpg");
        urls.add("http://ww3.sinaimg.cn/large/610dc034jw1f6aipo68yvj20qo0qoaee.jpg");
        urls.add("http://ww3.sinaimg.cn/large/610dc034jw1f69c9e22xjj20u011hjuu.jpg");
        urls.add("http://ww3.sinaimg.cn/large/610dc034jw1f689lmaf7qj20u00u00v7.jpg");
        urls.add("http://ww3.sinaimg.cn/large/c85e4a5cjw1f671i8gt1rj20vy0vydsz.jpg");
        urls.add("http://ww2.sinaimg.cn/large/610dc034jw1f65f0oqodoj20qo0hntc9.jpg");
        urls.add("http://ww2.sinaimg.cn/large/c85e4a5cgw1f62hzfvzwwj20hs0qogpo.jpg");
    }
    private void initUI() {
        showBtn = (Button) findViewById(R.id.btn_show);
        showImg = (ImageView) findViewById(R.id.img_show);
        showBtn.setOnClickListener(this);
    }
    @Override public void onClick(View v) {
        switch (v.getId()) {
            case R.id.btn_show:
                if (curPos > 9) {
                    curPos = 0;
                }
                loader.load(showImg, urls.get(curPos));
                curPos++;
                break;
        }
    }
}

3.运行效果图

(看手机屏幕用的是Chrome的插件Vysor,录Gif用得ScreenToGif)


4.小结

先说说本节做了些什么

  • 1.创建了DrySister项目,并把项目托管到Github上
  • 2.写了很简单的显示网络图片的功能

待优化与想加的东西

  • 1.代码中的图片来源是写死的,每天能看到的图片都是那么几张,Gank提供的接口没用到
  • 2.图片加载类只有加载网络的,应该加上加载本地图片的

下节要做的事

  • 1.用Android自带抠脚解析器解析接口数据,获取图片显示的数据源
  • 2.优化图片加载类

本节代码下载GithubDrySister