deform11.0怎样增加工具条

deform11.0怎样增加工具条,第1张

*** 作步骤:

1、新建MFC工程,找到“资源视图”界面,找不到资源视图的,或者不小心关闭了,可以通过快捷键(cotrl+shift+e),或者在视图->其他窗口中找到资源视图界面。

2、右键添加资源,可以找到以下类型,其中就有Toolbar,点击新建即可。

3、添加的工具条可以修改属性,主要是工具条的ID,方便后面调用。

4、逐个添加工具条里面的各个工具,可以在网上下载、截图。然后在此界面右键粘贴即可。

5、导入图标后,可以通过打开外部编辑器在画图工具下编辑图标。导入的每个图标记得要修改ID属性。

6、经过上面的步骤,图标的导入已经完成了。就可以创建工具条了。

Toolbar是Android 5.0中引入的一个新控件。好比是ActionBar升级版,但是相比ActionBar,Toolbar变得更加自由,可以放到任何位置。

由于我们平常开发app要兼容5.0以下的手机,所以使用Toolbar必须引用appcompat-v7兼容包,Android studio新建的工程默认是引用了appcompat-v7。

使用Toolbar替代ActionBar,使用的主题必须是没有ActionBar的,否则会造成冲突。因此修改style.xml中主题样式,继承Theme.AppCompat.NoActionBar

这种情况一般发生在你想利用ActionBar现有的一些功能(比如能够显示菜单中的 *** 作项,响应菜单点击事件,使用ActionBarDrawerToggle等),但是又想获得比actionbar更多的控制权限。

那么当前Activity需要继承AppCompatActivity,调用setSupportActionBar方法传入Toolbar的实例对象。

这种情况当前Activity可以不继承AppCompatActivity。

以上步骤完成后,Toolbar就添加到了页面中。

Toolbar在ActionBar原有的设计基础上又将标题栏分为了多个区域,如下从Google找到的一张示例图所示:

大抵来说,配置常用的几个元素就如图中所示:

设置导航按钮,比如作为返回按钮。

在Toolbar当作ActionBar来使用的情况下:

注意setNavigationIcon需要放在 setSupportActionBar之后才会生效。

可以使用ActionBar原有方法来添加一个系统的返回按钮。

可以通过setNavigationOnClickListener设置其点击事件。

设置图标(图中写错了,应该是setLogo)

设置主标题。

在Toolbar当作ActionBar来使用的情况下:

setDisplayShowTitleEnabled需要设置为false,setTitle才能有效。

设置副标题

设置菜单的点击事件,如果Toolbar当作ActionBar来使用的话,还可以直接在onOptionsItemSelected(MenuItem item)中设置。

关于Toolbar的初步使用就这么多,在Toolbar当作ActionBar使用的情况下,能用ActionBar原有方法实现的功能尽量用其方法实现,不能实现的再考虑使用Toolbar的方法,举个例子,像菜单构建设置监听什么的,直接使用Activity提供的方法就好了。

你可以使用支持包提供了新的AppCompatDelegate构件,很容易地将Toolbar添加到Activity上。

1,将Toolbar控件添加到布局文件上面

ActionBar现在已经被不再被告维护了,它应该被Toolbar取代,因为后者允许了更多的UI灵活性,并且允许Activity更容易地兼容于材料设计的UI模式。

因为我们要在这使用支持包,那么我们将使用Toolbar的支持版本,不然的话,将只能在API 21+上可用。

在xml中添加如下内容:

1 <android.support.v7.widget.Toolbar

2 android:id="@+id/my_awesome_toolbar"

3 android:layout_height="@dimen/abc_action_bar_

4 default_height_material"

5 android:layout_width="match_parent"

6 android:minHeight="@dimen/abc_action_bar_

7 default_height_material"

8 android:background="?attr/colorPrimary"

9 />

2,修改主题:

因为我们要将Toolbar嵌入到布局文件中,所以我们需要不支持ActionBar的主题。

所以,在确定在styles.xml文件中使用主题Theme.AppCompat.NoActionBar。

特别推荐,要在你的主题上添加如下所示的材料设计色彩项,这将很容易地实现对Toolbar和状态栏的着色(只有API 21+的设备上才会对状态栏进行着色):

1 <!-- Base application theme. -->

2 <style name="AppTheme" parent="Theme.AppCompat.NoActionBar">

3 <!-- colorPrimary is used for coloring the Toolbar -->

4 <item name="colorPrimary">#3F51B5</item>

5 <!-- colorPrimaryDark is used for coloring the status bar -->

6 <item name="colorPrimaryDark">#303F9F</item>

7 <!-- colorAccent is used as the default value for colorControlActivated

8 which is used to tint widgets -->

9 <item name="colorAccent">#FFAB40</item>

10 </style>

3,将AppCompatDelegate添加到Activity里面

AppCompatDelegate是一个委托代表,它将AppCompatActivity的特性提供给Activity,而且只能通过create()方法创建,此时它需要两个参数,Activity和AppCompatCallback。

所以,首先,我们将Activity实现AppCompatCallback接口,在本例中,可以不必具体实现要覆盖的方法。

1 public class MainActivity extends Activity implements AppCompatCallback {

2 @Override

3 public void onSupportActionModeStarted(ActionMode mode) {

4 //let's leave this empty, for now

5 }

6 @Override

7 public void onSupportActionModeFinished(ActionMode mode) {

8 // let's leave this empty, for now

9 }

10 }

然后,在Activity的onCreate()方法中,

通过AppCompatDelegate.create()方法创建AppCompatDelegate;

调用AppCompatDelegate.create();(有些Activity的生命周期方法应用由该AppCompatDelegate代理)

通过AppCompatDelegate.setContentView()方法填充布局文件;

通过AppCompatDelegate.setSupportActionbar()将Toolbar添加给AppCompatDelegate。

1 private AppCompatDelegate delegate

2 @Override

3 protected void onCreate(Bundle savedInstanceState) {

4 super.onCreate(savedInstanceState)

5 //let's create the delegate, passing the activity at both arguments (Activity, AppCompatCallback)

6 delegate = AppCompatDelegate.create(this, this)

7 //we need to call the onCreate() of the AppCompatDelegate

8 delegate.onCreate(savedInstanceState)

9 //we use the delegate to inflate the layout

10 delegate.setContentView(R.layout.activity_main)

11 //Finally, let's add the Toolbar

12 Toolbar toolbar= (Toolbar) findViewById(R.id.my_awesome_toolbar)

13 delegate.setSupportActionBar(toolbar)

14 }

特别推荐,一个Activity只能链接到一个AppCompatDelegate实例,因此通过create()方法返回的实例应该保存在Activity里面直到该Activity被销毁。

现在,你已经完成了,运行你的应用,然后你的Activity将会魔法一般拥有一个Toolbar,而且看起来完全你是材料设计的AppCompatActivity!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11355627.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存