Skip to content

Commit 535bc43

Browse files
Merge pull request #1 from SyncfusionExamples/Update-the-sample
KB : Updated the sample
2 parents e0d1132 + e186d8b commit 535bc43

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

42 files changed

+9289
-2
lines changed

GetDataPointsSample/App.xaml

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
<?xml version = "1.0" encoding = "UTF-8" ?>
2+
<Application xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
3+
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
4+
xmlns:local="clr-namespace:CircleDataPoints"
5+
x:Class="CircleDataPoints.App">
6+
<Application.Resources>
7+
<ResourceDictionary>
8+
<ResourceDictionary.MergedDictionaries>
9+
<ResourceDictionary Source="Resources/Styles/Colors.xaml" />
10+
<ResourceDictionary Source="Resources/Styles/Styles.xaml" />
11+
</ResourceDictionary.MergedDictionaries>
12+
</ResourceDictionary>
13+
</Application.Resources>
14+
</Application>

GetDataPointsSample/App.xaml.cs

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
namespace CircleDataPoints
2+
{
3+
public partial class App : Application
4+
{
5+
public App()
6+
{
7+
InitializeComponent();
8+
}
9+
10+
protected override Window CreateWindow(IActivationState? activationState)
11+
{
12+
return new Window(new AppShell());
13+
}
14+
}
15+
}

GetDataPointsSample/AppShell.xaml

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
<?xml version="1.0" encoding="UTF-8" ?>
2+
<Shell
3+
x:Class="CircleDataPoints.AppShell"
4+
xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
5+
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
6+
xmlns:local="clr-namespace:CircleDataPoints"
7+
Shell.FlyoutBehavior="Flyout"
8+
Title="CircleDataPoints">
9+
10+
<ShellContent
11+
ContentTemplate="{DataTemplate local:MainPage}"
12+
Route="MainPage" />
13+
14+
</Shell>
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
namespace CircleDataPoints
2+
{
3+
public partial class AppShell : Shell
4+
{
5+
public AppShell()
6+
{
7+
InitializeComponent();
8+
}
9+
}
10+
}
Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
<Project Sdk="Microsoft.NET.Sdk">
2+
3+
<PropertyGroup>
4+
<TargetFrameworks>net9.0-android;net9.0-ios;net9.0-maccatalyst</TargetFrameworks>
5+
<TargetFrameworks Condition="$([MSBuild]::IsOSPlatform('windows'))">$(TargetFrameworks);net9.0-windows10.0.19041.0</TargetFrameworks>
6+
<!-- Uncomment to also build the tizen app. You will need to install tizen by following this: https://github.com/Samsung/Tizen.NET -->
7+
<!-- <TargetFrameworks>$(TargetFrameworks);net9.0-tizen</TargetFrameworks> -->
8+
9+
<!-- Note for MacCatalyst:
10+
The default runtime is maccatalyst-x64, except in Release config, in which case the default is maccatalyst-x64;maccatalyst-arm64.
11+
When specifying both architectures, use the plural <RuntimeIdentifiers> instead of the singular <RuntimeIdentifier>.
12+
The Mac App Store will NOT accept apps with ONLY maccatalyst-arm64 indicated;
13+
either BOTH runtimes must be indicated or ONLY macatalyst-x64. -->
14+
<!-- For example: <RuntimeIdentifiers>maccatalyst-x64;maccatalyst-arm64</RuntimeIdentifiers> -->
15+
16+
<OutputType>Exe</OutputType>
17+
<RootNamespace>CircleDataPoints</RootNamespace>
18+
<UseMaui>true</UseMaui>
19+
<SingleProject>true</SingleProject>
20+
<ImplicitUsings>enable</ImplicitUsings>
21+
<Nullable>enable</Nullable>
22+
23+
<!-- Display name -->
24+
<ApplicationTitle>CircleDataPoints</ApplicationTitle>
25+
26+
<!-- App Identifier -->
27+
<ApplicationId>com.companyname.circledatapoints</ApplicationId>
28+
29+
<!-- Versions -->
30+
<ApplicationDisplayVersion>1.0</ApplicationDisplayVersion>
31+
<ApplicationVersion>1</ApplicationVersion>
32+
33+
<!-- To develop, package, and publish an app to the Microsoft Store, see: https://aka.ms/MauiTemplateUnpackaged -->
34+
<WindowsPackageType>None</WindowsPackageType>
35+
36+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'ios'">15.0</SupportedOSPlatformVersion>
37+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'maccatalyst'">15.0</SupportedOSPlatformVersion>
38+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'android'">21.0</SupportedOSPlatformVersion>
39+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'windows'">10.0.17763.0</SupportedOSPlatformVersion>
40+
<TargetPlatformMinVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'windows'">10.0.17763.0</TargetPlatformMinVersion>
41+
<SupportedOSPlatformVersion Condition="$([MSBuild]::GetTargetPlatformIdentifier('$(TargetFramework)')) == 'tizen'">6.5</SupportedOSPlatformVersion>
42+
</PropertyGroup>
43+
44+
<ItemGroup>
45+
<!-- App Icon -->
46+
<MauiIcon Include="Resources\AppIcon\appicon.svg" ForegroundFile="Resources\AppIcon\appiconfg.svg" Color="#512BD4" />
47+
48+
<!-- Splash Screen -->
49+
<MauiSplashScreen Include="Resources\Splash\splash.svg" Color="#512BD4" BaseSize="128,128" />
50+
51+
<!-- Images -->
52+
<MauiImage Include="Resources\Images\*" />
53+
<MauiImage Update="Resources\Images\dotnet_bot.png" Resize="True" BaseSize="300,185" />
54+
55+
<!-- Custom Fonts -->
56+
<MauiFont Include="Resources\Fonts\*" />
57+
58+
<!-- Raw Assets (also remove the "Resources\Raw" prefix) -->
59+
<MauiAsset Include="Resources\Raw\**" LogicalName="%(RecursiveDir)%(Filename)%(Extension)" />
60+
</ItemGroup>
61+
62+
<ItemGroup>
63+
<PackageReference Include="Microsoft.Maui.Controls" Version="$(MauiVersion)" />
64+
<PackageReference Include="Microsoft.Extensions.Logging.Debug" Version="9.0.0" />
65+
<PackageReference Include="Syncfusion.Maui.Toolkit" Version="*" />
66+
</ItemGroup>
67+
68+
</Project>
Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
2+
Microsoft Visual Studio Solution File, Format Version 12.00
3+
# Visual Studio Version 17
4+
VisualStudioVersion = 17.13.35931.197
5+
MinimumVisualStudioVersion = 10.0.40219.1
6+
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "CircleDataPoints", "CircleDataPoints.csproj", "{65EF48D8-F297-4B96-B360-C778C4A04F2F}"
7+
EndProject
8+
Global
9+
GlobalSection(SolutionConfigurationPlatforms) = preSolution
10+
Debug|Any CPU = Debug|Any CPU
11+
Release|Any CPU = Release|Any CPU
12+
EndGlobalSection
13+
GlobalSection(ProjectConfigurationPlatforms) = postSolution
14+
{65EF48D8-F297-4B96-B360-C778C4A04F2F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
15+
{65EF48D8-F297-4B96-B360-C778C4A04F2F}.Debug|Any CPU.Build.0 = Debug|Any CPU
16+
{65EF48D8-F297-4B96-B360-C778C4A04F2F}.Debug|Any CPU.Deploy.0 = Debug|Any CPU
17+
{65EF48D8-F297-4B96-B360-C778C4A04F2F}.Release|Any CPU.ActiveCfg = Release|Any CPU
18+
{65EF48D8-F297-4B96-B360-C778C4A04F2F}.Release|Any CPU.Build.0 = Release|Any CPU
19+
EndGlobalSection
20+
GlobalSection(SolutionProperties) = preSolution
21+
HideSolutionNode = FALSE
22+
EndGlobalSection
23+
GlobalSection(ExtensibilityGlobals) = postSolution
24+
SolutionGuid = {6104B410-52B3-479D-B10F-F7C43ED5AA65}
25+
EndGlobalSection
26+
EndGlobal
Lines changed: 115 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,115 @@
1+
using Syncfusion.Maui.Toolkit.Charts;
2+
using System;
3+
using System.Collections.Generic;
4+
using System.Linq;
5+
using System.Text;
6+
using System.Threading.Tasks;
7+
8+
namespace CircleDataPoints
9+
{
10+
public class CircleDataPointSelector : ChartInteractiveBehavior, IDrawable
11+
{
12+
13+
private float CenterX;
14+
private float CenterY;
15+
private float radius = 0;
16+
private bool showCircle = false;
17+
18+
public GraphicsView Graphics { get; set; }
19+
20+
public void Draw(ICanvas canvas, RectF dirtyRect)
21+
{
22+
canvas.StrokeColor = Colors.Black;
23+
canvas.StrokeSize = 2;
24+
canvas.FillColor = Colors.Red.WithAlpha(0.2f);
25+
canvas.DrawEllipse(CenterX - radius, CenterY - radius, radius * 2, radius * 2);
26+
}
27+
28+
protected override void OnTouchDown(ChartBase chart, float pointX, float pointY)
29+
{
30+
var seriesBounds = chart.SeriesBounds;
31+
32+
CenterX = (float)(pointX - seriesBounds.Left);
33+
CenterY = (float)(pointY - seriesBounds.Top);
34+
radius = 0;
35+
showCircle = true;
36+
Graphics.Invalidate();
37+
}
38+
39+
protected override void OnTouchMove(ChartBase chart, float pointX, float pointY)
40+
{
41+
if (showCircle)
42+
{
43+
var seriesBounds = chart.SeriesBounds;
44+
45+
// Calculate radius using exact code from clipboard
46+
float dx = (float)(pointX - seriesBounds.Left - CenterX);
47+
float dy = (float)(pointY - seriesBounds.Top - CenterY);
48+
radius = (float)Math.Sqrt(dx * dx + dy * dy);
49+
50+
51+
Graphics.Invalidate();
52+
}
53+
}
54+
55+
protected override void OnTouchUp(ChartBase chart, float pointX, float pointY)
56+
{
57+
if (chart is SfCartesianChart cartesianChart)
58+
{
59+
var viewModel = chart.BindingContext as ScatterSeriesViewModel;
60+
61+
// Create bounding rect for the circle in chart coordinates.
62+
var boundingRect = new Rect(
63+
CenterX - radius,
64+
CenterY - radius,
65+
radius * 2,
66+
radius * 2
67+
);
68+
69+
var selectedIndexes = new List<int>();
70+
71+
foreach (var series in cartesianChart.Series)
72+
{
73+
if (series is ScatterSeries scatterSeries)
74+
{
75+
var rectanglePoints = scatterSeries.GetDataPoints(boundingRect);
76+
77+
if (rectanglePoints != null && viewModel != null)
78+
{
79+
for (int i = 0; i < viewModel.Data.Count; i++)
80+
{
81+
var point = viewModel.Data[i];
82+
83+
if (rectanglePoints.Contains(point))
84+
{
85+
var xAxis = cartesianChart.XAxes[0];
86+
var yAxis = cartesianChart.YAxes[0];
87+
88+
// Convert data coordinates to pixel coordinates
89+
double pixelX = xAxis.ValueToPoint(point.XValue);
90+
double pixelY = yAxis.ValueToPoint(point.YValue);
91+
92+
// Calculate distance from center to this point
93+
double distance = Math.Sqrt(
94+
Math.Pow(pixelX - CenterX, 2) +
95+
Math.Pow(pixelY - CenterY, 2));
96+
97+
// If distance is less than radius, point is in circle
98+
if (distance <= radius)
99+
{
100+
selectedIndexes.Add(i);
101+
}
102+
}
103+
}
104+
105+
scatterSeries.SelectionBehavior.SelectedIndexes = selectedIndexes;
106+
}
107+
}
108+
}
109+
}
110+
111+
showCircle = false;
112+
Graphics.Invalidate();
113+
}
114+
}
115+
}

GetDataPointsSample/MainPage.xaml

Lines changed: 46 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,46 @@
1+
<?xml version="1.0" encoding="utf-8" ?>
2+
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
3+
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
4+
xmlns:chart="clr-namespace:Syncfusion.Maui.Toolkit.Charts;assembly=Syncfusion.Maui.Toolkit"
5+
xmlns:local="clr-namespace:CircleDataPoints"
6+
x:Class="CircleDataPoints.MainPage">
7+
8+
<ContentPage.BindingContext>
9+
<local:ScatterSeriesViewModel x:Name="viewModel"/>
10+
</ContentPage.BindingContext>
11+
12+
<Grid>
13+
<chart:SfCartesianChart>
14+
<chart:SfCartesianChart.PlotAreaBackgroundView>
15+
<GraphicsView Drawable="{x:Reference InteractionExt}" x:Name="graphicsView"
16+
InputTransparent="True"
17+
ZIndex="1"/>
18+
</chart:SfCartesianChart.PlotAreaBackgroundView>
19+
20+
<chart:SfCartesianChart.InteractiveBehavior>
21+
<local:CircleDataPointSelector x:Name="InteractionExt"
22+
Graphics="{x:Reference graphicsView}"/>
23+
</chart:SfCartesianChart.InteractiveBehavior>
24+
25+
<chart:SfCartesianChart.XAxes>
26+
<chart:NumericalAxis RangePadding="Additional"/>
27+
</chart:SfCartesianChart.XAxes>
28+
29+
<chart:SfCartesianChart.YAxes>
30+
<chart:NumericalAxis Interval="2" RangePadding="Additional"/>
31+
</chart:SfCartesianChart.YAxes>
32+
33+
<chart:SfCartesianChart.Series>
34+
<chart:ScatterSeries ItemsSource="{Binding Data}"
35+
XBindingPath="XValue"
36+
YBindingPath="YValue"
37+
PointWidth="8" Opacity="0.8" Fill="#FE7A36" PointHeight="8" >
38+
<chart:ScatterSeries.SelectionBehavior>
39+
<chart:DataPointSelectionBehavior Type="Multiple"
40+
SelectionBrush="#3652AD"/>
41+
</chart:ScatterSeries.SelectionBehavior>
42+
</chart:ScatterSeries>
43+
</chart:SfCartesianChart.Series>
44+
</chart:SfCartesianChart>
45+
</Grid>
46+
</ContentPage>
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
using Microsoft.Maui.Graphics;
2+
using Syncfusion.Maui.Toolkit.Charts;
3+
using System.Collections.ObjectModel;
4+
using System.ComponentModel;
5+
6+
namespace CircleDataPoints
7+
{
8+
public partial class MainPage : ContentPage
9+
{
10+
public MainPage()
11+
{
12+
InitializeComponent();
13+
}
14+
}
15+
}

GetDataPointsSample/MauiProgram.cs

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
using Microsoft.Extensions.Logging;
2+
using Syncfusion.Maui.Toolkit.Hosting;
3+
4+
namespace CircleDataPoints
5+
{
6+
public static class MauiProgram
7+
{
8+
public static MauiApp CreateMauiApp()
9+
{
10+
var builder = MauiApp.CreateBuilder();
11+
builder
12+
.UseMauiApp<App>()
13+
.ConfigureSyncfusionToolkit()
14+
.ConfigureFonts(fonts =>
15+
{
16+
fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular");
17+
fonts.AddFont("OpenSans-Semibold.ttf", "OpenSansSemibold");
18+
});
19+
20+
#if DEBUG
21+
builder.Logging.AddDebug();
22+
#endif
23+
24+
return builder.Build();
25+
}
26+
}
27+
}

0 commit comments

Comments
 (0)