- Introduced `IAiExtractionService` and its implementation `AiExtractionService` for processing images and extracting text. - Created `AiResultItem` model to hold results from AI extraction. - Added `ImageProcessingCoordinator` to manage image processing tasks and provide progress updates. - Implemented view models for AI settings, path settings, processing state, race upload settings, and visual settings to support UI binding. - Updated `Program.cs` to register new services and dependencies. - Modified project file to skip MinVer execution during local builds.
54 lines
3.4 KiB
XML
54 lines
3.4 KiB
XML
<UserControl xmlns="https://github.com/avaloniaui"
|
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
xmlns:avaloniaDataGrid="clr-namespace:Avalonia.Controls;assembly=Avalonia.Controls.DataGrid"
|
|
x:Class="ImageCatalog_2.AvaloniaViews.AiTabView">
|
|
<Grid>
|
|
<Grid.RowDefinitions>
|
|
<RowDefinition Height="Auto" />
|
|
<RowDefinition Height="*" />
|
|
</Grid.RowDefinitions>
|
|
|
|
<ScrollViewer Grid.Row="0" VerticalScrollBarVisibility="Auto">
|
|
<StackPanel Margin="4">
|
|
<TextBlock Text="AI / OCR" FontWeight="Bold" />
|
|
<CheckBox Content="Estrai numeri dalle immagini" IsChecked="{Binding ExtractNumbers}" Margin="0,6,0,0" />
|
|
|
|
<TextBlock Text="Modelli" FontWeight="Bold" Margin="0,8,0,0" />
|
|
<Grid Margin="0,4,0,0" ColumnDefinitions="Auto,*,Auto,Auto">
|
|
<TextBlock Text="Cartella modelli:" VerticalAlignment="Center" Margin="0,0,8,0" Grid.Column="0" />
|
|
<TextBox Text="{Binding ModelsFolderPath, Mode=TwoWay}" Grid.Column="1" VerticalAlignment="Center" />
|
|
<Button Width="88" Margin="6,0,0,0" Command="{Binding SelectModelsFolderCommand}"
|
|
Grid.Column="2" Content="Scegli..." />
|
|
<Button Width="56" Margin="6,0,0,0" Grid.Column="3"
|
|
Click="OpenModelsFolder_Click" Content="Apri" />
|
|
</Grid>
|
|
|
|
<StackPanel Orientation="Horizontal" HorizontalAlignment="Left" Margin="0,8,0,0" Spacing="8">
|
|
<Button Content="Avvia AI" Command="{Binding StartAiCommand}" Width="120" />
|
|
<Button Content="Annulla" Command="{Binding AsyncCancelOperationCommand}" Width="120" />
|
|
</StackPanel>
|
|
|
|
<TextBlock Text="Output CSV" FontWeight="Bold" Margin="0,8,0,0" />
|
|
<Grid Margin="0,4,0,0" ColumnDefinitions="Auto,*,Auto,Auto">
|
|
<TextBlock Text="Percorso CSV:" VerticalAlignment="Center" Margin="0,0,8,0" Grid.Column="0" />
|
|
<TextBox Text="{Binding CsvOutputPath, Mode=TwoWay}" Grid.Column="1" VerticalAlignment="Center" />
|
|
<Button Width="88" Margin="6,0,0,0" Command="{Binding SelectCsvOutputCommand}"
|
|
Grid.Column="2" Content="Scegli..." />
|
|
<Button Width="56" Margin="6,0,0,0" Grid.Column="3"
|
|
Click="OpenCsvOutputFolder_Click" Content="Apri" />
|
|
</Grid>
|
|
|
|
<TextBlock Text="Anteprima risultati" FontWeight="Bold" Margin="0,8,0,0" />
|
|
<ProgressBar Minimum="0" Maximum="100" Value="{Binding AiProgress}" Height="16" Margin="0,4,0,4" />
|
|
</StackPanel>
|
|
</ScrollViewer>
|
|
|
|
<avaloniaDataGrid:DataGrid Grid.Row="1" ItemsSource="{Binding PreviewResults}" IsReadOnly="True"
|
|
AutoGenerateColumns="False" Margin="4,4,4,4" CanUserResizeColumns="True" VerticalAlignment="Stretch">
|
|
<avaloniaDataGrid:DataGrid.Columns>
|
|
<avaloniaDataGrid:DataGridTextColumn Header="Path" Binding="{Binding Path}" Width="*" />
|
|
<avaloniaDataGrid:DataGridTextColumn Header="Text" Binding="{Binding Text}" Width="2*" />
|
|
</avaloniaDataGrid:DataGrid.Columns>
|
|
</avaloniaDataGrid:DataGrid>
|
|
</Grid>
|
|
</UserControl>
|