태그 보관물: android studio

안드로이드 스튜디오 앱 프로젝트가 사용하는 외부 라이브러리 최신 버전 확인하기

안드로이드 스튜디오를 사용해서 앱을 빌드하는 데는 그레들(Gradle)을 사용하고 있다. 그리고 작게는 몇 개에서 많게는 십수 개의 라이브러리를 사용하는 앱들을 흔하게 볼 수 있다. 물론 내가 개발하고 유지하는 앱들도 여러 개의 외부 라이브러리를 사용하고 있다.

이렇게 외부 라이브러리를 사용하다 보니, 개별 라이브러리의 최신 버전을 확인해야 하는 경우가 종종 있다. 이런 경우 라이브러리 프로젝트의 소스(대부분의 경우 Github에서 호스팅하고 있다)를 확인해서 버전이 업데이트 되었으면, 다시 동기화 하고 빌드해서 앱을 확인한다.

이 과정에서 라이브러리 업데이트는 필연으로 발생할 수 있는 문제지만, 라이브러리가 업데이트 되었는지 확인하는 작업은 아주 불편하다. 그래서 안드로이드 스튜디오에서 앱이 사용하는 라이브러리의 최신 버전을 확인할 수 있는 방법을 살펴보자. 인터넷으로 확인해본 결과 플러그인을 사용하는 방법, 안드로이드 스튜디오에서 지원하는 린트(Lint)를 사용하는 방법 그리고 젯브레인에 등록된 라이브러리를 사용하는 방법이 있다.

1. 플러그인을 사용하는 방법

https://github.com/ben-manes/gradle-versions-plugin 사이트에서 플러그인을 다운로드 받아서 설치해서 사용하면 된다.

1.1 예제 Build.xml

apply plugin: 'com.android.application'
apply plugin: 'com.github.ben-manes.versions'

buildscript {
    repositories {
        jcenter()
    }

    dependencies {
        classpath 'com.github.ben-manes:gradle-versions-plugin:0.12.0'
    }
}

android {
    compileSdkVersion 23
    buildToolsVersion "23.0.3"

    defaultConfig {
        applicationId "net.sjava.testapp"
        minSdkVersion 16
        targetSdkVersion 23
        versionCode 1
        versionName "1.0"
    }

    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:23.4.0'
    compile('com.mikepenz:materialdrawer:5.2.5@aar') {
        transitive = true
    }

    compile('com.mikepenz:aboutlibraries:5.6.6@aar') {
        transitive = true
    } 
}

1.2 실행

아래의 명령으로 프로젝트가 사용하는 라이브러리의 최신버전을 확인할 수 있다. 그리고 outputFormatter로 xml이나 json을 선택할 수 있다.
C:\dev\TestApp>gradlew dependencyUpdates -Drevision=release -DoutputFormatter=plain

1.3 결과

위 build.xml의 외부 라이브러리 확인결과, 아래와 같이 최신버전이 존재하는 것을 알 수 있다. 그리고, 맨 아래에 리포팅 결과를 txt파일로 저장했다는 것도 알 수 있다.

------------------------------------------------------------
:app Project Dependency Updates (report to plain text file)
------------------------------------------------------------
                                      
The following dependencies are using the latest release version:
 - com.github.ben-manes:gradle-versions-plugin:0.12.0
 - junit:junit:4.12                   
                                      
The following dependencies exceed the version found at the release revision level:
 - com.mikepenz:aboutlibraries [5.6.6  24.0.0-alpha2]
 - com.mikepenz:materialdrawer [5.2.5 -> 5.2.6]
                                      
Generated report file C:\dev\TestApp\app\build/dependencyUpdates/report.txt

2. 린트를 사용하는 방법

안드로이드 스튜디오에서 외부 라이브러리의 최신 버전을 쉽게 확인할 수 있게 린트를 사용해서 최신 버전을 확인할 수 있는 기능을 제공한다. 안드로이드 스튜디오에서 린트로 사용할 수 있지만, 기본으로 선택되어 있지 않아서 설정에서 추가한다.

2.1 린트 옵션 추가

안드로이드 스튜디오에서 Setting > Editor > Inspections 에러 아래와 같이 Newer로 찾으면 Newer Library Versions Available 옵션을 확인할 수 있고, 이 옵션을 선택하자.
setting_screen

2.2 린트를 실행해서 최신 버전의 라이브러리 확인

린트를 실행하는 방법은 상단 메뉴에서 Analyze > Run Inspection by Name…을 선택하고, Enter inspection name 창이 나오면 Newer 를 입력하면 Newer Library Versions Available을 선택할 수 있다. 그리고 Whole 프로젝트를 범위로 선택해서 확인하면, 아래와 같은 결과를 확인할 수 있다.
lint_result

3. 안드로이드 스튜디오 플러그인

안드로이드 스튜디오는 젯브레인(JetBrains)에 배포되어 있는 플러그인을 사용할 수 있다. 그래서 Setting > Plugins > Browse Repositories에 가서 version을 검색하면 Dependencies Version Checker 플러그인을 확인할 수 있고, 이 플러그인을 설치하고 안드로이드 스튜디오를 다시 시작하자. 현재 이 플러그인은 의존성 에러(안드로이드 2.1.1 버전에서 확인)로 사용할 수 없었다.

안드로이드 스튜디오 Gradle 빌드 플러그인 업데이트

안드로이드 스튜디오(Android Studio)에서 Gradle을 사용해서 애플리케이션을 빌드하기 위해서 꼭 필요한 플러그인이 있고, 이 플러그인은 프로젝트(모듈이 아님)의 build.gradle 파일에 선언되어 있다. 이 파일은 아래 이미지에 선택되어 있다.

project_directory

아래에 볼 수 있는 스크립트 내용이 현재 프로젝트를 진행하고 있는 build.gradle 파일의 내용이다. 빌드 플러그인은 2015년 11월 12일 1.5.0의 안정화 버전이 발표되어, 1.3.1 버전에서 1.5.0 버전으로 업데이트를 한 것을 알 수 있다. 간단하게 아래처럼 버전만 변경하면 쉽게 빌드 플러그인을 업데이트할 수 있다.

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        
        //classpath 'com.android.tools.build:gradle:1.3.1'
        classpath 'com.android.tools.build:gradle:1.5.0'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

이 빌드 플러그인은 Bintray에 배포가 되고 있으며, 아래에서 확인할 수 있다.
https://bintray.com/android/android-tools/com.android.tools.build.gradle

그리고 위 링크에서 배포된 버전들을 최신 순더로 살펴보면 다음과 같다. 최신 버전이 1.5.0임을 알 수 있고, 이 버전까지는 여러번의 베타 과정을 거치면서 안정화 된 것을 알 수 있다.

build.gradle.versions

이제 빌드 플러그인이 업데이트 되면 쉽게 업데이트할 수 있겠다.

IntelliJ/Android Studio Open Current Activity 플러그인

인텔리J나 인텔리J 기반의 IDE인 안드로이드 스튜디오에서 안드로이드 개발을 하면서 유용한 플러그인의 하나인 Open Current Activity에 대해서 살펴보자. 이 플러그인의 이름만으로도 어떤 기능을 제공하고 있는지 어렵지 않게 유추할 수 있다.

  1. 기능

    • 바로 에뮬레이터나 기기에 연결해서 보고 있는 앱 화면의 Activity로 바로 이동할 수 있는 플러그인이다.
  2. 설치 및 다운로드

    • 안드로이드 스튜디오의 경우에는 플러그인 설치 윈도에서 찾을 수가 없어서 다운로드 해서 설치하도록 하자. 설치 방법은 이 페이지(https://plugins.jetbrains.com/plugin/7877)에서 jar 파일을 다운로드 하고, Preference > Plugins > Install plugin from disk… 버튼을 클릭해서 다운로드 한 jar 파일을 로딩한다. 마지막으로 안드로이드 스튜디오를 재시작한다.
  3. 사용방법

    • 사용방법은 에뮬레이터나 기기를 연결해서 개발 중인 앱을 실행시킨다. 그리고 화면을 보는 상황에서 메뉴의 Navigate > Current Activity 메뉴를 찾아서 클릭한다. 이제 화면에 보고 있는 Activity가 에디터 창에 뜨는 것을 확인할 수 있다.

안드로이드를 개발하면서 화면을 이동하고, 이동한 화면에서 문제를 발견하면 어떤 Activity나 Fragment인지 찾아서 수정해야 하는데, 이 찾는 과정이 조금 시간이 걸리기도 하지만 기억력의 한계로 가끔은 짜증을 유발하기도 한다. 그래서 이 플러그인은 많은 안드로이드 개발자들에게 유익한 플러그인이 될 것으로 생각한다.

아래 화면은 플러그인 개발 사이트에서 보여주는 예시화면이다.

안드로이드 스튜디오(Android Studio)에서 Fabric의 Crashlytics을 플러그인 설치 없이 사용하기

Crashlytics는 안드로이드나 IOS에서 크래시나 그와 같은 상황에 대한 리포팅 서비스를 제공하고 있다. 이 서비스를 사용하는 기본 방법은 http://sjava.net/?p=479를 확인하면 쉽게 알 수 있다. 필자가 진행하고 있는 프로젝트로 외부 프로젝트도 같이 진행하고 있다. 그래서 Crashlytics 계정을 2개 이상 사용하고 있다.

프로젝트를 변경해서 다른 계정을 사용할 때는 Crashlytics의 플러그인에서 로그아웃 -> 로그인 해서 사용하는 계정을 변경해서 사용한다. 그리고 이 플러그인을 설치하고 싶지가 않았다. 그래서 이 글에서는 플러그인을 설치하지 않고 Crashlytics를 사용하는 방법을 살펴보자.

Crashlytics는 트위터(Twitter)가 인수를 하고 Fabric이라는 통합 툴의 일부가 되었다. 그리고 사용하는 방법도 변경이 되었기에 변경된 내용을 살펴보자.

1. Fabric에서 Crashlytics에 해당하는 gradle 설정은 다음과 같다. 아래 내용은 https://fabric.io/migrations/gradle 에서 확인 할 수 있다.

buildscript {
  repositories {
    jcenter()
    maven { url 'https://maven.fabric.io/public' }
  }
  dependencies {
    classpath 'com.android.tools.build:gradle:1.5.0'
    // The Fabric Gradle plugin uses an open ended version to react
    // quickly to Android tooling updates
    classpath 'io.fabric.tools:gradle:1.+'
  }
}

apply plugin: 'com.android.application'
apply plugin: 'io.fabric'

repositories {
  jcenter()
    maven { url 'https://maven.fabric.io/public' }
  }

android {
  compileSdkVersion 23
  buildToolsVersion "23.0.0"

  defaultConfig {
    minSdkVersion 16
    targetSdkVersion 23
  }
}

dependencies {
  // Crashlytics Kit
  compile('com.crashlytics.sdk.android:crashlytics:2.5.5@aar') {
    transitive = true
  }
}

2. AndroidManifest.xml 파일에 아래의 권한을 추가한다.

<manifest>
    <uses-permission android:name="android.permission.INTERNET" />
</manifest>

3. AndroidManifest.xml 의 <application> 요소에 아래의 값을 추가한다.

<application>
    <meta-data android:name="com.crashlytics.ApiKey" android:value="키를 넣어 주세요" />
</application>

3.1 위에서 필요한 키는 웹사이트에서 Settings > Organizations 의 목록에 있는 Admin 그룹을 클릭하면 사용자 목록을 볼 수 있고, 이 화면에서 API 키를 확인할 수 있다.

4. Application 클래스에서 사용
– Application 클래스를 상속하는 클래스의 onCreate() 메서드에서 아래와 같은 코드를 사용해서 Crashlytics를 사용할 수 있다.

public void onCreate() {
    super.onCreate();
    Fabric.with(this, new Crashlytics());
}

이제 아래 과정은 Crashlytics가 Fabric으로 통합되면서 Deprecated된 과정이다. 따라서, 아래의 과정은 참고를 하지 않는게 좋다.

이 과정은 안드로이드스튜디오(Android Studio)에 적용할 수 있다.

1. Crashlytics의 pom.xml 파일을 확인한다.
https://crashlytics.com/downloads/maven 에서 Crashlytics에서 배포하는 바이너리에 대한 정보를 확인할 수 있다.

2. 위 정보를 기준으로 build.gradle에 아래의 정보를 입력한다.

buildscript {
    repositories {
        // 1. Add the Crashlytics Maven repository
        maven { url 'http://download.crashlytics.com/maven' }
    }
    dependencies {
        // 2. Add the Crashlytics plugin to your dependencies
        classpath 'com.crashlytics.tools.gradle:crashlytics-gradle:1.+'
    }
}

apply plugin: 'com.android.application'

// 3. Apply the Crashlytics plugin after the Android plugin
apply plugin: 'crashlytics'

repositories {
    // 4. Add the Maven repository
    maven { url 'http://download.crashlytics.com/maven' }
}

dependencies {
    // 5. Add the Crashlytics SDK to the Android project
    compile 'com.crashlytics.android:crashlytics:1.+'
}

3. AndroidManifest.xml 파일에 아래의 권한을 추가한다.

<manifest>
    <uses-permission android:name="android.permission.INTERNET" />
</manifest>

4. AndroidManifest.xml 의 <application> 요소에 아래의 값을 추가한다.

<application>
    <meta-data android:name="com.crashlytics.ApiKey" android:value="키를 넣어 주세요" />
</application>

4.1 위에서 필요한 키는 웹사이트에서 Settings > Organizations 의 목록에 있는 Admin 그룹을 클릭하면 사용자 목록을 볼 수 있고, 이 화면에서 API 키를 확인할 수 있다.

5. Application 클래스에서 사용
– Application 클래스를 상속하는 클래스의 onCreate() 메서드에서 아래와 같이 Crashlytics를 사용할 수 있다.

public void onCreate() {
    super.onCreate();
    Crashlytics.start(this);
}

 

* 레퍼런스
http://blog.danlew.net/2015/02/20/setting-up-a-new-app-in-crashlytics-without-the-plugin/

Android Studio 편집기에서 탭(Tab) 캐릭터 사용하기

안드로이드 스튜디오(Android Studio)에서 백스페이스(Backspace)는 기본으로 한자(글자나 공백)씩 지우게 되어 있다. 에디터로 코드를 수정할 때, 탭으로 인덴트 설정만큼 이동시켰다가 뒤로 가려고 백스페이스를 4번 처야 하는데 이게 좀 불편하다. 그래서, 4번을 치지 않아도 원하는 만큼(인텐트 길이) 뒤로 이동시켰으면 좋겠다. 그래서 찾아보니 아래의 그림처럼 Settings > Code Style > Java > Use tab character를 선택하면 된다.

그리고 Code Style의 각 항목을 선택해서 아래 그림과 같이 탭을 사용하도록 변경하면 기존의 공백대신 탭을 사용해서, 더 편하게 편집할 수 있다.

* Reference
http://stackoverflow.com/questions/23632624/android-studio-tab-spacing