add media player
This commit is contained in:
parent
6ee4b8dbe0
commit
1d06821736
74
content/entities/media_player/media_player.gd
Normal file
74
content/entities/media_player/media_player.gd
Normal file
|
@ -0,0 +1,74 @@
|
|||
extends StaticBody3D
|
||||
|
||||
@export var entity_id = "media_player.bedroomspeaker"
|
||||
|
||||
@onready var previous = $Previous
|
||||
@onready var next = $Next
|
||||
@onready var play = $Play
|
||||
@onready var logo = $PlayingInfo/Logo
|
||||
@onready var title = $PlayingInfo/Title
|
||||
@onready var artist = $PlayingInfo/Artist
|
||||
@onready var http_request = $PlayingInfo/HTTPRequest
|
||||
|
||||
var playing = false
|
||||
|
||||
# Called when the node enters the scene tree for the first time.
|
||||
func _ready():
|
||||
var stateInfo = await HomeApi.get_state(entity_id)
|
||||
set_state(stateInfo)
|
||||
|
||||
await HomeApi.watch_state(entity_id, func(new_state):
|
||||
set_state(new_state)
|
||||
)
|
||||
|
||||
previous.on_button_down.connect(func():
|
||||
HomeApi.set_state(entity_id, "previous")
|
||||
)
|
||||
|
||||
play.on_button_down.connect(func():
|
||||
if playing:
|
||||
HomeApi.set_state(entity_id, "pause")
|
||||
else:
|
||||
HomeApi.set_state(entity_id, "play")
|
||||
)
|
||||
|
||||
next.on_button_down.connect(func():
|
||||
HomeApi.set_state(entity_id, "next")
|
||||
)
|
||||
|
||||
|
||||
func set_state(stateInfo):
|
||||
var state = stateInfo["state"]
|
||||
|
||||
print("State changed to ", stateInfo)
|
||||
|
||||
if state == "playing":
|
||||
if stateInfo["attributes"].has("entity_picture_local"):
|
||||
load_image(stateInfo["attributes"]["entity_picture_local"])
|
||||
title.text = stateInfo["attributes"]["media_title"]
|
||||
artist.text = stateInfo["attributes"]["media_artist"]
|
||||
|
||||
playing = true
|
||||
play.label = "pause"
|
||||
else:
|
||||
playing = false
|
||||
play.label = "play_arrow"
|
||||
|
||||
func load_image(url: String):
|
||||
http_request.request("http://192.168.33.33:8123" + url)
|
||||
|
||||
var result = await http_request.request_completed
|
||||
|
||||
if result[0] != HTTPRequest.RESULT_SUCCESS:
|
||||
print("Error loading image: ", result[0], " ", result[1])
|
||||
return
|
||||
|
||||
var image = Image.new()
|
||||
var error = image.load_jpg_from_buffer(result[3])
|
||||
|
||||
if error != OK:
|
||||
print("Error loading image: ", error)
|
||||
return
|
||||
|
||||
var texture = ImageTexture.create_from_image(image)
|
||||
logo.texture = texture
|
|
@ -1,14 +1,57 @@
|
|||
[gd_scene load_steps=2 format=3 uid="uid://dyktdg7ggiwl4"]
|
||||
[gd_scene load_steps=5 format=3 uid="uid://dyktdg7ggiwl4"]
|
||||
|
||||
[ext_resource type="PackedScene" uid="uid://bsjqdvkt0u87c" path="res://content/ui/components/button/button.tscn" id="1_8opk3"]
|
||||
[ext_resource type="Script" path="res://content/entities/media_player/media_player.gd" id="1_ame17"]
|
||||
[ext_resource type="Script" path="res://content/functions/movable.gd" id="3_bguto"]
|
||||
|
||||
[node name="Node3D" type="Node3D"]
|
||||
[sub_resource type="BoxShape3D" id="BoxShape3D_vi3eg"]
|
||||
size = Vector3(0.23, 0.07, 0.01)
|
||||
|
||||
[node name="Button" parent="." instance=ExtResource("1_8opk3")]
|
||||
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, -4.65661e-08, 0, 0)
|
||||
[node name="MediaPlayer" type="StaticBody3D"]
|
||||
script = ExtResource("1_ame17")
|
||||
|
||||
[node name="Button2" parent="." instance=ExtResource("1_8opk3")]
|
||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="."]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, -0.01)
|
||||
shape = SubResource("BoxShape3D_vi3eg")
|
||||
|
||||
[node name="Previous" parent="." instance=ExtResource("1_8opk3")]
|
||||
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, -0.07, 0, 0)
|
||||
label = "skip_previous"
|
||||
icon = true
|
||||
|
||||
[node name="Button3" parent="." instance=ExtResource("1_8opk3")]
|
||||
[node name="Play" parent="." instance=ExtResource("1_8opk3")]
|
||||
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, -4.65661e-08, 0, 0)
|
||||
label = "pause"
|
||||
icon = true
|
||||
|
||||
[node name="Next" parent="." instance=ExtResource("1_8opk3")]
|
||||
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, 0.07, 0, 0)
|
||||
label = "skip_next"
|
||||
icon = true
|
||||
|
||||
[node name="PlayingInfo" type="Node3D" parent="."]
|
||||
|
||||
[node name="Title" type="Label3D" parent="PlayingInfo"]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, -0.09, 0.07, 0)
|
||||
pixel_size = 0.001
|
||||
text = "All Falls Down"
|
||||
font_size = 24
|
||||
outline_size = 4
|
||||
horizontal_alignment = 0
|
||||
|
||||
[node name="Artist" type="Label3D" parent="PlayingInfo"]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, -0.09, 0.05, 0)
|
||||
pixel_size = 0.001
|
||||
text = "Alan Walker"
|
||||
font_size = 16
|
||||
outline_size = 4
|
||||
horizontal_alignment = 0
|
||||
|
||||
[node name="Logo" type="Sprite3D" parent="PlayingInfo"]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0.15, 0)
|
||||
pixel_size = 0.001
|
||||
|
||||
[node name="HTTPRequest" type="HTTPRequest" parent="PlayingInfo"]
|
||||
|
||||
[node name="Movable" type="Node" parent="."]
|
||||
script = ExtResource("3_bguto")
|
||||
|
|
|
@ -3,6 +3,7 @@ extends Object
|
|||
const Switch = preload("res://content/entities/switch/switch.tscn")
|
||||
const Light = preload("res://content/entities/light/light.tscn")
|
||||
const Sensor = preload("res://content/entities/sensor/sensor.tscn")
|
||||
const MediaPlayer = preload("res://content/entities/media_player/media_player.tscn")
|
||||
|
||||
static func create_entity(type: String, id: String):
|
||||
var entity = null
|
||||
|
@ -14,6 +15,8 @@ static func create_entity(type: String, id: String):
|
|||
entity = Light.instantiate()
|
||||
"sensor":
|
||||
entity = Sensor.instantiate()
|
||||
"media_player":
|
||||
entity = MediaPlayer.instantiate()
|
||||
_:
|
||||
return null
|
||||
|
||||
|
|
|
@ -4,6 +4,7 @@ const wall_corner_scene = preload("./wall_corner.tscn")
|
|||
const wall_edge_scene = preload("./wall_edge.tscn")
|
||||
|
||||
@onready var teleport_root = $TeleportRoot
|
||||
@onready var background = $Background
|
||||
@onready var wall_corners = $TeleportRoot/WallCorners
|
||||
@onready var wall_edges = $TeleportRoot/WallEdges
|
||||
@onready var wall_mesh = $TeleportRoot/WallMesh
|
||||
|
@ -16,6 +17,7 @@ var edit_enabled = false
|
|||
|
||||
func _ready():
|
||||
remove_child(teleport_root)
|
||||
background.visible = false
|
||||
get_tree().get_root().get_node("Main").add_child.call_deferred(teleport_root)
|
||||
|
||||
teleport_root.get_node("Ground/Clickable").on_click.connect(func(event):
|
||||
|
|
|
@ -6,7 +6,7 @@ runnable=true
|
|||
dedicated_server=false
|
||||
custom_features=""
|
||||
export_filter="all_resources"
|
||||
include_filter="*.j2"
|
||||
include_filter="*.j2,*.woff2"
|
||||
exclude_filter=""
|
||||
export_path="builds/android/immersive-home.apk"
|
||||
encryption_include_filters=""
|
||||
|
|
|
@ -6,7 +6,7 @@ runnable=false
|
|||
dedicated_server=false
|
||||
custom_features=""
|
||||
export_filter="all_resources"
|
||||
include_filter="*.j2"
|
||||
include_filter="*.j2,*.woff2"
|
||||
exclude_filter=""
|
||||
export_path="builds/android/immersive-home.apk"
|
||||
encryption_include_filters=""
|
||||
|
|
|
@ -245,6 +245,15 @@ func set_state(entity: String, state: String, attributes: Dictionary = {}):
|
|||
service = 'turn_on'
|
||||
elif state == 'off':
|
||||
service = 'turn_off'
|
||||
elif domain == 'media_player':
|
||||
if state == 'play':
|
||||
service = 'media_play'
|
||||
elif state == "pause":
|
||||
service = "media_pause"
|
||||
elif state == "next":
|
||||
service = "media_next_track"
|
||||
elif state == "previous":
|
||||
service = "media_previous_track"
|
||||
|
||||
if service == null:
|
||||
return null
|
||||
|
|
Loading…
Reference in New Issue
Block a user