Android开发 ShapeDrawable详解
<h1><span style="color: rgba(0, 128, 128, 1)">版权声明</span></h1><p>本文来自博客园,作者:观心静 ,转载请注明原文链接: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)">画圆形 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> </p>
<h1><span style="color: rgba(0, 128, 128, 1)">画半圆 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)">画矩形 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) 这个类一共有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> </p>
<h1><span style="color: rgba(0, 128, 128, 1)">画任意形状 PathShape</span></h1>
<p> 待续....</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]