Done thank you!
Use case fyi:
Was using buttons to flip through RSS news headlines.
Instead I’ve overlaid a transparent version of your touchpad on the news card and can now flip through hedlines by swiping left-right. Great!
However I lost the ability to open the link to the full news article by single-clicking on the headline
Thanks for considering this enhancement request,
Cheers.
Hi, the volume buttons are sort of inverted from what seems to be intuitively convenient, ie vol - is on top and vol + is at the bottom. Any way I can invert this without assigning the vol + command to the vol - button and vice versa?
Secondly, is it possible to have some now playing type info showing on the touchpad rather than an image, if thats not too much to ask
Nerwyn
(Nerwyn)
November 23, 2023, 4:05pm
86
Can you make a bug for this on the repo so I can remember to reverse the volume buttons order when in a column when I come back from out of town?
1 Like
fahrer
November 26, 2023, 1:46pm
87
@Nerwyn , great job on this card! Thank you for all the work on this, it works great.
1 Like
Yeah its too awesome, I have such a fantastic remote working for all my sources now.
@Nerwyn , is it possible to use keyboard with apple tv? Not managed that yet.
Nerwyn
(Nerwyn)
November 26, 2023, 6:11pm
89
Unfortunately I don’t think there is. I don’t see a way to do so in the Apple TV Home Assistant integration .
According to this thread , the underlying library does support sending text, so it would be possible if this functionality was implemented into the Home Assistant integration.
1 Like
I dont get the icons for nlziet kodi and jellyfin.
how can I get those?
Nerwyn
(Nerwyn)
November 27, 2023, 11:30pm
91
You’d have to add custom svg icons for them as described here . You could also use CSS to instead use an image as described here .
Nerwyn
(Nerwyn)
November 28, 2023, 4:48pm
93
For Smartube I’m using the card default YouTube source vnd.youtube://
. It does throw an error message at the bottom of the screen saying it can’t process the intent but it works anyway. Have you tried any of the alternates for YouTube or Smartube in the Android TV deep linking guide? ?
As for examples there a section in the README in custom keys and sources that has this example:
custom_sources:
max:
icon: hbo
source: hbomax://deeplink
With source being found using the deep linking guide.
1 Like
Thanks for your reply, i missed the deep link part my apologies.
1 Like
Nerwyn
(Nerwyn)
December 3, 2023, 9:42am
95
I’ve just released v3.1.0, which adds jinja2-like templating using nunjucks.
Because this uses nunjucks to recreate Home Assistant templating, I have to reimplement some of its functions as described in the Home Assistant templating documentation . So far the following functions are implemented:
states
is_state
state_attr
is_state_attr
has_value
iif
match_media
Here’s some examples of using templates with this card:
rows:
- - '{{ "navigation_buttons" if match_media("(orientation: landscape)") else "navigation_touchpad" }}'
- - '{{ "sunroom_light" if is_state("light.sunroom_ceiling", "off") else "volume_slider" }}'
custom_keys:
sunroom_light:
icon: >-
{{ iif(is_state("light.sunroom_ceiling", "on"), "mdi:ceiling-light",
"mdi:ceiling-light-outline") }}
service: light.toggle
data:
entity_id: light.sunroom_ceiling
style:
color: |
{% if is_state("light.sunroom_ceiling", "on") %}
rgb({{ state_attr("light.sunroom_ceiling", "rgb_color") }})
{% endif %}
Note: You still need to use VALUE
for slider service call data.
2 Likes
giof94is
(giof)
December 3, 2023, 5:14pm
96
Hi @Nerwyn , thanks a lot for your amazing card, works like a charm!
Here my custom config for a Samsung SmartTV, integrated with HA using ha-samsungtv-smart (GitHub - ollo69/ha-samsungtv-smart: 📺 Home Assistant SamsungTV Smart Component with simplified SmartThings API Support configurable from User Interface. ).
Hope it can help other using this amazing card!
type: custom:android-tv-card
media_player_id: media_player.samsung_tv_75_salotto_ci
custom_icons:
dazn: >-
m14.774 8.291.772-2.596.79 2.596zm3.848
2.268-2.025-6.128c-.045-.135-.097-.224-.154-.266a.497.497 0 0
0-.28-.063h-1.12a.485.485 0 0 0-.284.068c-.06.045-.11.132-.149.261l-2.045
6.128c-.025.032-.038.096-.038.192 0 .149.09.223.27.223h.84c.076 0
.139-.003.187-.01a.207.207 0 0 0 .116-.048.326.326 0 0 0
.077-.116c.022-.051.046-.119.072-.202l.318-1.071h2.306l.327
1.051c.026.09.051.16.077.213a.395.395 0 0 0
.087.12c.031.028.07.047.114.053h.002c.045.006.103.01.173.01h.897c.18 0
.27-.074.27-.223a.59.59 0 0 0-.005-.09.878.878 0 0
0-.036-.108l.003.006zm-.994 2.467h-.646c-.168
0-.279.024-.333.072-.055.049-.082.147-.082.295v3.638l-1.91-3.647c-.076-.155-.152-.253-.226-.295-.074-.041-.204-.063-.39-.063h-.599c-.167
0-.278.025-.332.073-.055.048-.082.147-.082.294v6.138c0
.148.025.246.077.294.052.048.16.072.328.072h.656c.167 0
.278-.024.332-.072.055-.048.082-.146.082-.294v-3.648l1.91
3.657c.077.155.152.253.227.295.073.042.204.062.39.062h.598c.167 0
.278-.024.333-.072.054-.048.082-.146.082-.294v-6.138c0-.148-.028-.246-.082-.294-.055-.048-.166-.073-.333-.073zm3.203-.581
1.665 1.665v8.385H1.505V14.11l1.663-1.664a.63.63 0 0 0 0-.89L1.504
9.891V1.505h20.991v8.384l-1.665 1.666a.63.63 0 0 0 0 .89zM24
0H0v10.613L1.387 12 0 13.387V24h24V13.387L22.613 12 24 10.613zM10.67
18.469H7.96l2.855-4.014a.67.67 0 0 0 .087-.155.425.425 0 0 0
.019-.135v-.772c0-.148-.028-.246-.082-.294-.055-.048-.166-.073-.334-.073H6.382c-.149
0-.245.028-.29.082-.045.055-.068.169-.068.343v.58c0
.172.023.287.068.341.045.055.141.083.29.083h2.545L6.11 18.469a.438.438 0 0
0-.107.27v.792c0 .148.027.245.082.294.055.048.167.072.334.072h4.25c.148 0
.245-.027.29-.081.045-.055.068-.17.068-.344v-.579c0-.173-.023-.287-.068-.342-.045-.055-.142-.082-.29-.082zM9.408
8.233c0 .264-.017.484-.052.661a1.08 1.08 0 0 1-.174.43.648.648 0 0
1-.318.231 1.523 1.523 0 0 1-.487.068h-.79v-4.17h.79c.366 0
.63.11.79.324.16.215.241.571.241
1.067v1.389zm1.38-2.789c-.225-.457-.533-.795-.921-1.013-.39-.219-.88-.328-1.47-.328H6.418c-.167
0-.278.024-.333.072-.054.049-.082.147-.082.294v6.138c0
.148.028.246.082.295.055.048.166.072.333.072h2.218c1.048 0 1.765-.447
2.15-1.342.09-.205.153-.413.188-.622a4.91 4.91 0 0 0
.054-.796V6.911c0-.367-.018-.656-.054-.868a2.2 2.2 0 0 0-.193-.612l.006.013z
custom_keys:
'0':
icon: mdi:numeric-0
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_0
'1':
icon: mdi:numeric-1
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_1
'2':
icon: mdi:numeric-2
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_2
'3':
icon: mdi:numeric-3
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_3
'4':
icon: mdi:numeric-4
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_4
'5':
icon: mdi:numeric-5
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_5
'6':
icon: mdi:numeric-6
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_6
'7':
icon: mdi:numeric-7
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_7
'8':
icon: mdi:numeric-8
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_8
'9':
icon: mdi:numeric-9
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_9
up:
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_UP
down:
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_DOWN
left:
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_LEFT
right:
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_RIGHT
center:
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_ENTER
power:
icon: mdi:power
service: media_player.toggle
target:
entity_id: media_player.samsung_tv_75_salotto_ci
home:
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_HOME
back:
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_RETURN
volume_mute:
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_MUTE
ch_up:
icon: mdi:arrow-up-bold
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_CHUP
ch_down:
icon: mdi:arrow-down-bold
service: media_player.play_media
data:
entity_id: media_player.samsung_tv_75_salotto_ci
media_content_type: send_key
media_content_id: KEY_CHDOWN
DAZN:
icon: dazn
service: media_player.select_source
data:
entity_id: media_player.samsung_tv_75_salotto_ci
source: DAZN
netflix:
icon: mdi:netflix
service: media_player.select_source
data:
entity_id: media_player.samsung_tv_75_salotto_ci
source: Netflix
youtube:
icon: mdi:youtube
service: media_player.select_source
data:
entity_id: media_player.samsung_tv_75_salotto_ci
source: YouTube
light_off:
icon: mdi:lightbulb-group-off
service: light.turn_off
target:
entity_id: light.all_lights
light_on:
icon: mdi:lightbulb
service: light.turn_on
target:
entity_id: light.soggiorno
rows:
- - power
- null
- volume_mute
- null
- light_on
- light_off
- - volume_slider
- - null
- - ch_up
- ch_down
- - null
- - netflix
- youtube
- DAZN
- primevideo
- spotify
- - navigation_touchpad
- - back
- home
- - 1
- 2
- 3
- 4
- 5
- - 6
- 7
- 8
- 9
- 0
1 Like
Searched a bit and am having trouble with one thing. Is there a way to define a source button for Kodi? I haven’t managed to figure it out yet.
I’ve got a Sony XR 65a83j, and it has the function to turn off the screen (while leaving the TV itself on) in the TV hotbar, a very handy function for using TV to play music. Do you know if and how it would be possible to configure this to have it as a dedicated button I can press on my phone to turn off the screen?
Also I have an app “TV Bro”, which is essentially a browser on my TV. Any idea how I can pull this browser app source, and also navigate inside of it via my mobile phone (is there even a way to just navigate via “mouse”, but via mobile?)
musonilo
(Musonilo)
December 12, 2023, 12:38pm
99
Hello Nerwyn
Thanks for the great work. I started using your card a few weeks ago. I tried your latest nunchuck update to animate buttons. I dont know why the new buttons work on my galaxy tab-s3 tablet but they don’t work on my laptop and s22ultra phone. Actually the icons dont show up on the card but they work when you touch on their supposed places on the screen.
Can you please advice how can I solve this problem
This is a picture from the non working version from my laptop, Normally the card is full of buttons but the buttons with conditional icons with nunchucks dont show up. only buttons with normal icons show up.
Nerwyn
(Nerwyn)
December 12, 2023, 3:25pm
100
99% of the time Inconsistent behavior between modern devices is a caching issue. Have you tried clearing browser cache on or restarting the non-working devices?
Nerwyn
(Nerwyn)
December 12, 2023, 3:27pm
101
Not sure what a TV hotbar is, but you’d have to figure out if this command is being sent via IR, RF, ADB, the remote API, or something Sony proprietary, and then figure out if it’s possible to call that from Home Assistant.
For creating new sources, see this thread: Android TV Remote - App Links/Deep Linking - Guide . I’m also not sure about 1:1 mouse control on Android TV. I know it’s possible on Windows using Unified Remote, but I don’t think the 1:1 mouse capability of that is possible on Home Assistant.
Nerwyn
(Nerwyn)
December 12, 2023, 3:30pm
102
I’m not a Kodi user, but if there is a way to do it it would be in the Kodi JSON-RPC API documentation .
Thx to this project, very cool and handy to control my media devices.
Here an example of my popup control with a logitech harmony. It is based on the Rounded Theme which you can find here
[01_Title]
Hey there! I wanted to share something with this wonderful community that has already been so helpful to me regarding my own Home Assistant installation. A while back, I sent in my dashboard for Everything Smart Home’s video and I noticed there was quite a bit of interest in how I built it. So, it’s about time I finally shared my process.
This is my Rounded dashboard made for our mobile devices. It’s my second dashboard that I’ve created using various custom cards made by other ama…
type: custom:android-tv-card
remote_id: remote.wohnzimmer
slider_id: media_player.denon_avr_2113
button_style:
width: 100px
height: 100px
border-radius: 20px
background: var(--contrast3)
'--size': 32px
touchpad_style:
height: 200px
background: url( '{{ state_attr("media_player.vu_wohnzimmer", "entity_picture") }}') center no-repeat
background-color: var(--contrast3)
slider_style:
'--border-radius': 12px
height: 24px
'--background-height': 12px
'--color': var(--contrast18)
'--background': var(--contrast3)
rows:
- - exit
- home
- power
- - menu
- channelup
- channeldown
- - volume_slider
- - navigation_touchpad
- - red
- green
- yellow
- blue
custom_keys:
power:
icon: mdi:power
service: select.select_option
service_data:
entity_id: select.wohnzimmer_activities
option: power_off
style:
color: |
{% if is_state("select.wohnzimmer_activities", "Fernsehen") %}
var(--black)
{% endif %}
background: |
{% if is_state("select.wohnzimmer_activities", "Fernsehen") %}
var(--red)
{% elif is_state("select.wohnzimmer_activities", "power_off") %}
var(--green)
{% endif %}
menu:
icon: mdi:menu
service: remote.send_command
service_data:
device: 26195962
command: Menu
entity_id: remote.wohnzimmer
channelup:
icon: mdi:arrow-up-circle
service: remote.send_command
service_data:
device: 26195962
command: ChannelUp
entity_id: remote.wohnzimmer
channeldown:
icon: mdi:arrow-down-circle
service: remote.send_command
service_data:
device: 26195962
command: ChannelDown
entity_id: remote.wohnzimmer
yellow:
entity: remote.wohnzimmer
icon: mdi:circle
service: remote.send_command
service_data:
device: 26195962
command: Yellow
entity_id: remote.wohnzimmer
style:
border-radius: 22px
background: var(--contrast3)
color: var(--yellow)
height: 40px
'--size': 25px
width: 75px
blue:
entity: remote.wohnzimmer
icon: mdi:circle
service: remote.send_command
service_data:
device: 26195962
command: Blue
entity_id: remote.wohnzimmer
style:
border-radius: 22px
background: var(--contrast3)
color: var(--blue)
height: 40px
'--size': 25px
width: 75px
red:
entity: remote.wohnzimmer
icon: mdi:circle
service: remote.send_command
service_data:
device: 26195962
command: Red
entity_id: remote.wohnzimmer
style:
border-radius: 22px
background: var(--contrast3)
color: var(--red)
height: 40px
'--size': 25px
width: 75px
green:
entity: remote.wohnzimmer
icon: mdi:circle
service: remote.send_command
service_data:
device: 26195962
command: Green
entity_id: remote.wohnzimmer
style:
border-radius: 22px
background: var(--contrast3)
color: var(--green)
height: 40px
'--size': 25px
width: 75px
up:
icon: mdi:arrow-up-bold
service: remote.send_command
entity: remote.wohnzimmer
service_data:
device: 26195962
command: DirectionUp
entity_id: remote.wohnzimmer
right:
icon: mdi:arrow-right-bold
service: remote.send_command
service_data:
device: 26195962
command: DirectionRight
entity_id: remote.wohnzimmer
left:
icon: mdi:arrow-left-bold
service: remote.send_command
service_data:
device: 26195962
command: DirectionLeft
entity_id: remote.wohnzimmer
down:
icon: mdi:arrow-down-bold
service: remote.send_command
service_data:
device: 26195962
command: DirectionDown
entity_id: remote.wohnzimmer
center:
icon: mdi:circle-outline
service: remote.send_command
service_data:
device: 26195962
command: OK
entity_id: remote.wohnzimmer
exit:
icon: mdi:keyboard-return
service: remote.send_command
service_data:
device: 26195962
command: Exit
entity_id: remote.wohnzimmer
3 Likes