Добрый день, Хабр.
Недавно возникла необходимость подцепить ККМ АТОЛ, в проект, разрабатываемый в Android Studio. Основная сложность состоит в том, что в официальном мануале расписано, как подключаться только в Eclipse.



Поиск по сети натолкнул на полезный совет.
Cоздайте папки jniLibs и libs по пути: app/src/main, как на скриншоте ниже:



В jniLibs, создайте папку armeabi, и в неё поместите .so — файлы. В libs — jar-файл. Правой кнопкой мыши щелкните по jar-файлу, и выберите «Add As Library».

Далее выберите File — New — Import Module, и найдите папку с проектом (FptrLibRes). Добавьте её в проект. В app.gradle — добавьте нижеприведенный текст(должно добавиться автоматом, но на всякий случай):

gradle
dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:23.4.0'
    compile files('src/main/libs/fptrlib.jar')
    compile project(':fptrLibRes')
}


Внесите изменения в основной манифест:

Файл AndroidManifest
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="ru.kkm">
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN"/>
    <uses-permission android:name="android.permission.BLUETOOTH"/>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="com.atol.drivers.fptr.settings.SettingsActivity"
            android:label="Свойства ККМ"
            android:windowSoftInputMode="adjustPan">
            <intent-filter>
                <action android:name="android.intent.action.VIEW"/>
            </intent-filter>
        </activity>
        <activity android:name="com.atol.drivers.fptr.settings.DeviceListActivity"
            android:configChanges="orientation|keyboardHidden"
            android:label="Выбор устройства"/>
    </application>
</manifest>


Теперь создадим тестовое приложение, которое позволяет получить доступ к стандартной странице настроек:

Тестовый код
package ru.kkm;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;

import com.atol.drivers.fptr.IFptr;
import com.atol.drivers.fptr.settings.SettingsActivity;

public class MainActivity extends AppCompatActivity {
    IFptr fptr = null;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        try{
            fptr = new IFptr();
            fptr.create(this);
        } catch (NullPointerException ex){
            fptr = null;
        }
    }

    public void onClick(View view){
        switch (view.getId()){
            case R.id.button:
                Intent intent = new Intent(this, SettingsActivity.class);
                intent.putExtra(SettingsActivity.DEVICE_SETTINGS, fptr.get_DeviceSettings());
                startActivityForResult(intent, 1);

                break;
        }
    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        if(requestCode == 1){
            if(data!=null && data.getExtras()!=null){
                String settings  = data.getExtras().getString(SettingsActivity.DEVICE_SETTINGS);
                Toast.makeText(this, settings, Toast.LENGTH_LONG).show();

            }
        }
    }
}


Разметка экрана
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="ru.cse.kkm_test.MainActivity">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!"
        android:id="@+id/textView" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="New Button"
        android:id="@+id/button"
        android:onClick="onClick"
        android:layout_below="@+id/textView"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_marginTop="46dp" />
</RelativeLayout>


Далее, работаем по официальному руководству.

Засим позвольте откланяться. Надеюсь кому-то это позволит сохранить время и нервы.
Если у кого-то есть замечания и подсказказки, с большим удовольствием их выслушаю
Поделиться с друзьями
-->

Комментарии (6)


  1. real_mista
    31.08.2016 14:31

    напишите, есть ли возможность обрабатывать ответы от принтера с помощью RX. А то я скатился в callback-hell


    1. Snakecatcher
      31.08.2016 14:34

      Пока изучаю сам работу с данным ККМ.
      Подключение к AS — было первыми граблями, которые пришлось обходить.
      К сожалению, пока что ничем не могу помочь. Но может, кто-нибудь из прочитавших пост, знает по данному вопросу больше.


  1. thelongrunsmoke
    31.08.2016 17:06
    +1

    Эм, стандартное подключение нативной библиотеки, гуглится на счёт раз.
    И раз уж на то пошло, не "к" а "в", можно подумать, что статья будет про учёт результатов тестов или что-то подобное.
    Кроме того, основная сложность этих ККМ в кривой библиотеке, а не в том как её подключить.


    1. Snakecatcher
      31.08.2016 17:13

      ОК, название подправил.
      Собственно статью написал, чтобы не гуглить, а иметь пошаговое руководство.
      Кому-то, может она сэкономит немного времени и нервов.


  1. agent10
    31.08.2016 23:49

    Единственное отличие этого решение от вообще принятого стандартного, что джарник помещён в 'src/main/libs/fptrlib.jar'
    Почему именно сюда, а не в стандартный app/libs? Что это меняет?


    1. Snakecatcher
      01.09.2016 09:37

      Вы забыли еще про so файлы. В них-то и главная сложность.
      Полагаю, что не меняет ничего. Я сделал так.
      P.S.: Я конечно понимаю, что для гуру программирования, это кажется наивно, как комментатор выше меня уже тыкнул. Но для начинающих, может стать неприятной задачей.