角が丸い境界線と透明度
この質問は、透明度のある丸い境界線を作成して、基礎となるコンポーネントが透けて見えるようにする問題に取り組みます。 。解決策には、TextBubbleBorder クラスを変更して、境界線のクリップ領域の外側の親の背景色をペイントすることが含まれます。
解決策:
TextBubbleBorder クラスに加えられた変更は次のとおりです。 follow:
// Paint the BG color of the parent, everywhere outside the clip // of the text bubble. Component parent = c.getParent(); if (parent!=null) { Color bg = parent.getBackground(); Rectangle rect = new Rectangle(0,0,width, height); Area borderRegion = new Area(rect); borderRegion.subtract(area); g2.setClip(borderRegion); g2.setColor(bg); g2.fillRect(0, 0, width, height); g2.setClip(null); }
このコードは、親コンポーネントとその背景色を取得します。次に、境界領域を表す領域を作成し、そこからバブル領域とポインター領域を減算します。これにより、境界線の外側の領域が定義されます。
クリップ領域を設定すると、コードは親コンポーネントの背景色で領域を塗りつぶし、丸い角の外側の境界線を透明にします。
追加の考慮事項:
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3