No.2ベストアンサー
- 回答日時:
ああ、勘違いをしてました。
大変失礼しました。そういうことですと、フォントを探して……という方法は考えられますが、この場合、標準でインストールされていないフォントをどのような形態で配布するか、という問題が出てきます。ですので、やはりグラフィックとして描画するのが最善の道と思います。1つ1つの部品はシンプルな形状ですから、あらかじめ7つの部品の表示のオンオフをセットにしたデータを用0~9の数字分、配列などで用意し、それを参照しながら描画する、という形になるかと思います。
表示の更新は、それほどの正確さを求めないのであれば、Java SEにあるTimerが使えるので、これを利用すれば簡単でしょう。もっとリアルタイム性を持たせたい場合は、SurfaceViewの場合、ScheduledExecutorServiceというものが用意されており、これを使うことでマルチスレッドな処理を実行できるようになります。
スレッドも使えますが、Androidの場合、コンポーネントはマルチスレッド非対応であるため、別スレッドを使うにはけっこう面倒な処理が必要となります。ScheduledExecutorServiceを利用するとこうした問題を回避してコーディングできますので、スレッドよりは、こっちの使い方を覚えて利用した方がいいでしょう。
早速のご返答まことにありがとうございます。
やはりグラフィックでの描画にて実施しようと思います。
また、ScheduledExecutorServiceのご指摘まで本当にありがとうございます。
時間の正確性をどのように実施していくかは次のテーマだったのですがここまでフォローしていただけるとは感激物です;;。
本当にありがとうございました、頑張って作成していつか公開できるところまでたどり着ければと思います。
No.1
- 回答日時:
まず、少し勘違いをされているところがあると思いますが、ウィジェットのセルサイズ(セグ?ではなくて、セルです)は、公式には「占有したいセルの数に74を掛けて2を引く」形で指定されます。
例えばセル2つ分の高さとセル2つ分の幅(計4セル)なら、高さまたは幅のサイズは((74*2)-2)となり、それぞれ146です。この値は、あらかじめAndroidManifest.xmlにandroid:minWidth、android:minHeightとして指定しておきます。つまり、ウィジェットは最初から固定サイズで作成されるわけで、まずそのサイズで作るかを決めておく必要があります。
サイズが決まっていますから、それをもとに最適なフォントサイズを決定し、表示すればいいだけです。固定サイズですから、何度も表示を調整して一番いいサイズを見つけ出せばいいだけでしょう。
ちなみに、個人的にはTextViewなどより、Viewを継承してウィジェットを作り、onDrawでCanvasから描画した方がいいと思いますよ。そのほうが軽くなります。ウィジェットのようなものは、コンポーネントを多用するより、すべてViewなりSurfaceViewなりの単体クラスで作り込んだ方がよいです。常時動作するウィジェットは重いと誰も使いたくなくなります。
なお、最近はホームなどで配置するセル数を変更できるものが増えていますが、これらはホームのアプリ側で無理矢理ウィジェットの表示などを調整しています(ですから、よくウィジェットがはみ出たり表示がずれたりするわけです)。開発する際に、公式にサイズ調整される機能が用意されている訳ではないのです。念のため。
早速のご回答ありがとうございます。
ワタシの質問の書き方がよくなかったようで申し訳ありません。
ウィジェットのセルサイズではなく、実は7セグ=7セグメントディスプレィの意味でした。
デジタル時計で数字を表示させる文字(カクカクの文字)のことです。
TTFでフリーフォントの類ではあったのですが、rootをとってインストールしなければならないこともあり、個人使用ではいいですがあまり一般的ではないかなと思いましてこの質問をさせていただいた次第です。
ご指摘のなかでview継承→onDrawが処理が軽くなるアドバイス、ありがとうございます。
TextViewが簡単かなと思いましたが、上記の理由もあって悩んでいたのですが、Canvas描画の方が軽くなるのということであればこちらを使用したほうがよさそうですね。
貴重なご指摘まことにありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- デスクトップパソコン デジタルってみんな一様に伝送できるんですよね?なのにどうしてCPUのクロックは100Ghzにならない 12 2022/12/13 22:39
- au(KDDI) P30liteで楽天モバイル+POVOにすると、Yahoo!天気ウィジェットが更新されなくなった 3 2022/05/17 05:45
- Android AndroidミラーリングでPCからAndroidを操作するには 4 2022/06/17 11:16
- Android(アンドロイド) 初スマートウォッチを買いたいのですが、種類多すぎて分からなくなりました 2 2023/07/04 11:47
- 戸籍・住民票・身分証明書 マイナンバーカードは廃止すべきですね? 12 2023/06/21 12:27
- その他(趣味・アウトドア・車) フリーライセンス無線家の方々にお伺いします。 合法CBの呼出チャンネルの8チャンネルでCQを出した後 1 2023/03/21 12:49
- Excel(エクセル) Excel ピボットテーブルの表示方法を変更したいのですが、、、(合計値を下部に) 3 2023/06/18 21:10
- Android(アンドロイド) Android携帯のキーボード入力で時間入力を簡単にしたい 1 2023/05/17 02:13
- 時計・電卓・電子辞書 皆さんは腕時計の電池が切れたらどうしますか? 1.メーカーや時計屋さんなどで電池交換してもらう。 2 9 2022/06/05 13:42
- 写真・ビデオ MP4からDVDを作製する簡単な方法を教えて下さい Windows10パソコンとAndroidタブレ 2 2022/11/13 08:19
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルでハイパーリンクのコピー
-
結合されたセルの一部を変更す...
-
エクセルでセル内改行の1行目...
-
Word文書にパスワードをマクロ...
-
エクセル 0:00 の時間をカウン...
-
エクセルのセル内で改行コピー...
-
VBAからのHYPERLINK関数のアド...
-
【Excel】 色の一致するセル数...
-
アクティブセルとそのセルに隣...
-
VBA セル内で改行またはカンマ...
-
エクセルで 来年の曜日の自動設定
-
エクセルの結合セル内に文章を...
-
Excel セル貼り付けができません
-
PowerPointの表内のカンマ
-
【VBA】PDF出力に任意のファイ...
-
EXCELでタイトル行と一番下の行...
-
エクセルで「-3E+06」と...
-
Excelのテーブル上のセルの保護...
-
エクセルでleft関数の結果が表...
-
LINEのこの空白ってどんな意味...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルでハイパーリンクのコピー
-
エクセルでセル内改行の1行目...
-
結合されたセルの一部を変更す...
-
エクセル 0:00 の時間をカウン...
-
エクセルの結合セル内に文章を...
-
【Excel】 色の一致するセル数...
-
エクセルのセル内で改行コピー...
-
アクティブセルとそのセルに隣...
-
エクセルで 来年の曜日の自動設定
-
Excel vba 毎月の第○ △曜日を求...
-
VBAからのHYPERLINK関数のアド...
-
VBA セル内で改行またはカンマ...
-
エクセル 行も列もバラバラの入...
-
Word文書にパスワードをマクロ...
-
エクセルで納期遅れのセルを色...
-
Excel セル貼り付けができません
-
エクセルのセルの右下の角の十...
-
エクセルでセルの1部分を別のセ...
-
word文章をexcelのセル結合した...
-
VBA ダブルクリックでセルの真...
おすすめ情報