По сути, я повторно задаю этот вопрос, но для его реализации на Android.
Я пытаюсь разрешить пользователям переключаться между фильтрами статического изображения. Идея состоит в том, что изображение остается на месте, пока фильтр прокручивается над ним. Snapchat недавно выпустил версию, в которой реализована эта функция. В этом видео показано, чего я пытаюсь добиться на 1:05.
Я попытался заполнить список наложениями и пролистать его с помощью onFling и нарисовать с помощью onDraw, но я потерял анимацию. Есть ли способ сделать это с помощью ViewPager?
РЕДАКТИРОВАТЬ: В соответствии с запросом я предоставил свою реализацию для пейджинга представления оверлея. Он заполняет окно просмотра прозрачными изображениями в формате png, которые располагаются поверх изображения. Кроме того, этот код написан на C#, так как я использую Xamarin Android. Это очень похоже на Java для тех, кто не знаком с C#.
...
static List<ImageView> overlayList = new List<ImageView>();
...
public class OverlayFragmentAdapter : FragmentPagerAdapter
{
public OverlayFragmentAdapter(Android.Support.V4.App.FragmentManager fm) : base(fm)
{
}
public override int Count
{
get { return 5; } //hardcoded temporarily
}
public override Android.Support.V4.App.Fragment GetItem(int position)
{
return new OverlayFragment ();
}
}
public class OverlayFragment : Android.Support.V4.App.Fragment
{
public override View OnCreateView (LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
{
View view = inflater.Inflate (Resource.Layout.fragment_overlay, container, false);
LinearLayout l1 = view.FindViewById<LinearLayout> (Resource.Id.overlay_container);
ImageView im = new ImageView (Activity);
im.SetImageResource (Resource.Drawable.Overlay); //Resource.Drawable.Overlay is a simple png transparency I created. R
l1.AddView (im);
overlayList.AddElement (im);
return view;
}
}
XML макета активности:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="bottom">
<ImageView
android:id="@+id/background_image"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<RelativeLayout <!-- This second layout is for buttons which I have omitted from this code -->
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:id="@+id/edit_layout">
<android.support.v4.view.ViewPager
android:id="@+id/overlay_pager"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</RelativeLayout>
</RelativeLayout>
Фрагмент наложения XML
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/overlay_container"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center" />
Подведем краткий итог: просмотрщик располагается поверх первого изображения, которое действует как фон. Метод OnCreateView создает фрагмент наложения и представление изображения наложения из ресурса, который он помещает в макет overlay_container. Сохранение изображения (которое я не опубликовал, поскольку оно выходит за рамки этого вопроса) простое, все, что он делает, это создает фоновое растровое изображение, растровое изображение наложения и использует холст для рисования наложения на фон, а затем записывает в файл.