-
Notifications
You must be signed in to change notification settings - Fork 175
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
D ui3 305 agis implement highlight for individual features e.g. from receive report #3529
Merged
oguzhankoral
merged 12 commits into
dui3/alpha
from
DUI3-305-AGIS-Implement-highlight-for-individual-features-e.g.-from-receive-report
Jul 1, 2024
Merged
Changes from all commits
Commits
Show all changes
12 commits
Select commit
Hold shift + click to select a range
f9706ea
introduce ObjectID constructor
KatKatKateryna 05adfe9
adapt BasicBindings highlight to use ObjectId struct
KatKatKateryna d64f854
select individual features
KatKatKateryna 4820b86
Merge branch 'dui3/alpha' into DUI3-305-AGIS-Implement-highlight-for-…
KatKatKateryna 1d3987d
update missing tracker Items
KatKatKateryna e405a1d
query features by ID for selection
KatKatKateryna 882057d
Merge branch 'dui3/alpha' into DUI3-305-AGIS-Implement-highlight-for-…
KatKatKateryna 79e22de
separate struct for MapMembers
KatKatKateryna 7320352
add comments
KatKatKateryna 6f5e062
formatting
KatKatKateryna 6108841
formatting
KatKatKateryna e7f798a
Merge branch 'dui3/alpha' into DUI3-305-AGIS-Implement-highlight-for-…
oguzhankoral File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
16 changes: 16 additions & 0 deletions
16
DUI3-DX/Connectors/ArcGIS/Speckle.Connectors.ArcGIS3/Utils/MapMemberFeature.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
using ArcGIS.Desktop.Mapping; | ||
|
||
namespace Speckle.Connectors.ArcGIS.Utils; | ||
|
||
// bind together a layer object on the map, and auto-assigned ID if the specific feature | ||
public readonly struct MapMemberFeature | ||
{ | ||
public int? FeatureId { get; } // unique feature id (start from 0) of a feature in the layer | ||
public MapMember MapMember { get; } // layer object on the Map | ||
|
||
public MapMemberFeature(MapMember mapMember, int? featureId) | ||
{ | ||
MapMember = mapMember; | ||
FeatureId = featureId; | ||
} | ||
} |
38 changes: 38 additions & 0 deletions
38
DUI3-DX/Connectors/ArcGIS/Speckle.Connectors.ArcGIS3/Utils/ObjectID.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
namespace Speckle.Connectors.ArcGIS.Utils; | ||
|
||
// this struct is needed to be able to parse single-string value into IDs of both a layer, and it's individual feature | ||
public struct ObjectID | ||
{ | ||
private const string FEATURE_ID_SEPARATOR = "__speckleFeatureId__"; | ||
public string MappedLayerURI { get; } // unique ID of the layer on the map | ||
public int? FeatureId { get; } // unique feature id (start from 0) of a feature in the layer | ||
|
||
public ObjectID(string encodedId) | ||
{ | ||
List<string> stringParts = encodedId.Split(FEATURE_ID_SEPARATOR).ToList(); | ||
MappedLayerURI = stringParts[0]; | ||
FeatureId = null; | ||
if (stringParts.Count > 1) | ||
{ | ||
FeatureId = Convert.ToInt32(stringParts[1]); | ||
} | ||
} | ||
|
||
public ObjectID(string layerId, int? featureId) | ||
{ | ||
MappedLayerURI = layerId; | ||
FeatureId = featureId; | ||
} | ||
|
||
public readonly string ObjectIdToString() | ||
{ | ||
if (FeatureId == null) | ||
{ | ||
return $"{MappedLayerURI}"; | ||
} | ||
else | ||
{ | ||
return $"{MappedLayerURI}{FEATURE_ID_SEPARATOR}{FeatureId}"; | ||
} | ||
} | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would omit MapMember from this struct, it is confusing why objectID checks for MapMember as below.
What I expect from
ObjectID
is just id, if you include MapMember it becomes something else. In this case, we might need another struct that has MapMember too instead considering its nullability onObjectID
struct.