dots - viewpagerindicator android studio
Agregar ViewPagerIndicator a Android Studio (4)
A partir de hoy (marzo de 2016), los repositorios maven de Jitpack funcionan para mí: https://jitpack.io/#JakeWharton/ViewPagerIndicator/2.4.1/aar
En root build.gradle
:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
En el proyecto build.gradle
:
dependencies {
compile ''com.github.JakeWharton:ViewPagerIndicator:2.4.1''
}
Estoy intentando que ViewPagerIndicator de Jake Wharton trabaje con Android Studio, pero desafortunadamente no funcionará.
Descargué el archivo .aar de aquí y lo incluí en mi carpeta libs.
Lo hice referencia así:
compile files(''src/main/libs/viewpagerindicator_2.4.1.aar'')
Android Studio me da el siguiente error:
Error:duplicate files during packaging of APK
No estoy muy familiarizado con Gradle y no sé qué hacer cuando me da este error.
¿Puedes ayudarme con esto?
Aquí está mi completo build.gradle:
apply plugin: ''com.android.application''
android {
compileSdkVersion 19
buildToolsVersion "20.0.0"
defaultConfig {
applicationId "de.xxx"
minSdkVersion 15
targetSdkVersion 19
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_7
targetCompatibility JavaVersion.VERSION_1_7
}
}
buildTypes {
release {
runProguard false
proguardFiles getDefaultProguardFile(''proguard-android.txt''), ''proguard-rules.txt''
}
}
}
dependencies {
compile ''com.android.support:support-v4:20.0.0''
compile ''com.github.amlcurran.showcaseview:library:5.0.0''
compile files(''src/main/libs/PdfViewer.jar'')
compile files(''src/main/libs/viewpagerindicator_2.4.1.aar'')
}
Gradle puede importarlo así:
Nivel superior Build.gradle:
buildscript {
repositories {
maven { url "http://dl.bintray.com/populov/maven" }
mavenCentral()
}
dependencies {
classpath ''com.android.tools.build:gradle:0.12.+''
}
}
allprojects {
repositories {
maven { url "http://dl.bintray.com/populov/maven" }
mavenCentral()
}
}
En build.gradle de su aplicación, agregue esto a su sección de dependencias:
compile ''com.viewpagerindicator:library:2.4.1@aar''
(Agregue @aar para evitar el "error de empaquetado para apklib")
Funciona bien para mí
ACTUALIZAR
Según la respuesta dada por Jürgen ''Kashban'' Wahlmann , ahora es posible agregar ViewPagerIndicator a través de gradle:
Nivel superior Build.gradle:
buildscript {
repositories {
maven { url "http://dl.bintray.com/populov/maven" }
mavenCentral()
}
}
allprojects {
repositories {
maven { url "http://dl.bintray.com/populov/maven" }
mavenCentral()
}
}
Build.gradle de la aplicación:
compile ''com.viewpagerindicator:library:2.4.1@aar''
Además, según la respuesta dada por Enrico Susatyo, ahora parece posible descargar la biblioteca de los repositorios de Jitpack maven. Hazlo de la siguiente manera:
En root build.grade:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
En proyecto build.grade:
dependencies {
compile ''com.github.JakeWharton:ViewPagerIndicator:2.4.1''
}
------------
Para usar Android-ViewPagerIndicator en Android Studio, no puede descargarlo desde gradle. En su lugar, debe importar la biblioteca como un "Proyecto existente" a su biblioteca actual.
Sigue estos pasos:
# 1 Descargar el código fuente de GitHub.
# 2 En su Android Studio Project: Archivo -> Estructura del proyecto -> agregar (+ símbolo) -> Importar proyecto existente. Importa solo la carpeta llamada "biblioteca", no el proyecto completo (deja las opciones de importación como sugiere Android Studio).
# 3 Si la "compileSdkVersion" especificada en su build.gradle no coincide con la especificada en el proyecto Android-ViewPagerIndicator, cambie la segunda. Lo mismo se aplica a cualquier otra propiedad, como "minSdkVersion" o incluso la biblioteca de soporte actual.
# 4 Agregue el proyecto Android-ViewPagerIndicator como una dependencia de su módulo build.gradle:
dependencies {
compile project('':library'')
}
# 5 Proyecto de sincronización con archivos gradle.
Puedes hacerlo sin una biblioteca de terceros
Resultado final:
1) Use el diseño del marco como un contenedor para Viewpager y luego agregue un Linearlayout en la parte inferior del mismo.
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:layout_collapseMode="parallax">
<android.support.v4.view.ViewPager
android:id="@+id/product_images_pager"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<HorizontalScrollView
android:layout_width="match_parent"
android:layout_height="20dp"
android:layout_gravity="bottom|center_horizontal"
android:layout_margin="10dp">
<LinearLayout
android:id="@+id/indicator_root"
android:layout_width="20dp"
android:layout_height="match_parent"
android:layout_gravity="bottom|center_horizontal"
android:gravity="center_horizontal"
android:orientation="horizontal">
</LinearLayout>
</HorizontalScrollView>
</FrameLayout>
2) Definir tamaño y margen para indicadores
//define globaly
private LinearLayout.LayoutParams imageParam;
//init params
int margin = Utils.pxFromDp(getActivity(), 5);
int width = Utils.pxFromDp(getActivity(), 8);
imageParam = new LinearLayout.LayoutParams(width, width);
imageParam.setMargins(margin, margin, margin, margin);
3) Agregue indicadores en el diseño lineal
for (int indicatorCount = 0; indicatorCount < productFromShoppingList.getProductImages().size();
indicatorCount++) {
ImageView imageIndicator =
new ImageView(getActivity());
imageIndicator.setAdjustViewBounds(true);
imageIndicator.setScaleType(ImageView.ScaleType.FIT_XY);
imageIndicator.setLayoutParams(imageParam);
indicatorContainer.addView(imageIndicator);
indicators.add(imageIndicator);
imageIndicator.setBackgroundResource(R.drawable.indicator_unselected);
}
4) Indicador de inicialización en la posición 0
indicators.get(0).setBackgroundResource(R.drawable.indicator_unselected);
5) Actualizar indicador en el cambio de página de paginador de vista
carousalViewPager.setAdapter(new slidingPagerAdapter(getActivity(),
productFromShoppingList.getProductImages()));
carousalViewPager
.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position,
float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
currentPageIndex = position;
updateIndicators(currentPageIndex);
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
private void updateIndicators(int selectedPostion) {
for (int indicatorPosition = 0; indicatorPosition < indicators.size(); indicatorPosition++) {
indicators.get(indicatorPosition).setBackgroundResource(indicatorPosition == selectedPostion ? R.drawable.indicator_selected
: R.drawable.indicator_unselected);
}
}
Por último, pero no menos importante, agregue 2 dibujables para el indicador
indicator_unselected.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
<stroke
android:width="1dp"
android:color="@color/white" />
</shape>
indicator_selected.xml
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
<corners android:radius="100dp" />
<solid android:color="@android:color/white" />
</shape>