Северный (Арктический) федеральный университет им. М.В. Ломоносова
Опубликован: 10.04.2014 | Доступ: свободный | Студентов: 7002 / 1386 | Длительность: 14:18:00
Специальности: Программист
Самостоятельная работа 9:

Использование сторонних библиотек

< Лекция 6 || Самостоятельная работа 9 || Лекция 7 >
Аннотация: Научиться писать приложения с использованием сторонних библиотек.

Цель лабораторной работы:

Научиться писать приложения с использованием сторонних библиотек

Задачи лабораторной работы:

  • Научиться подключать библиотеки
  • Научиться использовать библиотеки в своих приложениях

15.1 Использование библиотеки для построения графиков AChartEngine

Рассмотрим пример подключения библиотеки AChartEngine, предназначенной для построения графиков. На сайте разработчика (http://code.google.com/p/achartengine) помимо самой библиотеки можно найти подробную документацию, оформленную в стиле Javadoc pages, примеры использования библиотеки, а также ее исходный код.

В разделе Downloads также можно скачать демонстрационные примеры использования библиотеки.

  1. Создайте проект Graphics.
  2. Чтобы подключить библиотеку, нужно скачать ее с сайта разработчика, потом просто перетащить из проводника в папку libs вашего проекта в Eclipce.
  3. Теперь нужно добавить строку <activity android:name="org.achartengine.GraphicalActivity"/> в раздел <application> в файле манифеста вашего проекта. Библиотека подключена.
  4. Теперь перейдем к файлу MainActivity.java. Создайте и инициализируйте три массива (в методе onCreate()). В первом будут содержаться цвета, во втором - подписи, в третьем - значения.
    int[] values = new int[] { 25,25,25,25 }; 
    String[] bars = new String[] {"Bananas",  "Kiwi", "Oranges", "Cream"};
    int[] colors = new int[] { Color.YELLOW,  Color.GREEN, Color.RED, Color.WHITE };
          
  5. Создайте объект CategorySeries и загрузите в него массивы строк с подписями и значения. При построении диаграмм будут использоваться именно эти данные.
    CategorySeries series = new CategorySeries("Pie Chart");
          
  6. Создайте объект DefaultRenderer. CategorySeries и DefaultRenderer определены в библиотеке AChartEngine.
    DefaultRenderer dr = new DefaultRenderer();
          
  7. Для каждого цвета в диаграмме создайте SimpleSeriesRenderer и установите его в этот цвет. Затем каждый SimpleSeriesRenderer добавьте в DefaultRenderer. Таким образом, имеем один Render на каждый Series. К слову, Render может включать другой Render, таким образом можно создавать подкатегории.
    for (int v=0; v<4; v++){
      series.add(bars[v], values[v]);
    SimpleSeriesRenderer r = new SimpleSeriesRenderer();
       r.setColor(colors[v]);
      dr.addSeriesRenderer(r);
    }
          
  8. Создайте объект PieChartIntent и передайте ему CategorySeries и DefaultRenderer.
    return ChartFactory.getPieChartIntent(this, series, dr, "Fruit Salad");
          
    С помощью PieChartIntent можно показать диаграмму, как отдельную деятельность.
  9. С помощью методов библиотеки можно изменить размер и цвет подписей, включить зум:
    dr.setZoomEnabled(true);
    dr.setChartTitleTextSize(20);
    dr.setLegendTextSize(TEXT_SIZE);
    dr.setChartTitleTextSize(20);
    dr.setZoomButtonsVisible(false);
    dr.setLabelsTextSize(TEXT_SIZE);
    dr.setLegendTextSize(TEXT_SIZE);
    dr.setLabelsColor(Color.BLACK);
          
  10. Для удобства можно создать дополнительную переменную, в которой будет храниться размер текста.
    private static final int TEXT_SIZE = 40;
    
      Intent intent = buildIntent();
        startActivity(intent);  
        }
     
        public Intent buildIntent() {
          int[] values = new int[] { 25,25,25,25 };
        . . . 
            
    
          dr.addSeriesRenderer(r);
        }
        dr.setChartTitleTextSize(20);
        . . . 
        dr.setLabelsColor(Color.BLACK);
      return ChartFactory.getPieChartIntent(
      this, series, dr, "Fruit Salad");
        }
          
Приложение, запущенное на эмуляторе

Рис. 15.1. Приложение, запущенное на эмуляторе
Приложение, запущенное на устройстве

увеличить изображение
Рис. 15.2. Приложение, запущенное на устройстве
package com.mypackage.graphics;


import org.achartengine.ChartFactory;
import org.achartengine.chart.PieChart;
import org.achartengine.model.CategorySeries;
import org.achartengine.renderer.DefaultRenderer;
import org.achartengine.renderer.SimpleSeriesRenderer;
import android.content.Context;
import android.content.Intent;
import android.graphics.Color;
import android.app.Activity;
import android.os.Bundle;
 
public class MainActivity extends Activity {
private static final int TEXT_SIZE = 40;
    @Override
    public void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
          Intent intent = buildIntent();
        startActivity(intent); 
    }
 
    public Intent buildIntent() {
        int[] values = new int[] { 25,25,25,25 };
        String[] bars = new String[] {"Bananas",  "Kiwi", "Oranges", "Cream"};
        int[] colors = new int[] { Color.YELLOW,  Color.GREEN, Color.RED, Color.WHITE };
 
        CategorySeries series = new CategorySeries("Pie Chart");
        DefaultRenderer dr = new DefaultRenderer(); 
 
        for (int v=0; v<4; v++){
            series.add(bars[v], values[v]);
            SimpleSeriesRenderer r = new SimpleSeriesRenderer();
            r.setColor(colors[v]);
            dr.addSeriesRenderer(r);
        }
dr.setZoomButtonsVisible(true);
        dr.setZoomEnabled(true);
        dr.setChartTitleTextSize(20);
        dr.setLegendTextSize(TEXT_SIZE);
        dr.setChartTitleTextSize(20);
        dr.setZoomButtonsVisible(false);
        dr.setLabelsTextSize(TEXT_SIZE);
        dr.setLegendTextSize(TEXT_SIZE);
        dr.setLabelsColor(Color.BLACK);
        return ChartFactory.getPieChartIntent(this, series, dr, "Fruit Salad");
    }
 
}
    
Листинг 15.1. Код MainActivity.java
< Лекция 6 || Самостоятельная работа 9 || Лекция 7 >
Марат Нуриджанян
Марат Нуриджанян

Пример: Скачать среду можно с сайта для разработчиков Android (http://developer.android.com/sdk/index.html).

Там скачать можно только Android Studio

Владимир Каункин
Владимир Каункин

В самостоятельной работе 2 в примере решения задания некорректно загадывается число (в двух местах), выбирая случайное целое число из диапазона [0, 99] вместо [1, 100], как того требует условие. Кроме того, загадывание числа всё таки лучше вынести в отдельный метод, как мне кажется.