Android StudioでAndroidAnnotations3.0.1を使う方法

http://qiita.com/hiroq/items/43106b3b03708612bf90


去年から変わっているところもあり改めて最新環境で書き直しました。
Android StudioでAndroidAnnotations3.2を使う方法

はじめに

Android StudioでAndroidAnnotationsを使うための設定方法のまとめです。

ゴール

  • Android StudioのプロジェクトでAndroidAnnotaionsを使えるようにする
  • ActivityをAndroidAnnotationsで処理できるようにする

環境(2014年5月2日現在)

Androidツール
toolversion
Android Studio0.5.7, 0.5.8
Android SDK Tools22.6.3
Android SDK Platform-tools19.0.1
Android SDK Build-tools19.0.3

#2014.5.10 AndroidStudio 0.5.8での動作確認を行いました

ライブラリ
toolversion
AndroidAnnotations3.0.1(2014/01/12リリース)

手順

1. Android Studioでプロジェクト作成

プロジェクト作成については細かいことは省略します。
この後の手順は、以下の設定で作成したものとして進めていきます。

no.設定項目入力値
1Application nameAASample
2Module nameapp
3Package namecom.teamhiroq.sample.aasample
4Project location適当
5Create Activitychecked
6Activity typeBlankActivity
7Activity nameMainActivity
8Layout nameactivity_main


2. build.gradleの変更

apt(Annotation Processing Tool)をgradleで使えるようにします。
AASample直下のbuild.gradleに以下の一行を追加します。
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.2'

追加後の全体のbuild.gradleは以下の通りです。

build.gradle
// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:0.9.+'
        classpath 'com.neenbedankt.gradle.plugins:android-apt:1.2'
    }
}

allprojects {
    repositories {
        mavenCentral()
    }
}

3. app/build.gradleの変更

app/build.gradleを以下のようにします。

app/build.gradle
apply plugin: 'android'
apply plugin: 'android-apt'
def AAVersion = '3.0.1'

android {
    compileSdkVersion 19
    buildToolsVersion "19.0.3"

    defaultConfig {
        minSdkVersion 8
        targetSdkVersion 19
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            runProguard false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile 'com.android.support:appcompat-v7:19.+'

    apt "org.androidannotations:androidannotations:$AAVersion"
    compile "org.androidannotations:androidannotations-api:$AAVersion"
}

apt {
    arguments {
        androidManifestFile variant.processResources.manifestFile
- androidManifestFile variant.processResources.manifestFile
+ androidManifestFile variant.outputs[0].processResources.manifestFile

resourcePackageName 'com.teamhiroq.sample.aasample' // パッケージ名 }}

上記の変更箇所は以下の3点です。
applyとdefの2行追加

apply plugin: 'android-apt'
def AAVersion = '3.0.1'

aptとcompileの2行追加*

dependencies {
    // ・・・省略

    apt "org.androidannotations:androidannotations:$AAVersion"
    compile "org.androidannotations:androidannotations-api:$AAVersion"
}

aptのブロック6行を追加

apt {
    arguments {
        androidManifestFile variant.processResources.manifestFile
        resourcePackageName 'com.teamhiroq.sample.aasample' // パッケージ名
    }
}

※パッケージ名は手順1.の表のno.3で指定したパッケージ名を設定します。

4. Activityにアノテーションを設定

MainActivityに@EActivityアノテーションを設定します。

MainActivity.java
ackage com.teamhiroq.sample.aasample;

import android.support.v7.app.ActionBarActivity;
import android.view.Menu;
import android.view.MenuItem;

import org.androidannotations.annotations.EActivity;

@EActivity(R.layout.activity_main)
public class MainActivity extends ActionBarActivity {
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}

変更箇所は3つです

アノテーションのインポート

MainActivity.java
import org.androidannotations.annotations.EActivity;

アノテーションの設定

MainActivity.java
@EActivity(R.layout.activity_main)
public class MainActivity extends ActionBarActivity {

onCreateの削除
アノテーション@EActivity(R.layout.activity_main)を使うことで、setContentView(R.layout.activity_main)は自動的に行われるため、onCreateを削除しています。

5. AndroidManifest.xmlで参照するActivityクラスを変更する

先ほど設定したAndroidAnnotationsの@EActivityアノテーションによって、aptがMainActivity.javaからMainActivity_.javaを自動的に生成します。
必要な処理自体はすべてMainActivity.javaへ記載すればよいのですが、Androidのフレームワークから呼び出されるときには、自動生成されたクラスが呼び出されるようにする必要があります。
従って、AndroidManifest.xmlを以下のように変更します。

AndroidManifest.xml
        <activity
            android:name="com.teamhiroq.sample.aasample.MainActivity_"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

変更箇所は

android:name="com.teamhiroq.sample.aasample.MainActivity_"

です。
あとは、Activity内で@OnClickアノテーションや@ViewById等のアノテーションを自由に使ってAndroidAnnotationsを楽しんでみてください。


ありがとうございます。参考にさせて頂きました。

一点、僕の環境だとandroid-aptの設定でエラーが出たため、以下の箇所を変更しました。
原因は追ってませんが、見に来る方が多そうなので、同じような方がいたらご参考までに。
使用したgradleは2.2.1、android-aptは1.4です。

- androidManifestFile variant.processResources.manifestFile
+ androidManifestFile variant.outputs[0].processResources.manifestFile

参考URL: https://bitbucket.org/hvisser/android-apt 










  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值