studio dots android gradle android-studio viewpagerindicator

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>