KavishDevar

KavishDevar

0-day streak
didn't manage to do much for my airpods project today, but i tried to communicate with the find my server running on the airpods case to read battery even when the airpods are not connected for audio. And of course a few bug fixes in the UI... github.com/kavishdevar/aln
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/9006248f-b344-4909-b5ea-b6bf7fb520e8-image.png
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/76eebc26-663b-4ef3-b840-2d133635c235-1000029576.png
github emoji
slack emoji
I finally made the connections to airpods automatic on the ALN Android app! Now I don't need to worry about accidentally opening the app before connecting the airpods. I had to move around the whole service into a new one that also listens for bluetooth connections, and refactor all of my UI code, and the actual part where the l2cap socket is opened and a connection is established. Because originally the service would only run when airpods were connected. Now, the service always runs and connects to the socket itself! Along with that, I also fixed the QuickSettings tile which kept on crashing for some reason. Demo Video: youtube.com/shorts/WcjxR78_Q_Q GitHub: github.com/kavishdevar/aln Last post: hackclub.slack.com/archives/C01504DCLVD/p1732823258716669?thread_ts=1732823258.716669&cid=C01504DCLVDDCLVD
goose-honk-technologist emoji
github emoji
slack emoji
I tried to add a overlay to show whenever airpods are connected! And it turned out to be really difficult. It doesn't want to work whenever i try to use compose instead of the layouts, so, ig i'm stuck with the old boring layoutinflators etc...
pf emoji
it feels like my 2015 macbook air's temperature is reaching 200°C, when running slack, brave, and android studio all at once. too lazy to get up to my pc and work on it :/ original scrap: hackclub.slack.com/archives/C01504DCLVD/p1732651925430999 github: github.com/kavishdevar/aln
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/eeaf5cfd-0164-4408-9497-27d2780ad1a7-screenshot_20241129-011558_lawnchair__debug_.png
macbook-air-space-gray-screen emoji
slack emoji
c emoji
github emoji
I managed to style my AirPodsLikeNormal android app a little bit better now. • The top app bar blurs the background (wth google! you're saying i can't blur background on jetpack compose directly!?) • The sliders are better themed now • and i tracked down a bug where the app would activate bluetooth audio profiles (a2dp and hsp) when they were put into case, just after deactivating them after they're taken out of ear Not much of an update, just because the blurring part took me 3 hours -_- GitHub - github.com/kavishdevar/aln Original Scrap - hackclub.slack.com/archives/C01504DCLVD/p1732651925430999
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/5b91a6ef-437f-4436-a1dd-5d2b2cab7288-image.png
Been a long time since I actually posted something on here... I have made an app for android (and linux) that makes using AirPods on those operating systems way easier and better. Do you know how much Apple likes to restrict most of the features to their devices. Well, I removed the restriction! I reverse-engineered how Apple devices communicate with AirPods and wrote an app for linux and android. AirPods use the L2CAP Bluetooth protocol to communicate with apple devices. The linux version of this app has multiple scripts. One of them runs as a daemon to handle the connection, and others to handle UI, userspace, like pausing music, lowering volume, etc.. I did this so that I can have multiple applications which can talk to the AirPods without interrupting the other one. It is written purely in Python. Currently, I have made a tray application using PyQT5/6. It manages ear detection, conversational awareness, and gives me control over ANC. And, it shows the battery level too! As for the Android app, well I have attached a few images! Yes, I have tried to clone iOS's settings screen for AirPods.
okig emoji
The android app was a pain to work upon. For starters, Android's bluetooth stack sent extra packets to the AirPods to check for some flow control mode. The AirPods will not respond to anything until they receive a specific handshake packet. I had to download the entire android source to test out and edit the libbluetooth_jni.so (the bluetooth stack). Then, I used my smol brain to make a few changes to the source code (and by a few changes, i mean commented a few lines)... And, it worked! Rant about Apple - Guess what- They hide their handshake packet from the PacketLogger app which allows me to view all the packets sent/received from my mac to any bluetooth device. Fortunately this was available online thanks to some other people who worked way before me. Apple even hid another packet necessary to activate Conversational Awareness and Adaptive Audio! Somehow, I got really, really, really lucky, and the packet just showed up in the PacketLogger app, shortly after which, it crashed.
confused-dino emoji
What works on the app – • Accurate battery levels • In-Ear detection – Music is automatically paused when they're taken out of ear! Plus, AirPods are removed as an available audio output device when none of the AirPods are in ear. • Conversational Awareness – Lowers volume when you start speaking! • Set Noise Control Mode – I can change the Noise Control Mode on my AirPods Pro 2! • Renaming AirPods • And a bunch of other settings extracted from the iOS/iPadOS settings page. ◦ Namely, Toggle Conversational Awareness, Toggle Loud Sound Reduction, Set Adaptive Audio Noise level, Toggle Automatic ear detection, Off listening Mode, Tone Volume, Noise Cancellation with Single AirPod, Toggle Volume Control by swiping. • And, of course, a debug screen, which lists all packets received, and even allows you to send packets! GitHub: github.com/kavishdevar/aln upvote the issue on android issue tracker so that the bug gets fixed: issuetracker.google.com/issues/371713238 :>
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/d89740a1-d87a-490e-be84-8ab1c47934a4-image.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/d2fc76f3-eb75-49b2-9d58-15b6d944eced-image.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/c40dd5a4-128b-429a-933a-91615e602052-image.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/16c5d016-de35-4cc6-8fab-8a02a2bce59b-image.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/a574e52c-3562-4241-9c73-1f14ace53bd4-image.png
I started making a openrgb client for mac in swift(ui) (cuz I use a hackintosh), just because I believe an app looks the most beautiful in an OS's native UI. I haven't really made much progress, since I started working on other projects, but here's the first 1 hour of my work GitHub: github.com/kavishdevar/OpenRGB-Swift
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/47b43417-72bc-4a6e-a7db-92488f7030c4-685fd681-bee4-42c3-9050-4351e4c2a88a.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/3044fb96-d077-4952-8ec7-461b8ab58bc5-126953df-1c9b-4d37-9930-944d377ad9a6.png
summer-of-making emoji
github emoji
swift emoji
https://scrapbook-into-the-redwoods.s3.amazonaws.com/db2b2f02-7788-47e6-bf85-9ae4b82d454a-image.png
github emoji
spotify emoji
summer-of-making emoji
I've made a few changes to the touchscreen dashboard that I made for my waveshare touchscreen display! • I've added support for controlling HomeAssistant entites, using their websocket API. • The device state is also updated using the websocket API. • The device controls/elements are dynamically created after the page has been loaded, instead of being hardcoded. • I've changed the UI for controlling devices a bit. • Switched from OpenWeatherMap to WeatherAPI for fetching weather. • Added colored icons for the weather widget (used in daytime). • And of course, I've refactored a lot. (basically split the ~1000 lines of code into various files) And, obviously, I broke the whole while making these changes :D (I just saw that the day/night detection isn't working, while writing this! nice.) I want to add more widgets, like reminders, simple text updates, current energy source (generator/grid), etc.. But, that's it for now! Links: GitHub
https://scrapbook-into-the-redwoods.s3.amazonaws.com/d923ac24-871b-4f55-a8b5-4af2485cf06d-image.png
github emoji
summer-of-making emoji
goose-honk-technologist emoji
I made a dashboard for my waveshare touchscreen display! It's pretty basic rn, i'm still gonna add multiple widgets, like calendar, shared reminders, music control from Spotify, and much more! Here's an image of what it looks like rn... (yes, ik it looks very apple-like, that's what i was aiming for, i love the design!) GitHub Repo: github.com/kavishdevar/dashboard
https://scrapbook-into-the-redwoods.s3.amazonaws.com/f2113927-aff7-44bc-84f1-0d26e4c6bbe1-image.png
music emoji
appleinc emoji
summer-of-making emoji
github emoji
spotify emoji
I re-wrote my Hamming Code visualizer that i had initially written in AngularJS and hosted on vercel. But it was totally unnecessary, so i wrote it again in plain javascript and html, with some css, and it's currently hosted on gh-pages. it just took me 30 minutes, i don't even know if this will count :] Source Code Published website
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/f8386b52-1673-4e71-9651-d4c87ca1ed50-33671c13-a33c-443c-932a-8616a37fe930.png
I have also worked on adding temporary (one-time) connections to my openrgb client for android... github.com/kavishdevar/OpenRGB-Android. I had already shared screenshots of it earlier, but forgot to link one session specific to this...
summer-of-making emoji
github emoji
I created a quick vector calculator using plain HTML and CSS. It can add, subtract, find out dot and cross products! I will definitely be working on it further, and may calculate all the results as the input values are updated... I am also planning on adding a graph for visualization. Check it out at my website! And you can find the source code on Github.
https://scrapbook-into-the-redwoods.s3.amazonaws.com/75c066d7-32c3-45f2-a22c-331f4859afb3-image.png
Apparently I forgot to select one of the sessions for this scrap, so posting it again... I updated the hammimg code ui and refactored the code slightly. github.com/kavishdevar/Angular-Playground/tree/main/hammingcode p.s. I couldn't deploy it on vercel, so anyone who wants to try it out will have to run it locally..
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/5c48eafb-a65f-45ab-a88f-d8759def428e-6075c8d0-d231-4542-9dfe-7ec28e50f27e.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/68046c6d-54a2-427e-81b6-aea12d158cc5-10051f3a-7a0f-4083-8c42-3a598e863f7b.png
goose-honk-technologist emoji
github emoji
summer-of-making emoji
I made a hamming code visualizer! I made it in angularjs unfortunately, i couldn't get it setup on vercel... but here are a few screenshots... it's also uploaded on github: github.com/kavishdevar/Angular-Playground/tree/main/hammingcode for anyone who wants to try it out(and yes i picked up the same example as the 3b1b vid :D)
https://scrapbook-into-the-redwoods.s3.amazonaws.com/0e2a4644-8402-4f24-8674-8cd3bdb6ba37-image.pnghttps://scrapbook-into-the-redwoods.s3.amazonaws.com/f1ba1cbf-8e75-42e6-8652-042be7a5897e-image.pnghttps://scrapbook-into-the-redwoods.s3.amazonaws.com/0b2c0b83-918c-4c40-a67e-22580364fe01-image.pnghttps://scrapbook-into-the-redwoods.s3.amazonaws.com/fb2182b3-afdc-436a-a30a-310ce695bfbf-image.pnghttps://scrapbook-into-the-redwoods.s3.amazonaws.com/39291a9e-25af-4292-9e1d-cbdb36d452a8-image.png
goose-honk-technologist emoji
vercel emoji
summer-of-making emoji
github emoji
https://scrapbook-into-the-redwoods.s3.amazonaws.com/48c015d9-d670-4a60-afe2-0975cbfea45c-image.png
I am reverse engineering my school's web portal! Turns out its easy! I have made the login page which posts the credentials and fetches the access token. I have also figured out a way to get the ebooks and homeworks from the website/portal github.com/kavishdevar/Angular-Playground Funny thing is that I didn't actually want to reverse engineer it, but instead learn angular. Guess I do both now..
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/eb2c712c-07ea-42ee-a4b9-af00da789641-0364c0b1-7026-4c85-a523-5ee3ab25b1f4.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/cc07697d-27ac-4c98-be02-2c5d4eb713ce-a82ae22c-1553-42fa-8a6b-c4332fb9fd19.png
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/d71400e3-2f95-47de-be9f-f5530bdd1e61-c39a9c8c-401f-4287-8c3b-5975fbe4eb45.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/b4a1bac4-4a26-4bbe-b6af-69e12a4a64b7-7f5dd0de-b1ed-4dee-a8da-c3ea4c51427b.png
github emoji
summer-of-making emoji
I built an app to control PC lighting from my phone using OpenRGB. It is functional, but not pretty, still working on the UI. I've also added a check if the device is able to connect to the computer, and provide the neccessary information/actions to the user if the connection fails...
https://scrapbook-into-the-redwoods.s3.amazonaws.com/9cb26830-5c3c-454a-b81f-41de276804fd-image.pnghttps://scrapbook-into-the-redwoods.s3.amazonaws.com/b780ed30-c4e2-4f0c-8c29-4d07dcab67e4-image.pnghttps://scrapbook-into-the-redwoods.s3.amazonaws.com/5a2eb609-96f0-4b18-8806-cc5cf45de23b-image.png