列表:FontAwesome/iconfont/高斯模糊

Android-Training-Course

http://hukai.me/android-training-course-in-chinese/index.html

Android字体度量(FontMetrics)

http://www.gimoo.net/t/1508/55c1933651e00.html

Android Font Basic

http://my.oschina.net/xesam/blog/386159

FontAwesome 图标被视为字符

http://fortawesome.github.io/Font-Awesome/icons/

iconfont取代imageView来展示图标

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0627/3115.html

高斯模糊效果实现方案及性能对比

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0831/3389.html

安卓的模糊视图-500px的关于背景模糊的技术分享

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0403/2692.html

android图片处理之图像模糊

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0728/3229.html

FlyRefresh——让人眼前一亮的下拉刷新

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0603/2987.html

听FaceBook工程师讲自定义ViewGroup

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0524/2920.html

Android实现双进程守护

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0521/2903.html

LeakCanary开源项目(使用及原理github项目文档的翻译)

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0510/2860.html

Google推荐的图片加载库Glide介绍

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0327/2650.html

Android矢量化VectorDrawable支持SVG

http://item.congci.com/item/android-shiliang-hua-vectordrawable-zhichi-svg

Android动画插值器

http://inloop.github.io/interpolator/

NotificationManagerService使用详解与原理分析

http://blog.csdn.net/yihongyuelan/article/details/40977323
http://blog.csdn.net/yihongyuelan/article/details/41084165

分享下android中路径动画svg格式的(一)

1,下载生成svg格式的工具Adobe Illustrator CS5,下载地址:http://pan.baidu.com/s/1hqkz9cg
在线svg格式编辑的地址:http://editor.method.ac/
20 个有用的 SVG 工具,提供更好的图像处理:http://www.oschina.net/translate/20-useful-svg-tools-for-better-graphics
2,引用github上的库:https://github.com/geftimov/android-pathview,demo下载地址:http://pan.baidu.com/s/1i3o1qRj
3,开发工具使用android studio
效果图:
分享下android中路径动画svg格式的 - dongyangzhang - 软件开发
4,使用方法直接看代码:

public class MainActivity extends ActionBarActivity {

   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      final ViewPager viewpager = (ViewPager) findViewById(R.id.viewpager);
      final ScreenSlidePagerAdapter screenSlidePagerAdapter = new ScreenSlidePagerAdapter(getSupportFragmentManager());
      viewpager.setAdapter(screenSlidePagerAdapter);
      viewpager.setPageTransformer(true, new CustomTransformer());
   }

   private class ScreenSlidePagerAdapter extends FragmentStatePagerAdapter {
      public ScreenSlidePagerAdapter(FragmentManager fm) {
         super(fm);
      }

      @Override
      public Fragment getItem(int position) {
         if (position == 0) {
            return new IssuesFragment();
         }
         if (position == 1) {
            return new IssuesFragment();
         }
         if (position == 2) {
            return new LogoutFragment();
         }
         return new SettingsFragment();
      }

      @Override
      public int getCount() {
         return 2;
      }
   }

   private class CustomTransformer implements ViewPager.PageTransformer {


      @Override
      public void transformPage(View page, float position) {
         if (position < -1 || position > 1) { // [-Infinity,-1)
            // This page is way off-screen to the left.
            page.setAlpha(0);
            return;
         }
         final float abs = 1 - Math.abs(position);
         final PathView pathView = (PathView) page.findViewById(R.id.pathView);
         pathView.setPercentage(abs);
      }
   }

}


public class IssuesFragment extends Fragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View inflate = inflater.inflate(R.layout.fragment_issues, container, false);
        final PathView pathView = (PathView) inflate.findViewById(R.id.pathView);
        pathView.getPathAnimator().
                delay(100).
                duration(1500).
                interpolator(new AccelerateDecelerateInterpolator()).
                start();
        pathView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                pathView.getPathAnimator().
                        delay(100).
                        duration(1500).
                        interpolator(new AccelerateDecelerateInterpolator()).
                        start();
            }
        });
        return inflate;
    }
}

xml

"http://schemas.android.com/apk/res/android"
                xmlns:tools="http://schemas.android.com/tools"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                tools:context=".MainActivity">

    "@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>



"1.0" encoding="utf-8"?>
"http://schemas.android.com/apk/res/android"
              android:orientation="vertical"
              xmlns:app="http://schemas.android.com/apk/res-auto"
              android:layout_width="match_parent"
              android:gravity="center"
              android:layout_height="match_parent">

    "@+id/pathView"
        android:layout_width="match_parent"
        app:pathColor="@android:color/holo_red_dark"
        app:pathWidth="3"
        app:svg="@raw/test"
        android:layout_height="match_parent"/>

5,最后写下生成文字path的简单操作:

①,打开Adobe Illustrator CS5,新建文件,选择文字直接写文字

②,使用选择工具选中文字,执行工具栏中文字–》创建轮廓

③,执行工具栏中效果–》路径查找器–》轮廓

④,保存为svg格式就行,然后添加到android工程中就可以直接使用了

新玩具:Android里的DataBinding

你可能感兴趣的:(Android)