HighlightMarker.MAUI
4.0.15
See the version list below for details.
dotnet add package HighlightMarker.MAUI --version 4.0.15
NuGet\Install-Package HighlightMarker.MAUI -Version 4.0.15
<PackageReference Include="HighlightMarker.MAUI" Version="4.0.15" />
paket add HighlightMarker.MAUI --version 4.0.15
#r "nuget: HighlightMarker.MAUI, 4.0.15"
// Install HighlightMarker.MAUI as a Cake Addin #addin nuget:?package=HighlightMarker.MAUI&version=4.0.15 // Install HighlightMarker.MAUI as a Cake Tool #tool nuget:?package=HighlightMarker.MAUI&version=4.0.15
<img src="https://raw.githubusercontent.com/thomasgalliker/HighlightMarker/develop/Images/logo_cropped.png" ><br> HighlightMarker is a library which supports you in highlighting text of a UI label. This can be particularly helpful if you want to highlight the user's search input e.g. in a list of text items.
Xamarin Android | Xamarin iOS | Windows Presentation Foundation |
---|---|---|
<img src="/Images/Screenshot.Android.png" width="190"> | <img src="/Images/Screenshot.iOS.png" width="190"> | <img src="/Images/Screenshot.WPF.png" width="190"> |
Download and Install HighlightMarker
This library is available on NuGet: https://www.nuget.org/packages/HighlightMarker/ Use the following command to install HighlightMarker using NuGet package manager console:
PM> Install-Package HighlightMarker
The library is compatible with .NET Framework 4.5+, .NET 5+ and .NET Standard 1.0+. There is a special NuGet package for Xamarin.Forms available:
PM> Install-Package HighlightMarker.Forms
How to use HighlightMarker
Essentially, HighlightMarker tells you from/to which character of a given text you need to start/stop highlighting the user's search input. To explain how HighlightMarker works, it's best to consult the a simple unit test. Following test shows how a given FullText
is highlighted with the string in variable SearchText
:
// Arrange
const string FullText = "full text for highlight marking";
const string SearchText = "highlight";
var highlightMarker = new HighlightMarker(FullText, SearchText);
// Act
var highlightList = highlightMarker.ToList();
// Assert
...
In order to make this highlighting logic accessible to any UI, there is a couple of platform-specific implementations for UI text highlighting. Have a look at the following subchapters:
Using HighlightMarker in Xamarin.Forms
In the folder Samples\HighlightMarker.Forms you can find a Xamarin.Forms demo project which displays a searchable list of shopping malls. The <ViewCell.View>
defines a custom cell template for the malls list. The most interesting part are the custom bindings named TextHighlightBehavior.HighlightedText
and TextHighlightBehavior.FullText
. All you need to do is binding the HighlightedText property to the search string (in our case we reference the Text property of the SearchBar) and binding the FullText property to the ViewModel property.
<Label forms:TextHighlightBehavior.HighlightedText="{Binding Text, Source={x:Reference SearchBar}}"
forms:TextHighlightBehavior.FullText="{Binding Title}" />
Using HighlightMarker in Native Xamarin.Android projects
Create a custom ListFragment and update each list item's content (which can be a custom FrameLayouts for example) when the highlight text has changed. There is an extension method TextViewExtensions.HighlightText
for highlighting the text of a TextView
object.
Using HighlightMarker in Native Xamarin.iOS projects
The sample project HighlightMarkerSample.iOS illustrates how to use HighlightMarker in Xamarin.iOS projects. CustomTableViewCell (which is an implementation of UITableViewCell) is responsible for updating the highlighting. UILabelExtensions
contains an extension method HighlightText
which is used to highlight the text of a UILabel.
public class CustomTableViewCell : UITableViewCell
{
private readonly UILabel headingLabel;
private readonly UILabel subheadingLabel;
public CustomTableViewCell(NSString cellId) : base(UITableViewCellStyle.Default, cellId)
{
//...
}
public void UpdateCell(string caption, string subtitle, UIImage image, string searchText)
{
this.headingLabel.Text = caption;
this.headingLabel.HighlightText(searchText, UIColor.Blue);
this.subheadingLabel.Text = subtitle;
this.subheadingLabel.HighlightText(searchText, UIColor.Blue);
}
//...
Feedback
Let me know your optinion and how we can improve this project. You are kindly invited to write an issue if you want to discuss problems and/or propose new features. Contributors are highly welcome!
License
HighlightMarker is Copyright © 2023 Thomas Galliker. Free for non-commercial use. For commercial use please contact the author.
Sources
https://developer.xamarin.com/recipes/ios/standard_controls/text_field/style_text/
https://www.syntaxismyui.com/xamarin-forms-searchbar-recipe/
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-android31.0 is compatible. net6.0-ios was computed. net6.0-ios16.1 is compatible. net6.0-maccatalyst was computed. net6.0-maccatalyst16.1 is compatible. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net6.0-windows10.0.19041 is compatible. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net6.0
- No dependencies.
-
net6.0-android31.0
- No dependencies.
-
net6.0-ios16.1
-
net6.0-maccatalyst16.1
-
net6.0-windows10.0.19041
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
4.0.16-pre | 195 | 4/12/2023 |
4.0.15 | 2,337 | 3/28/2023 |
4.0.5-pre | 179 | 12/31/2022 |