A shapeable, layered, intrinsincally animated container widget offering convenient
access to blurring ImageFilter
s, Material
InkResponse
, and HapticFeedback
.
A delightfully bouncy and position-mirroring reaction to user input on a piece of Material
.
Details in the screenshot above are from an outdated version.
Offers robust customization for a set app-wide style or on-the-fly changes.
- Support for
Color
s andGradient
s in both 📚SurfaceLayer
sBASE
andMATERIAL
layers. - Support for three different filters and their strengths.
- The top-most of which will affect any
InkResponse
that occurs on the middle 📚SurfaceLayer
- The top-most of which will affect any
- Insets may be divided amongst different 📚
Layer
s by 🔛Shape.padLayer
.
- 🆕 Manual
Shape
ing is here! Work in progress. - Defined by 📐
CornerSpec
and generates aSurfaceShape
. - Optionally, provide a ➖
border
or 📏scaling
.
📚 MATERIAL
inset or "border", the size of which is set by parameter 🔲 Peek.peek
.
- Give special treatment, generally a thicker appearance, to selected
side(s) by passing
Peek.alignment
and tuning withPeek.ratio
.
If the 🌟 Surface
is TapSpec.tappable
then:
- 👆
TapSpec.onTap
callback becomes available. - Colors may be provided for
InkResponse
customization--thoughThemeData
defaults are accessed otherwise. - Consider a
HapticFeedback
shortcut 👆TapSpec.providesFeedback
. - Enjoy the 🏓
BouncyBall
splashFactory
, pick your own, or have 🌟Surface
default to yourTheme
's.
- In configured 👓
Filter.filteredLayers
Set
- Whose radii (strength) are mapped with 📊
Filter.radiusMap
- Whose radii (strength) are mapped with 📊
- A 📚
SurfaceLayer.BASE
filter may be extended through theSurface.margin
withFilter.extendBaseFilter
. - 🤹♂️
SurfaceFX typedef
for passing along your ownFilterSpec.effect
s based on 📚SurfaceLayer
and the currentLayer
'sradius
.- Default effect is a nice gaussian blur (though a
new 🌟 Surface
has no active effects).
- Default effect is a nice gaussian blur (though a
Currently only responsible for 💧 FX.blurry
, the default ImageFilter
for 🔬 Filter
.
🌟 Surface
- A shapeable, layered, animated container Widget
- Defined by 📐
CornerSpec
and generates aSurfaceShape
🔲 Peek
- An Object with optional parameters to customize a 🌟 Surface
's "peek"
👆 TapSpec
- An Object with optional parameters to customize a 🌟 Surface
's tap behavior
🔬 Filter
- An Object with optional parameters to customize a 🌟 Surface
's 🤹♂️ filters/effects
🤹♂️ SurfaceFX typedef
for customFilterSpec.effect
s!
A delightfully bouncy and position-mirroring reaction to user input on a piece of Material
.
Turn ink splashes for an InkWell
, InkResponse
or material Theme
into 🏓 BouncyBall
s or 🔮 "glass" BouncyBall
s with the built-in InteractiveInkFeatureFactory
s, or design your own with custom rubber Paint
using 🪀 BouncyBall.mold
.
- 🔦 [
WithShading
]Color
extension- ⬛ [
withBlack
].withBlack(int subtract)
- ⬜ [
withWhite
].withWhite(int add)
- ⬛ [
- 🤚 [
DragNub
] A small, round "handle" indicator used to visualize impression of draggable material
This is my first public package and I expect things may still be altered greatly.
- Speaking of which, an overhaul is currently ongoing as of [0.4.0]. I am still new to Dart and improving my programming. Feel absolutely free to suggest improvements or make PRs.
- Since releasing
Surface
, I have found many more advanced and powerful packages. StillSurface
progress marches onward as I plan to continue development as I learn. - For example, I have already earned experience in deprecating features and "bad pushes"!
🔳 Animations of 📐 Surface.shape
change.
✅ Differed radius on 📚 SurfaceLayer.MATERIAL
vs 📚 SurfaceLayer.BASE
Smaller inner radius gives a better aesthetic for nested shapes.🆕 Manual setting ofSurface.radius
orSurface.baseRadius
available now.- 🆕 Manual
Shape
ing is here! Work in progress.
✅ Proposed [SurfaceCornerSpec] for [Surface.corners] parameter or expansion of 🔰 [SurfaceShape] class that allows customization of all four corners independently.
- 🆕 Manual
Shape
ing is here! Work in progress.
See example usage of the 🌟 Surface
package for Flutter:
- Surface Example Android source:
/example/lib/main.dart
- Animated GIF preview of Surface Example app
- Surface Example APK