Skip to content

Commit 331ee6a

Browse files
Add ability to view camera images in VR
1 parent 913d940 commit 331ee6a

File tree

9 files changed

+146
-14
lines changed

9 files changed

+146
-14
lines changed

unity/Assets/Fetch VR/Scenes/Fetch VR.unity

+94-7
Original file line numberDiff line numberDiff line change
@@ -1925,6 +1925,92 @@ MonoBehaviour:
19251925
m_Flags: 0
19261926
m_Reference: {fileID: 7779212132400271959, guid: c348712bda248c246b8c49b3db54643f, type: 3}
19271927
m_ButtonPressPoint: 0.5
1928+
--- !u!1 &896847980
1929+
GameObject:
1930+
m_ObjectHideFlags: 0
1931+
m_CorrespondingSourceObject: {fileID: 0}
1932+
m_PrefabInstance: {fileID: 0}
1933+
m_PrefabAsset: {fileID: 0}
1934+
serializedVersion: 6
1935+
m_Component:
1936+
- component: {fileID: 896847981}
1937+
- component: {fileID: 896847984}
1938+
- component: {fileID: 896847983}
1939+
- component: {fileID: 896847982}
1940+
m_Layer: 5
1941+
m_Name: Image
1942+
m_TagString: Untagged
1943+
m_Icon: {fileID: 0}
1944+
m_NavMeshLayer: 0
1945+
m_StaticEditorFlags: 0
1946+
m_IsActive: 1
1947+
--- !u!224 &896847981
1948+
RectTransform:
1949+
m_ObjectHideFlags: 0
1950+
m_CorrespondingSourceObject: {fileID: 0}
1951+
m_PrefabInstance: {fileID: 0}
1952+
m_PrefabAsset: {fileID: 0}
1953+
m_GameObject: {fileID: 896847980}
1954+
m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
1955+
m_LocalPosition: {x: 0, y: 0, z: 0}
1956+
m_LocalScale: {x: 1, y: 1, z: 1}
1957+
m_Children: []
1958+
m_Father: {fileID: 2147003913}
1959+
m_RootOrder: 1
1960+
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
1961+
m_AnchorMin: {x: 0.5, y: 0.5}
1962+
m_AnchorMax: {x: 0.5, y: 0.5}
1963+
m_AnchoredPosition: {x: 0, y: -100}
1964+
m_SizeDelta: {x: 960, y: 720}
1965+
m_Pivot: {x: 0.5, y: 0.5}
1966+
--- !u!114 &896847982
1967+
MonoBehaviour:
1968+
m_ObjectHideFlags: 0
1969+
m_CorrespondingSourceObject: {fileID: 0}
1970+
m_PrefabInstance: {fileID: 0}
1971+
m_PrefabAsset: {fileID: 0}
1972+
m_GameObject: {fileID: 896847980}
1973+
m_Enabled: 1
1974+
m_EditorHideFlags: 0
1975+
m_Script: {fileID: 11500000, guid: efe44a7eced089545a3f9044719bad73, type: 3}
1976+
m_Name:
1977+
m_EditorClassIdentifier:
1978+
compressedImageTopic: /head_camera/rgb/image_raw/compressed
1979+
--- !u!114 &896847983
1980+
MonoBehaviour:
1981+
m_ObjectHideFlags: 0
1982+
m_CorrespondingSourceObject: {fileID: 0}
1983+
m_PrefabInstance: {fileID: 0}
1984+
m_PrefabAsset: {fileID: 0}
1985+
m_GameObject: {fileID: 896847980}
1986+
m_Enabled: 1
1987+
m_EditorHideFlags: 0
1988+
m_Script: {fileID: 11500000, guid: 1344c3c82d62a2a41a3576d8abb8e3ea, type: 3}
1989+
m_Name:
1990+
m_EditorClassIdentifier:
1991+
m_Material: {fileID: 0}
1992+
m_Color: {r: 1, g: 1, b: 1, a: 1}
1993+
m_RaycastTarget: 1
1994+
m_RaycastPadding: {x: 0, y: 0, z: 0, w: 0}
1995+
m_Maskable: 1
1996+
m_OnCullStateChanged:
1997+
m_PersistentCalls:
1998+
m_Calls: []
1999+
m_Texture: {fileID: 0}
2000+
m_UVRect:
2001+
serializedVersion: 2
2002+
x: 0
2003+
y: 0
2004+
width: 1
2005+
height: 1
2006+
--- !u!222 &896847984
2007+
CanvasRenderer:
2008+
m_ObjectHideFlags: 0
2009+
m_CorrespondingSourceObject: {fileID: 0}
2010+
m_PrefabInstance: {fileID: 0}
2011+
m_PrefabAsset: {fileID: 0}
2012+
m_GameObject: {fileID: 896847980}
2013+
m_CullTransparentMesh: 1
19282014
--- !u!4 &914276583 stripped
19292015
Transform:
19302016
m_CorrespondingSourceObject: {fileID: 5728026746976872579, guid: 34a694434569ac240b18eed0ee0ad068, type: 3}
@@ -1948,7 +2034,7 @@ GameObject:
19482034
m_Icon: {fileID: 0}
19492035
m_NavMeshLayer: 0
19502036
m_StaticEditorFlags: 0
1951-
m_IsActive: 1
2037+
m_IsActive: 0
19522038
--- !u!4 &923452953
19532039
Transform:
19542040
m_ObjectHideFlags: 0
@@ -2838,8 +2924,8 @@ RectTransform:
28382924
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
28392925
m_AnchorMin: {x: 0.5, y: 0.5}
28402926
m_AnchorMax: {x: 0.5, y: 0.5}
2841-
m_AnchoredPosition: {x: 0, y: 300}
2842-
m_SizeDelta: {x: 1800, y: 400}
2927+
m_AnchoredPosition: {x: 0, y: 370}
2928+
m_SizeDelta: {x: 960, y: 180}
28432929
m_Pivot: {x: 0.5, y: 0.5}
28442930
--- !u!114 &1767593087
28452931
MonoBehaviour:
@@ -2862,13 +2948,13 @@ MonoBehaviour:
28622948
m_PersistentCalls:
28632949
m_Calls: []
28642950
m_FontData:
2865-
m_Font: {fileID: 10102, guid: 0000000000000000e000000000000000, type: 0}
2866-
m_FontSize: 96
2951+
m_Font: {fileID: 12800000, guid: 0c6946011f1762d4ead1561e0e19bc21, type: 3}
2952+
m_FontSize: 72
28672953
m_FontStyle: 0
28682954
m_BestFit: 0
28692955
m_MinSize: 1
28702956
m_MaxSize: 256
2871-
m_Alignment: 4
2957+
m_Alignment: 6
28722958
m_AlignByGeometry: 0
28732959
m_RichText: 1
28742960
m_HorizontalOverflow: 0
@@ -3105,7 +3191,7 @@ MonoBehaviour:
31053191
armGroupName: arm
31063192
targetLinkName: gripper_link
31073193
targetLinkTransform: {fileID: 312825479}
3108-
useVisibilityConstraint: 1
3194+
useVisibilityConstraint: 0
31093195
visibilityConstraintWeight: 0
31103196
sensorFrameId: head_camera_link
31113197
targetVisibilityTransform: {fileID: 923452953}
@@ -3220,6 +3306,7 @@ RectTransform:
32203306
m_LocalScale: {x: 1, y: 1, z: 1}
32213307
m_Children:
32223308
- {fileID: 1767593086}
3309+
- {fileID: 896847981}
32233310
m_Father: {fileID: 413338642}
32243311
m_RootOrder: 0
32253312
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
using RosMessageTypes.Sensor;
2+
using Unity.Robotics.ROSTCPConnector.MessageGeneration;
3+
using Unity.Robotics.ROSTCPConnector;
4+
using UnityEngine.UI;
5+
using UnityEngine;
6+
7+
public class CompressedImageViewer : MonoBehaviour
8+
{
9+
[SerializeField] private string compressedImageTopic;
10+
11+
private RawImage rawImage;
12+
13+
private ROSConnection rosConnection;
14+
15+
public void Start()
16+
{
17+
rawImage = gameObject.GetComponent<RawImage>();
18+
Debug.Assert(rawImage != null);
19+
20+
rosConnection = ROSConnection.GetOrCreateInstance();
21+
rosConnection.Subscribe<CompressedImageMsg>(compressedImageTopic, (compressedImage) =>
22+
{
23+
rawImage.texture = compressedImage.ToTexture2D();
24+
});
25+
}
26+
}

unity/Assets/Fetch VR/Scripts/Behaviours/CompressedImageViewer.cs.meta

+11
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

unity/Assets/Fetch VR/Scripts/Behaviours/MoveGroupController.cs

+3-3
Original file line numberDiff line numberDiff line change
@@ -141,9 +141,9 @@ private void PlanTrajectory()
141141
case ResultState.Rejected:
142142
state = State.HasFailedPlan;
143143

144-
var errorId = result.error_code.val;
145-
var errorMessage = result.error_code.GetErrorMessage();
146-
feedbackText.text = $"Plan has failed: {errorMessage}!";
144+
// var errorId = result.error_code.val;
145+
// var errorMessage = result.error_code.GetErrorMessage();
146+
feedbackText.text = "Plan has failed!";
147147

148148
tintColor = Color.red;
149149
tintColor.a = 0.5f;

unity/Assets/Fetch VR/Scripts/Extensions/ROSExtensions.cs

+1-1
Original file line numberDiff line numberDiff line change
@@ -49,7 +49,7 @@ public static string GetErrorMessage(this MoveItErrorCodesMsg errorMessage)
4949
MoveItErrorCodesMsg.INVALID_ROBOT_STATE => "Invalid robot state",
5050
MoveItErrorCodesMsg.MOTION_PLAN_INVALIDATED_BY_ENVIRONMENT_CHANGE => "Motion plan invalidated by environment change",
5151
MoveItErrorCodesMsg.NO_IK_SOLUTION => "No IK solution",
52-
MoveItErrorCodesMsg.PLANNING_FAILED => "Planning failed",
52+
MoveItErrorCodesMsg.PLANNING_FAILED => "Planning has failed",
5353
MoveItErrorCodesMsg.PREEMPTED => "Preempted",
5454
MoveItErrorCodesMsg.ROBOT_STATE_STALE => "Robot state stale",
5555
MoveItErrorCodesMsg.SENSOR_INFO_STALE => "Sensor info stale",

unity/Assets/Fetch VR/Scripts/Robotics/ROSActionClient.cs

-2
Original file line numberDiff line numberDiff line change
@@ -176,8 +176,6 @@ private void HandleStatus(GoalStatusArrayMsg goalStatusArray)
176176

177177
private void HandleTransition(GoalState previousState, GoalTransition goalTransition, GoalState newState)
178178
{
179-
Debug.Log($"{previousState.ToString()} {goalTransition.ToString()} {newState.ToString()}");
180-
181179
goalState = newState;
182180

183181
switch (goalState)

unity/Assets/Resources/ROSConnectionPrefab.prefab

+1-1
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,7 @@ MonoBehaviour:
4343
m_Script: {fileID: 11500000, guid: 7acef0b79454c9b4dae3f8139bc4ba77, type: 3}
4444
m_Name:
4545
m_EditorClassIdentifier:
46-
m_RosIPAddress: 192.168.1.4
46+
m_RosIPAddress: 192.168.1.7
4747
m_RosPort: 10000
4848
m_ConnectOnStart: 1
4949
m_KeepaliveTime: 1

unity/Packages/manifest.json

+1
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
"com.unity.ide.rider": "2.0.7",
55
"com.unity.ide.visualstudio": "2.0.14",
66
"com.unity.ide.vscode": "1.2.5",
7+
"com.unity.recorder": "2.5.7",
78
"com.unity.robotics.ros-tcp-connector": "https://github.com/Unity-Technologies/ROS-TCP-Connector.git?path=/com.unity.robotics.ros-tcp-connector",
89
"com.unity.robotics.urdf-importer": "https://github.com/Unity-Technologies/URDF-Importer.git?path=/com.unity.robotics.urdf-importer",
910
"com.unity.robotics.visualizations": "https://github.com/Unity-Technologies/ROS-TCP-Connector.git?path=/com.unity.robotics.visualizations",

unity/Packages/packages-lock.json

+9
Original file line numberDiff line numberDiff line change
@@ -57,6 +57,15 @@
5757
},
5858
"url": "https://packages.unity.com"
5959
},
60+
"com.unity.recorder": {
61+
"version": "2.5.7",
62+
"depth": 0,
63+
"source": "registry",
64+
"dependencies": {
65+
"com.unity.timeline": "1.0.0"
66+
},
67+
"url": "https://packages.unity.com"
68+
},
6069
"com.unity.robotics.ros-tcp-connector": {
6170
"version": "https://github.com/Unity-Technologies/ROS-TCP-Connector.git?path=/com.unity.robotics.ros-tcp-connector",
6271
"depth": 0,

0 commit comments

Comments
 (0)