ncs_io 0.0.2 ncs_io: ^0.0.2 copied to clipboard
Unofficial NoCopyrightSound client for flutter to play/download copyright free songs.
NoCopyrightSound
Unofficial NoCopyrightSound client for flutter to play/download copyright free songs
πGenres #
- Bass
- Chill
- Drum Bass
- Drum Step
- Dubstep
- EDM
- Electronic
- Future House
- Hard Style
- House
- Indie
- Melodic Dubstep
- Trap
- Glitch Hop
- Phonk
- Future Bass
- Bass House
π₯ Moods #
- Angry
- Dark
- Dreamy
- Epic
- Euphoric
- Energetic
- Fear
- Funny
- Glamorous
- Gloomy
- Happy
- Hopeful
- LaidBack
- Mysterious
- Peaceful
- Quirky
- Relaxing
- Restless
- Romantic
- Sad
- Scary
- Sexy
- Suspense
- Weird
π₯ Usage #
Add the dependency in pubspec.yaml
:
dependencies:
...
ncs_io: latest_version
π§° Complete example #
class Home extends StatefulWidget {
const Home({Key? key}) : super(key: key);
@override
State<Home> createState() => _HomeState();
}
class _HomeState extends State<Home> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text(''),
actions: [
IconButton(
onPressed: () {
Navigator.of(context).push(MaterialPageRoute(builder: (context) => const SearchPage()));
},
icon: const Icon(Icons.search))
],
),
body: FutureBuilder<List<Song>?>(
future: NCS.getMusic(),
builder: (context, snapshot) {
if (snapshot.hasData) {
return GridView.builder(
gridDelegate: const SliverGridDelegateWithMaxCrossAxisExtent(maxCrossAxisExtent: 200),
shrinkWrap: true,
itemCount: snapshot.data?.length ?? 0,
itemBuilder: (context, index) {
Song? song = snapshot.data?[index];
return Container(
width: 150,
margin: const EdgeInsets.all(5),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(15),
image: DecorationImage(
fit: BoxFit.cover,
image: NetworkImage(
song?.imageUrl ?? '',
),
onError: (exception, stackTrace) => const Center(
child: FlutterLogo(style: FlutterLogoStyle.markOnly),
),
)),
);
},
);
} else if (snapshot.hasError) {
return Center(child: Text(snapshot.error.toString()));
}
return const Center(child: CupertinoActivityIndicator());
},
),
);
}
}
class SearchPage extends StatefulWidget {
const SearchPage({Key? key}) : super(key: key);
@override
State<SearchPage> createState() => _SearchPageState();
}
class _SearchPageState extends State<SearchPage> {
List<Song> songs = [];
bool isSearching = false;
bool isDataFetched = false;
TextEditingController searchController = TextEditingController();
@override
Widget build(BuildContext context) {
return GestureDetector(
onTap: FocusScope.of(context).unfocus,
child: Scaffold(
appBar: AppBar(
title: TextField(
controller: searchController,
decoration: InputDecoration(
border: InputBorder.none,
hintText: 'Search sound',
filled: true,
suffixIcon: InkWell(
onTap: () async {
setState(() {
isSearching = false;
isDataFetched = false;
});
songs.clear();
setState(() => isSearching = true);
songs.addAll(await NCS.searchMusic(search: searchController.text.trim()) ?? []);
setState(() {
isDataFetched = true;
isSearching = false;
});
},
child: const Icon(Icons.search))),
)),
body: Stack(
children: [
Visibility(
visible: !isDataFetched & !isSearching,
child: const Center(
child: Text('Search results appear here'),
)),
Visibility(
visible: !isDataFetched & isSearching,
child: Center(
child: Column(
mainAxisSize: MainAxisSize.min,
children:const [
CupertinoActivityIndicator(color: Colors.deepPurple),
Text('Searching...'),
],
),
)),
Container(
padding: const EdgeInsets.all(10),
child: ListView.separated(
itemCount: songs.length,
shrinkWrap: true,
itemBuilder: (context, index) {
Song song = songs[index];
return InkWell(
onTap: () {
// Got single instance of music here
// You can use this instance, in which you will get song url to play music
},
child: Container(
decoration: BoxDecoration(borderRadius: BorderRadius.circular(15), color: Colors.grey.shade200),
padding: const EdgeInsets.all(10),
child: Row(
children: [
ClipRRect(borderRadius: BorderRadius.circular(15), child: Image.network(song.imageUrl ?? '', width: 60, height: 60)),
const SizedBox(width: 10),
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(song.name ?? '', style: Theme.of(context).textTheme.bodyText1),
Wrap(
children: [
Icon(Icons.person, color: Colors.deepPurple.shade400),
...List.generate(
song.artists?.length ?? 0,
(index) => Container(
decoration: BoxDecoration(color: Colors.deepPurple.shade50, borderRadius: BorderRadius.circular(10)),
padding: const EdgeInsets.all(3),
margin: const EdgeInsets.only(right: 3),
child: Text(song.artists?[index].name ?? ''),
))
],
),
Wrap(
children: [
Icon(Icons.tag, color: Colors.green.shade400),
...List.generate(
song.tags?.length ?? 0,
(index) => Container(
decoration: BoxDecoration(color: Colors.green.shade50, borderRadius: BorderRadius.circular(10)),
padding: const EdgeInsets.all(3),
margin: const EdgeInsets.only(right: 3),
child: Text(song.tags?[index].name ?? ''),
))
],
),
Text(song.genre ?? '', style: const TextStyle(color: Colors.grey))
],
),
),
],
),
),
);
},
separatorBuilder: (context, index) => const Divider(height: 10, color: Colors.transparent),
)),
],
),
),
);
}
}
βοΈ Authors #
- Ashish Pipaliya - Author
π License #
This project is licensed under the MIT License - see the LICENSE file for details.
π§° Contribution #
Feel free to raise issues and open PR