清香茉莉 發表於 2019-7-6 14:18:00

Android开发 ShapeDrawable详解

<h1><span style="color: rgba(0, 128, 128, 1)">版权声明</span></h1>
<p>本文来自博客园,作者:观心静&nbsp;,转载请注明原文链接:https://www.cnblogs.com/guanxinjing/p/11142590.html</p>
<div>本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。</div>
<h1><span style="color: rgba(0, 128, 128, 1)">前言</span></h1>
<p>  ShapeDrawable一开始我以为它是对应xml文件属性里的shape的画图,后来发现我错了... 其实ShapeDrawable更像是一共自由度更大跟偏向与实现draw()方法的一共图像绘制类.所以,它的优点就是可以有更大的自由在代码里绘制一个你想要的图形,缺点是它搞起来有点不太方便,对于只需要简单的图形还不如GradientDrawable方便.</p>
<p>  ShapeDrawable是靠new一个继承Shape的类,来实现方便你的绘制的(其实底层原理就是View的draw()那套东西).我们可以查到一共有多少个shape,看如下图片:</p>
<p>  <img src="https://img2018.cnblogs.com/blog/1497956/201907/1497956-20190724210153136-1449759748.png" alt=""></p>
<h1><span style="color: rgba(0, 128, 128, 1)">画圆形&nbsp;OvalShape</span></h1>
<div class="cnblogs_code">
<pre>      ShapeDrawable shapeDrawable = <span style="color: rgba(0, 0, 255, 1)">new</span> ShapeDrawable(<span style="color: rgba(0, 0, 255, 1)">new</span><span style="color: rgba(0, 0, 0, 1)"> OvalShape());
      shapeDrawable.getPaint().setColor(Color.BLACK);
      Rect rect </span>= <span style="color: rgba(0, 0, 255, 1)">new</span><span style="color: rgba(0, 0, 0, 1)"> Rect();
      rect.top </span>= 0<span style="color: rgba(0, 0, 0, 1)">;
      rect.left </span>= 0<span style="color: rgba(0, 0, 0, 1)">;
      rect.bottom </span>= 50<span style="color: rgba(0, 0, 0, 1)">;
      rect.right </span>= 50<span style="color: rgba(0, 0, 0, 1)">;
      shapeDrawable.setBounds(rect);
      mTextView.setBackground(shapeDrawable);</span></pre>
</div>
<p>效果图:</p>
<p><img src="https://img2018.cnblogs.com/blog/1497956/201907/1497956-20190724200826758-1626258536.png" alt=""></p>
<p>&nbsp;</p>
<h1><span style="color: rgba(0, 128, 128, 1)">画半圆&nbsp;ArcShape</span></h1>
<div class="cnblogs_code">
<pre>      ShapeDrawable shapeDrawable = <span style="color: rgba(0, 0, 255, 1)">new</span> ShapeDrawable(<span style="color: rgba(0, 0, 255, 1)">new</span> ArcShape(0,180));<span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">ArcShape参数 开始角度startAngle 要画多少角度sweepAngle</span>
<span style="color: rgba(0, 0, 0, 1)">      shapeDrawable.getPaint().setColor(Color.BLACK);
      Rect rect </span>= <span style="color: rgba(0, 0, 255, 1)">new</span><span style="color: rgba(0, 0, 0, 1)"> Rect();
      rect.top </span>= 0<span style="color: rgba(0, 0, 0, 1)">;
      rect.left </span>= 0<span style="color: rgba(0, 0, 0, 1)">;
      rect.bottom </span>= 50<span style="color: rgba(0, 0, 0, 1)">;
      rect.right </span>= 50<span style="color: rgba(0, 0, 0, 1)">;
      shapeDrawable.setBounds(rect);
      mTextView.setBackground(shapeDrawable);</span></pre>
</div>
<p>效果图:</p>
<p><img src="https://img2018.cnblogs.com/blog/1497956/201907/1497956-20190724201448348-1062504162.png" alt=""></p>
<h1><span style="color: rgba(0, 128, 128, 1)">画矩形&nbsp;RectShape</span></h1>
<div class="cnblogs_code">
<pre>      ShapeDrawable shapeDrawable = <span style="color: rgba(0, 0, 255, 1)">new</span> ShapeDrawable(<span style="color: rgba(0, 0, 255, 1)">new</span><span style="color: rgba(0, 0, 0, 1)"> RectShape());
      shapeDrawable.getPaint().setColor(Color.BLACK);
      Rect rect </span>= <span style="color: rgba(0, 0, 255, 1)">new</span><span style="color: rgba(0, 0, 0, 1)"> Rect();
      rect.top </span>= 0<span style="color: rgba(0, 0, 0, 1)">;
      rect.left </span>= 0<span style="color: rgba(0, 0, 0, 1)">;
      rect.bottom </span>= 50<span style="color: rgba(0, 0, 0, 1)">;
      rect.right </span>= 50<span style="color: rgba(0, 0, 0, 1)">;
      shapeDrawable.setBounds(rect);
      mTextView.setBackground(shapeDrawable);</span></pre>
</div>
<p>效果图:</p>
<p><img src="https://img2018.cnblogs.com/blog/1497956/201907/1497956-20190724201605408-1982162121.png" alt=""></p>
<h1><span style="color: rgba(0, 128, 128, 1)">画内外双层矩形,并且有圆角 RoundRectShape</span></h1>
<div class="cnblogs_code">
<pre>      <span style="color: rgba(0, 0, 255, 1)">float</span>[] externalRound = {8, 8, 8, 8, 8, 8, 8, 8};<span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">外部矩形的8个圆角半径,为什么是8个? 因为这个居然是一个角2个半圆组成的(太精细了...)</span>
      RectF distanceRectF = <span style="color: rgba(0, 0, 255, 1)">new</span> RectF(10, 10, 10, 10); <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">内部矩形与外部矩形的距离</span>
      <span style="color: rgba(0, 0, 255, 1)">float</span>[] insideRound = {10, 10, 10, 10, 10, 10, 10, 10}; <span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)">内部矩形的8个圆角半径值</span>
      ShapeDrawable shapeDrawable = <span style="color: rgba(0, 0, 255, 1)">new</span> ShapeDrawable(<span style="color: rgba(0, 0, 255, 1)">new</span><span style="color: rgba(0, 0, 0, 1)"> RoundRectShape(externalRound, distanceRectF, insideRound));
      shapeDrawable.getPaint().setColor(Color.BLACK);
      Rect rect </span>= <span style="color: rgba(0, 0, 255, 1)">new</span><span style="color: rgba(0, 0, 0, 1)"> Rect();
      rect.top </span>= 0<span style="color: rgba(0, 0, 0, 1)">;
      rect.left </span>= 0<span style="color: rgba(0, 0, 0, 1)">;
      rect.bottom </span>= 50<span style="color: rgba(0, 0, 0, 1)">;
      rect.right </span>= 50<span style="color: rgba(0, 0, 0, 1)">;
      shapeDrawable.setBounds(rect);
      mTextView.setBackground(shapeDrawable);</span></pre>
</div>
<p><span style="color: rgba(0, 0, 0, 1)">public RoundRectShape(@Nullable float[] outerRadii, @Nullable RectF inset, @Nullable float[] innerRadii)&nbsp; 这个类一共有3个参数,我在上面的注解已经说明了. </span></p>
<p><span style="color: rgba(0, 0, 0, 1)"><strong>注意!</strong>这3个参数都是可以为null的.意思就是,你可以取消任意一个.获得一些其他效果,比如设置第二个和第三个参数为null,你就可以得到一个实心的圆角矩形.</span></p>
<p>效果图:</p>
<p><img src="https://img2018.cnblogs.com/blog/1497956/201907/1497956-20190724205145840-1497927080.png" alt=""></p>
<p>&nbsp;</p>
<h1><span style="color: rgba(0, 128, 128, 1)">画任意形状 PathShape</span></h1>
<p>&nbsp; 待续....</p>

</div>
<div id="MySignature" role="contentinfo">
    <div style="text-align: center">
    <p style="color:orange;font-size:16px;" >本文来自博客园,作者:观心静 ,转载请注明原文链接:https://www.cnblogs.com/guanxinjing/p/11142590.html </p>
    <div style="color:orange;font-size:16px;">本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。 </div>
</div><br><br>
来源:https://www.cnblogs.com/guanxinjing/p/11142590.html
頁: [1]
查看完整版本: Android开发 ShapeDrawable详解