コンテンツにスキップ
メインメニュー
メインメニュー
サイドバーに移動
非表示
案内
メインページ
最近の更新
未作成ページ
おまかせ表示
ヘルプ
MonoBook
検索
検索
ログイン
個人用ツール
ログイン
ログアウトした編集者のページ
もっと詳しく
投稿記録
トーク
「
MAUIのXAMLでボタンの中身をViewにしたい
」を編集中
ページ
議論
日本語
閲覧
編集
ソースを編集
履歴表示
ツール
ツール
サイドバーに移動
非表示
操作
閲覧
編集
ソースを編集
履歴表示
全般
リンク元
関連ページの更新状況
特別ページ
ページ情報
警告:
ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。
ログイン
または
アカウントを作成
すれば、あなたの編集はその利用者名とともに表示されるほか、その他の利点もあります。
スパム攻撃防止用のチェックです。 けっして、ここには、値の入力は
しない
でください!
MAUIのButtonの中身をXAMLの図形機能でベクター画像として描画しようと思ったがMAUIのButtonの中に別Viewは配置できないらしい。 MAUIのButtonクラスはViewの派生クラスでありダイレクトコンテンツをサポートしていないらしい。 Buttonクラスは文字を表示するしかできない。 まじでゴミ。 Gridなどで代用しようと試みたがGridにはClickedなどのイベントも見当たらない。 まじでゴミ。 == 解決策:ContentView派生クラスのボタンを作る == ViewではなくContentViewを基底クラスとするボタンを作る。 <source lang="csharp"> using System; using Microsoft.Maui.Controls; public class ContentButton : ContentView { public event EventHandler? Clicked; public ContentButton() { var tapGestureRecognizer = new TapGestureRecognizer(); tapGestureRecognizer.Tapped += (s, e) => Clicked?.Invoke(this, e); GestureRecognizers.Add(tapGestureRecognizer); } } </source> こんな感じで使う。 <source lang="xml"> <?xml version="1.0" encoding="utf-8" ?> <ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui" xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml" xmlns:local="using:Capture8" x:Class="Capture8.MainPage"> <StackLayout> <!-- スマホのカメラによくある撮影ボタンのようなもの --> <local:ContentButton BackgroundColor="CornflowerBlue" WidthRequest="80" HeightRequest="80" HorizontalOptions="CenterAndExpand" VerticalOptions="CenterAndExpand" Clicked="OnCaptureButtonClicked" > <Grid> <Ellipse WidthRequest="70" HeightRequest="70" Fill="Red" /> <Ellipse WidthRequest="60" HeightRequest="60" Fill="White" /> </Grid> </local:ContentButton> </StackLayout> </ContentPage> </source> [[category: MAUI]]
編集内容の要約:
MonoBookへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細は
MonoBook:著作権
を参照)。
著作権保護されている作品は、許諾なしに投稿しないでください!
このページを編集するには、下記の確認用の質問に回答してください (
詳細
):
1たす1は?(全角で入力してください)
キャンセル
編集の仕方
(新しいウィンドウで開きます)
本文の横幅制限を有効化/無効化