Сайт разработчика Александр Климова

/* Моя кошка замечательно разбирается в программировании. Стоит мне объяснить проблему ей - и все становится ясно. */
John Robbins, Debugging Applications, Microsoft Press, 2000

Библиотека Android-WScratchView

Многим из вас приходилось иметь дело с скретч-картами, когда монеткой нужно было стереть защитный слой и увидеть заветные цифры. Это могли быть и счастливые номера лотереи или пин-код и т.д.

Scratch Card

Библиотека WScratchView позволяет добиться такого же эффекта. Вам надо потереть экран, чтобы под защитным слоем увидеть картинку.

Адрес библиотеки: winsontan520/Android-WScratchView

Скопируйте библиотеку на свой компьютер, импортируйте её (проект в папке WScratchViewLibrary) и подключите её к своему проекту через Properties | Android | Add....

Простейший пример без дополнительных настроек.


<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <TextView
        android:id="@+id/percentage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@+id/scratch_view"
        android:layout_centerHorizontal="true"
        android:textColor="#000000" />

    <ImageView
        android:layout_width="300dp"
        android:layout_height="300dp"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:background="@drawable/cat1" />

    <com.winsontan520.WScratchView
        xmlns:wsv="http://schemas.android.com/apk/res-auto"
        android:id="@+id/scratch_view"
        android:layout_width="300dp"
        android:layout_height="300dp"
        android:layout_centerInParent="true" />

    <Button
        android:id="@+id/reset_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_marginBottom="14dp"
        android:onClick="onClickHandler"
        android:text="Reset" />

</RelativeLayout>

Контейнер RelativeLayout позволяет наложить один компонент поверх другого. В нашем случае на компонент ImageView с требуемой картинкой накладывается компонент WScratchView, который представляет собой по умолчанию чёрный прямоугольник. Этого кода достаточно, чтобы увидеть эффект в действии. Запустите пример и начинайте тереть чёрный прямоугольник, чтобы увидеть картинку под ним.

Чтобы восстановить защитный слой, вызовите метод reset(). В примере мы заблаговременно добавили кнопку для этой операции.


public void onClickHandler(View view) {
	WScratchView scratchView = (WScratchView) findViewById(R.id.scratch_view);
	scratchView.resetView();
}

От базового примера перейдём к тонкой настройке.


<com.winsontan520.WScratchView
    xmlns:wsv="http://schemas.android.com/apk/res-auto"
    android:id="@+id/scratch_view"
    android:layout_width="300dp"
    android:layout_height="300dp"
    android:layout_centerInParent="true"
    wsv:antiAlias="true"
    wsv:overlayColor="#0000ff"
    wsv:revealSize="20dp"
    wsv:scratchable="true" />

Атрибут wsv:overlayColor позволяет задать свой цвет для защитного слоя, а атрибут wsv:revealSize - размер пальца/лапы, когда вы елозите им по экрану.

WScratchView

Также вы можете установить свойства программно. Вот часть из них.


scratchView.setScratchable(true);
scratchView.setRevealSize(50);
scratchView.setAntiAlias(true);
scratchView.setOverlayColor(Color.RED);

Вместо сплошного цвета для защитного слоя вы можете задать свою картинку при помощи атрибута wsv:scratchDrawable="@drawable/over".

Также вы можете отслеживать площадь стёртой поверхности в процентах. В разметке мы уже разместили компонент TextView, в которой и будем выводить эту информацию в процессе стирания защитного слоя.


package ru.alexanderklimov.test;

import com.winsontan520.WScratchView;

import android.app.Activity;

import android.os.Bundle;
import android.view.View;
import android.widget.TextView;

public class MainActivity extends Activity {

	private WScratchView scratchView;
	private TextView percentageView;

	/** Called when the activity is first created. */
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		percentageView = (TextView) findViewById(R.id.percentage);
		scratchView = (WScratchView) findViewById(R.id.scratch_view);

		scratchView.setOnScratchCallback(new WScratchView.OnScratchCallback() {

			@Override
			public void onScratch(float percentage) {
				updatePercentage(percentage);
			}
		});
		updatePercentage(0f);
	}

	public void onClickHandler(View view) {
		scratchView.resetView();
		updatePercentage(0f);
	}

	protected void updatePercentage(float percentage) {
		String percentage2decimal = String.format("%.2f", percentage) + " %";
		percentageView.setText(percentage2decimal);
	}
}

WScratchView

Реклама