├── MBLog ├── .gitignore ├── app │ ├── .gitignore │ ├── build.gradle │ ├── proguard-rules.pro │ └── src │ │ ├── androidTest │ │ └── java │ │ │ └── com │ │ │ └── mblog │ │ │ └── ApplicationTest.java │ │ ├── main │ │ ├── AndroidManifest.xml │ │ ├── java │ │ │ └── com │ │ │ │ └── mblog │ │ │ │ └── simple │ │ │ │ ├── App.java │ │ │ │ ├── MainActivity.java │ │ │ │ ├── SimpleLog.java │ │ │ │ └── SuperMbPrinter.java │ │ └── res │ │ │ ├── layout │ │ │ └── activity_main.xml │ │ │ ├── mipmap-hdpi │ │ │ └── ic_launcher.png │ │ │ ├── mipmap-mdpi │ │ │ └── ic_launcher.png │ │ │ ├── mipmap-xhdpi │ │ │ └── ic_launcher.png │ │ │ ├── mipmap-xxhdpi │ │ │ └── ic_launcher.png │ │ │ ├── mipmap-xxxhdpi │ │ │ └── ic_launcher.png │ │ │ ├── values-w820dp │ │ │ └── dimens.xml │ │ │ └── values │ │ │ ├── colors.xml │ │ │ ├── dimens.xml │ │ │ ├── strings.xml │ │ │ └── styles.xml │ │ └── test │ │ └── java │ │ └── com │ │ └── mblog │ │ └── ExampleUnitTest.java ├── build.gradle ├── gradle.properties ├── gradle │ └── wrapper │ │ ├── gradle-wrapper.jar │ │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat ├── library │ ├── .gitignore │ ├── build.gradle │ ├── proguard-rules.pro │ └── src │ │ └── main │ │ ├── AndroidManifest.xml │ │ └── java │ │ └── sj │ │ └── mblog │ │ ├── L.java │ │ ├── MBPrinter.java │ │ ├── Printer.java │ │ └── parser │ │ ├── ArrayParser.java │ │ ├── JsonParser.java │ │ ├── ObjectParser.java │ │ ├── Parser.java │ │ ├── UrlParser.java │ │ └── XmlParser.java └── settings.gradle ├── README.md └── output ├── 666.jpg ├── app-debug.apk ├── chrome_console_log.png ├── drymartine.jpg ├── format.png ├── format_old.png └── inspect.png /MBLog/.gitignore: -------------------------------------------------------------------------------- 1 | *.iml 2 | .gradle 3 | /local.properties 4 | /.idea/workspace.xml 5 | /.idea/libraries 6 | .DS_Store 7 | /build 8 | /captures 9 | /.idea -------------------------------------------------------------------------------- /MBLog/app/.gitignore: -------------------------------------------------------------------------------- 1 | /build 2 | -------------------------------------------------------------------------------- /MBLog/app/build.gradle: -------------------------------------------------------------------------------- 1 | apply plugin: 'com.android.application' 2 | 3 | android { 4 | compileSdkVersion 23 5 | buildToolsVersion "23.0.2" 6 | 7 | defaultConfig { 8 | applicationId "com.mblog.simple" 9 | minSdkVersion 9 10 | targetSdkVersion 23 11 | versionCode 1 12 | versionName "1.0" 13 | } 14 | buildTypes { 15 | release { 16 | minifyEnabled false 17 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 18 | } 19 | } 20 | } 21 | 22 | dependencies { 23 | compile fileTree(dir: 'libs', include: ['*.jar']) 24 | testCompile 'junit:junit:4.12' 25 | compile 'com.android.support:appcompat-v7:23.2.1' 26 | compile 'com.jakewharton:butterknife:7.0.1' 27 | compile project(':library') 28 | 29 | // please use -> debugCompile 'com.facebook.stetho:stetho:1.3.1' 30 | compile 'com.facebook.stetho:stetho:1.3.1' 31 | } 32 | -------------------------------------------------------------------------------- /MBLog/app/proguard-rules.pro: -------------------------------------------------------------------------------- 1 | # Add project specific ProGuard rules here. 2 | # By default, the flags in this file are appended to flags specified 3 | # in /Users/sj/Library/Android/sdk/tools/proguard/proguard-android.txt 4 | # You can edit the include path and order by changing the proguardFiles 5 | # directive in build.gradle. 6 | # 7 | # For more details, see 8 | # http://developer.android.com/guide/developing/tools/proguard.html 9 | 10 | # Add any project specific keep options here: 11 | 12 | # If your project uses WebView with JS, uncomment the following 13 | # and specify the fully qualified class name to the JavaScript interface 14 | # class: 15 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview { 16 | # public *; 17 | #} 18 | -------------------------------------------------------------------------------- /MBLog/app/src/androidTest/java/com/mblog/ApplicationTest.java: -------------------------------------------------------------------------------- 1 | package com.mblog; 2 | 3 | import android.app.Application; 4 | import android.test.ApplicationTestCase; 5 | 6 | /** 7 | * Testing Fundamentals 8 | */ 9 | public class ApplicationTest extends ApplicationTestCase { 10 | public ApplicationTest() { 11 | super(Application.class); 12 | } 13 | } -------------------------------------------------------------------------------- /MBLog/app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 6 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | -------------------------------------------------------------------------------- /MBLog/app/src/main/java/com/mblog/simple/App.java: -------------------------------------------------------------------------------- 1 | package com.mblog.simple; 2 | 3 | import android.app.Application; 4 | 5 | import com.facebook.stetho.Stetho; 6 | 7 | import sj.mblog.L; 8 | import sj.mblog.MBPrinter; 9 | import sj.mblog.parser.JsonParser; 10 | import sj.mblog.parser.ObjectParser; 11 | import sj.mblog.parser.UrlParser; 12 | 13 | /** 14 | * Created by sj on 16/4/20. 15 | */ 16 | public class App extends Application { 17 | @Override 18 | public void onCreate() { 19 | super.onCreate(); 20 | 21 | /** 22 | * 这是非必须的 23 | * 如果你什么也不做,输出Log时默认按如下配置初始化 24 | */ 25 | L.initPrinter(new MBPrinter()) 26 | .setTag("MBLog") 27 | .setPrint(L.PRINT.MBLOG) 28 | .setParserList(new JsonParser(), new UrlParser(), new ObjectParser()); 29 | 30 | /** 31 | * 支持在程序中动态的改变print的设置 32 | */ 33 | L.setTag("MBLog"); 34 | L.setPrint(L.PRINT.MBLOG); 35 | L.setParserList(new JsonParser(), new UrlParser(), new ObjectParser()); 36 | 37 | 38 | /** 39 | * 支持chrome输出log调试 40 | * 建议使用单独的buildtype, 确保release版本不包含stetho 41 | */ 42 | initStetho(); 43 | L.initPrinter(new SuperMbPrinter()); 44 | } 45 | 46 | private void initStetho() { 47 | Stetho.initialize( 48 | Stetho.newInitializerBuilder(this) 49 | .enableDumpapp(Stetho.defaultDumperPluginsProvider(this)) 50 | .enableWebKitInspector(Stetho.defaultInspectorModulesProvider(this)) 51 | .build()); 52 | } 53 | } 54 | -------------------------------------------------------------------------------- /MBLog/app/src/main/java/com/mblog/simple/MainActivity.java: -------------------------------------------------------------------------------- 1 | package com.mblog.simple; 2 | 3 | import android.content.Intent; 4 | import android.net.Uri; 5 | import android.os.Bundle; 6 | import android.support.v7.app.AppCompatActivity; 7 | 8 | import java.util.HashMap; 9 | 10 | import butterknife.ButterKnife; 11 | import butterknife.OnClick; 12 | import sj.mblog.L; 13 | 14 | 15 | public class MainActivity extends AppCompatActivity { 16 | 17 | String url = "https://www.google.com.hk/search?q=github+w446108264+MBLog&safe=strict&biw=1280&bih=636&tbm=isch&source=lnms&sa=X&ved=0ahUKEwin2pz5457MAhWF5KYKHWTVDRsQ_AUIBygC"; 18 | 19 | String json = "{\"error_code\":\"0\",\"error_msg\":\"\",\"data\":{\"user_id\":395569,\"username\":\"\\u857e\\u9635\\u5b50\",\"avatar\":\"http:\\/\\/avatar.image.com\\/FkaM-V8n9V-jwCFHiAlQ4nDSfgg_?imageView2\\/1\\/w\\/200\\/h\\/200\",\"list\":[{\"id\":\"174979\",\"user_id\":\"395414\",\"username\":\"\\u9c81\\u742a\\u742a\\u742a\\u742a\\u742a\\u742a\\u742a\\u4e36\",\"avatar\":\"http:\\/\\/tp2.sinaimg.cn\\/2145948257\\/50\\/5722834057\\/0\",\"is_followed\":\"0\"},{\"id\":\"174935\",\"user_id\":\"395576\",\"username\":\"\\u957f\\u9888\\u9e7f\\u541b395576\",\"avatar\":\"http:\\/\\/q.qlogo.cn\\/qqapp\\/1103279332\\/1A67C53BE84BD126A3047497DF05BDCB\\/100\",\"is_followed\":\"0\"},{\"id\":\"174889\",\"user_id\":\"395504\",\"username\":\"hshjzjajajwbhzhzhw\",\"avatar\":\"http:\\/\\/tp2.sinaimg.cn\\/5112186889\\/180\\/5714551813\\/0\",\"is_followed\":\"0\"}],\"total\":1}}"; 20 | 21 | double[][] doubles = { 22 | {1.2, 1.6, 1.7, 30, 33}, 23 | {1.2, 1.6, 1.7, 30, 33}, 24 | {1.2, 1.6, 1.7, 30, 33}, 25 | {1.2, 1.6, 1.7, 30, 33} 26 | }; 27 | 28 | public class User { 29 | private String name; 30 | private String sex; 31 | User(String name, String sex) { 32 | this.name = name; 33 | this.sex = sex; 34 | } 35 | } 36 | 37 | @Override 38 | protected void onCreate(Bundle savedInstanceState) { 39 | super.onCreate(savedInstanceState); 40 | setContentView(R.layout.activity_main); 41 | ButterKnife.bind(this); 42 | } 43 | 44 | @OnClick(R.id.btn_log) void btn_log() { 45 | 46 | HashMap hashMap = new HashMap<>(); 47 | hashMap.put("1", "hashMap1"); 48 | hashMap.put("2", "hashMap2"); 49 | hashMap.put("3", "hashMap3"); 50 | hashMap.put("4", "hashMap4"); 51 | 52 | L.d("NetTest", url, "\n" + json + "\n"); 53 | 54 | L.i(2016); 55 | 56 | L.e(doubles, new User("jack", "f"), hashMap, "end"); 57 | 58 | findViewById(R.id.btn_log).postDelayed(new Runnable() { 59 | @Override 60 | public void run() { 61 | L.setPrint(L.PRINT.SYSTEM); 62 | 63 | L.i("defalut log"); 64 | } 65 | }, 1000); 66 | 67 | } 68 | 69 | @OnClick(R.id.btn_github) void btn_github() { 70 | Uri uri = Uri.parse("http://github.com/w446108264/MBLog"); 71 | Intent it = new Intent(Intent.ACTION_VIEW, uri); 72 | startActivity(it); 73 | } 74 | } 75 | -------------------------------------------------------------------------------- /MBLog/app/src/main/java/com/mblog/simple/SimpleLog.java: -------------------------------------------------------------------------------- 1 | package com.mblog.simple; 2 | 3 | import sj.mblog.L; 4 | 5 | public class SimpleLog { 6 | 7 | /** 8 | * 假如希望在MBLog上封装一层自己的log 9 | * 那么你需要额外设置最后一个方法偏移的类名 10 | */ 11 | static { 12 | L.setLastMethodClassName("com.mblog.simple.SimpleLog"); 13 | } 14 | 15 | public static void d(Object... args) { 16 | L.d(args); 17 | } 18 | 19 | public static void e(Object... args) { 20 | L.e(args); 21 | } 22 | 23 | public static void e(Throwable throwable, Object... args) { 24 | L.e(throwable, args); 25 | } 26 | 27 | public static void w(Object... args) { 28 | L.w(args); 29 | } 30 | 31 | public static void i(Object... args) { 32 | L.i(args); 33 | } 34 | 35 | public static void v(Object... args) { 36 | L.v(args); 37 | } 38 | 39 | public static void wtf(Object... args) { 40 | L.wtf(args); 41 | } 42 | } 43 | -------------------------------------------------------------------------------- /MBLog/app/src/main/java/com/mblog/simple/SuperMbPrinter.java: -------------------------------------------------------------------------------- 1 | package com.mblog.simple; 2 | 3 | import android.util.Log; 4 | 5 | import com.facebook.stetho.inspector.console.CLog; 6 | import com.facebook.stetho.inspector.console.ConsolePeerManager; 7 | import com.facebook.stetho.inspector.protocol.module.Console; 8 | 9 | import sj.mblog.MBPrinter; 10 | 11 | /** 12 | * Created by sj on 16/4/25. 13 | */ 14 | public class SuperMbPrinter extends MBPrinter { 15 | 16 | ConsolePeerManager sPeerManager; 17 | 18 | public SuperMbPrinter() { 19 | sPeerManager = ConsolePeerManager.getInstanceOrNull(); 20 | } 21 | 22 | protected void print(int priority, String tag, String chunk) { 23 | super.print(priority, tag, chunk); 24 | 25 | if (sPeerManager == null) { 26 | sPeerManager = ConsolePeerManager.getInstanceOrNull(); 27 | } 28 | 29 | Console.MessageLevel logLevel; 30 | 31 | switch (priority) { 32 | case Log.VERBOSE: 33 | case Log.DEBUG: 34 | logLevel = Console.MessageLevel.DEBUG; 35 | break; 36 | case Log.INFO: 37 | logLevel = Console.MessageLevel.LOG; 38 | break; 39 | case Log.WARN: 40 | logLevel = Console.MessageLevel.WARNING; 41 | break; 42 | case Log.ERROR: 43 | case Log.ASSERT: 44 | logLevel = Console.MessageLevel.ERROR; 45 | break; 46 | default: 47 | logLevel = Console.MessageLevel.LOG; 48 | } 49 | 50 | CLog.writeToConsole( 51 | logLevel, 52 | Console.MessageSource.OTHER, 53 | chunk 54 | ); 55 | } 56 | } 57 | -------------------------------------------------------------------------------- /MBLog/app/src/main/res/layout/activity_main.xml: -------------------------------------------------------------------------------- 1 | 2 | 10 | 11 |