Xama.JTPorts.ShineButton
Xamarin.Android Native UI lib button effects like "shining".
Xamarin.Android Native "Shine Button" control. This is a UI lib for Xamarin Android. Creates 'shining' effects. Initial port from ShineButton by Chad Song
This is a ported build, converted from Java to C# for use with the Xamarin MonoFramework. There are only a couple of new additions from the original library currently.
Outstanding Tasks
-
Fill out readme.md a bit better.
-
Rework the sample removing the physical classes, replacing them with nuget references.
-
Convert setters to properties instead as per c# standards.
-
Convert to Camel case where appropriate.
-
Create v1 nuget package.
-
There's quite a few issues I've noticed from the original port library, so need to work through these.
-
Create animated gifs showcasing different settings
-
Decide if I want to fix the 'sighing' effect that can happen with certain settings.
Basic usage
The Icon shape is made from png mask and the ported library preferred RAW formats, however you can use normal images, just bear in mind that as it masks an image you'll lose details, so use cut-out images instead, similar to the animated gif above.
Create programatically and then simply add to your view:
ShineButtonControl shineButtonControl = new ShineButtonControl(this);
shineButtonControl.ButtonColour = Color.Gray;
shineButtonControl.ButtonFillColour = Color.Red;
shineButtonControl.ShapeResource = Resource.Raw.heart;
shineButtonControl.AllowRandomColour = true;
var layoutParams = new LinearLayout.LayoutParams(100, 100);
shineButtonControl.LayoutParameters = layoutParams;
Or simply define in AXML as such:
<ShineButton.Classes.ShineButtonControl
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_marginBottom="50dp"
android:layout_centerInParent="true"
android:id="@+id/po_like"
app:btn_color="@android:color/darker_gray"
app:btn_fill_color="#0f4cad"
app:big_shine_color="#8094e5"
app:click_animation_duration="200"
app:shine_animation_duration="1500"
app:shine_turn_angle="10"
app:small_shine_offset_angle="20"
app:shine_distance_multiple="1.5"
app:small_shine_color="#CC9999"
app:shine_count="8"
app:shine_size="30dp"
app:siShape="@raw/like" />
Available Attributes
<attr name="btn_color" format="color" />
<attr name="btn_fill_color" format="color" />
<attr name="shine_count" format="integer" />
<attr name="shine_turn_angle" format="float" />
<attr name="small_shine_offset_angle" format="float" />
<attr name="enable_flashing" format="boolean" />
<attr name="allow_random_color" format="boolean" />
<attr name="small_shine_color" format="color" />
<attr name="big_shine_color" format="color" />
<attr name="shine_animation_duration" format="integer" />
<attr name="click_animation_duration" format="integer" />
<attr name="shine_distance_multiple" format="float" />
<attr name="shine_size" format="dimension" />
Dependencies
Xama.JTPorts.EasingInterpolator
Useful?
You know, only if you want to