2015-10-29 5 views
5

Esiste la possibilità di creare un controllo diapositiva di confronto immagini in Android come quello esistente in HTML 5?A "Prima e dopo" Confronto di immagini Controllo diapositive in Android

http://thenewcode.com/819/A-Before-And-After-Image-Comparison-Slide-Control-in-HTML5

Come posso realizzare questa cosa?

+0

Sembra che tu solo bisogno di cambiare il valore alfa di un'immagine su una modifica del valore Slider. –

+0

Sembra che dovresti avere 2 bitmap (prima e dopo). Vorrei creare una vista personalizzata che mantenga/gestisca questi 2 bitmap e li disegni di conseguenza usando 'drawBitmap (bitmap bitmap, rect src, rect dst, paint paint)'. –

risposta

4

Un modo è utilizzare una barra di ricerca e un framelayout che si trova sopra l'immagine originale. Mentre si fa scorrere la barra di ricerca, l'altezza dei fotogrammi si regola e contiene la seconda immagine.

Codice in alto verso il basso rivelare

private SeekBar seekBar; 

sotto protected void onCreate(Bundle savedInstanceState) {

aggiungere

seekBar = (SeekBar) findViewById(R.id.seekBar1); 

     seekBar.setOnSeekBarChangeListener(new OnSeekBarChangeListener() { 

      int progress = 0; 

      @Override 

      public void onProgressChanged(SeekBar seekBar, int progresValue, boolean fromUser) { 
       FrameLayout target = (FrameLayout) findViewById(R.id.target); 

       progress = progresValue; 

       ViewGroup.LayoutParams lp = target.getLayoutParams(); 
       lp.height = progress; 
       target.setLayoutParams(lp); 

      } 

      @Override 
      public void onStartTrackingTouch(SeekBar seekBar) { 

      } 

      @Override 
      public void onStopTrackingTouch(SeekBar seekBar) { 

      } 
     }); 

il layout

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:tools="http://schemas.android.com/tools" 
    xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" 
    android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin" 
    android:paddingRight="@dimen/activity_horizontal_margin" 
    android:paddingTop="@dimen/activity_vertical_margin" 
    android:paddingBottom="@dimen/activity_vertical_margin" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" 
    tools:showIn="@layout/activity_main" tools:context=".MainActivity"> 

    <ImageView 
     android:id="@+id/image" 
     android:layout_width="600dp" 
     android:layout_height="300dp" 
     android:src="@drawable/pug_color"/> 
    <FrameLayout 
     android:id="@+id/target" 
     android:layout_width="600dp" 
     android:layout_height="150dp"> 
     <ImageView 
      android:id="@+id/imageb" 
      android:layout_width="600dp" 
      android:layout_height="300dp" 
      android:layout_gravity="center_horizontal" 
      android:src="@drawable/pug_bw"/> 
    </FrameLayout> 

    <SeekBar 
     android:id="@+id/seekBar1" 
     android:layout_below="@+id/image" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:progress="300" 
     android:max="600" /> 
</RelativeLayout> 
5

ho creato library per questa funzionalità, qualcuno che potrebbe acciaio bisogno di questa funzione, sarà un bene per loro

compile 'com.github.developer--:beforeafterslider:1.0.4' 
+1

Jemo, ottimo lavoro! Ho provato ad usare il tuo cursore, è davvero fantastico. Ho trovato un bug però - quando ho impostato la stessa immagine per entrambe le parti del cursore (il prima e il dopo) sembra che una delle immagini sia distorta, come se fosse leggermente ingrandita (mi dispiace scrivere qui, non ho un Account Github). – Lelik

+0

grazie, controllerò il prima possibile –

+0

È la riga val tmpBitmap = getScaledBitmap (theBitmap) in ClipDrawableProcessorTask.kt Probabilmente, l'hai messo lì per mostrare che le immagini sono diverse, quando si impostano entrambe le parti di il cursore della stessa immagine. Così ho commentato e ora funziona tutto bene. L'immagine "prima" è sulla destra, il "dopo" è sulla sinistra. Ancora una volta, grazie per il tuo lavoro, mi ha davvero aiutato molto a dimostrare alcuni effetti di elaborazione delle immagini. – Lelik

Problemi correlati