Getting_Started----Adding the Action Bar
Action Bar 是在你的app的activity里最重要的的设计元素之一。提供了用户界面特性,主要功能包括:
* 提供一个专用空间来标识应用商标和用户位置
* 为用户常用的操作和行为提供便捷访问点(如搜索)
* 支持导航和视图切换(使用tab或者下拉列表)
如图:
你也应该看:
Implementing Effective Navigation
本文只是讲诉了Action Bar最基本的实现。更多详细信息请参阅Action Bar
大纲:
1.Setting Up the Action Bar
怎么样加你的activity里加一个简单的action bar。不管你的app支持的版本是3.0或者更高,还是低于2.1的版本,都可以通过Android Support Library实现。
2.Adding Action Buttons
怎么在Action Bar里添加用户行为,以及相应用户行为。
3.Styling the Action Bar
怎么定制你的Action Bar的样式和外观。
4.Overlaying the Action Bar
学习怎么叠加你的action bar到你的布局上,及如何让action bar在隐藏和显示之间无缝切换
Setting Up the Action Bar
Action Bar最基本的形式是在左边展示activity的标题和app图标。即使action bar如此简单的使用,它也告诉了用户你是在哪个activity,并且在你的应用里展示统一的标识。如图:
Figure 1. An action bar with the app icon and activity title.
产生一个基本action bar要求有能支持action bar的activity theme. 怎么样获取如此一个theme,取决于你的android sdk 版本。
Support Android 3.0 and Above Only
从android3.0(API 11)开始,action bar使用Theme.Holo(或者它的子类)加到所有的activity里。当设置 “targetSdkVersion” 或者 “minSdkVersion” ,属性的值为“11”或者更高,Theme.Holo是这默认的theme。
因此,为了加action bar到你的activity里,简单的设置sdk版本等于或者高于11.例如:
<manifest ... > <uses-sdk android:minSdkVersion="11" ... /> ... </manifest>
注:如果你用自定义theme,确保你自定义theme使用Theme.Holo的theme之一作为她的父theme。更多详情,see Styling the Action Bar。
Support Android 2.1 and Above
在sdk3.0之下(下至android 2.1)添加action bar时,需要你导入android Support Library包。
参阅Support Library Setup文档,然后导入v7 appcompat库(如果你已下载了库包,遵循Adding libraries with resources指导安装)
如果你已集成了Support Library到你的工程里:
1、更新你的activity让其继承ActionBarActivity,例如:
public class MainActivity extends ActionBarActivity { ... }
2.在你的Manifest.xml里更新<application>标签的Theme使用Theme.AppCompat主题之一。或者在具体的activity上指定Theme;
<activity android:theme="@style/Theme.AppCompat.Light" ... >
注:如果你使用自定义Theme,确保使用Theme.AppCompat主题之一作为你的自定义主题的父Theme.更多详情,see Styling the Action Bar。
现在,当你运行在android2.1及以上的api时,你的activity就拥有了action bar。
记住在Manifest.xml里合理的设置你的API level支持:
<manifest ... > <uses-sdk android:minSdkVersion="7" android: targetSdkVersion="18" /> ... </manifest>
Adding Action Buttons
action bar能添加与你的应用的当前上下文相关的重要的用户功能入口的按钮,这些直接显示在action bar上的icon或者文本被称为action buttons。不适合放在action bar或者不太重要的行为和功能放在action overflow里,见下图:
Figure 1. An action bar with an action button for Search and the action overflow, which reveals additional actions.
Specify the Actions in XML
所有的action button 和在action overflow里的action被定义在XMl menu resources里。为了加action到action bar,在你的工程的res/menu/目录里产生一个新的XML文件。
给每一个你想要include到action bar里的action item添加<item>元素。例如:
res/menu/main_activity_actions.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android" > <!-- Search, should appear as action button --> <item android:id="@+id/action_search" android:icon="@drawable/ic_action_search" android:title="@string/action_search" android:showAsAction="ifRoom" /> <!-- Settings, should always be in the overflow --> <item android:id="@+id/action_settings" android:title="@string/action_settings" android:showAsAction="never" /> </menu>
该声明表示Search action在当空间是有效时应该作为一个action button出现,但是Settings action应该总是出现在overflow。(默认地,所有的actions出现在overflow,但是对应每一个action明晰地声明
你的设计意图是一个好的行为)。
Download action bar icons
To best match the Android iconographyguidelines, you should use icons provided in the Action Bar Icon Pack.
icon属性要求一个图片的资源ID,图片名字跟在@drawable/后, 该名字必须是保存在res/drawable目录下的一个bitmap图片的名字。例如:”@drawable/ic_action_search"指向ic_action_search.png.同样地,
title属性使用string资源。该资源被定义在res/valuses/目录下,像在Building a Simple User Interface里讨论的一样。
注意:当常说icon或者其他的bitmap图片时,你应该提供不同分辨率版本的图片.这将在Support Different Screens里更详细的讨论。
如果你的app使用的是Support Library用于兼容Android2.1及以上版本,showAsAction属性不能用android:命名空间。
因为该属性是Support Library提供的一个属性。你必须定义你的自己的XML命名空间。使用自定义命名空间作为前缀。(自定义XML命名空间应该基于你的app名。但是它可以是你想要的任何名字,仅仅能在你声明它的文件范围内访问。例如:
res/menu/main_activity_actions.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:yourapp="http://schemas.android.com/apk/res-auto" > <!-- Search, should appear as action button --> <item android:id="@+id/action_search" android:icon="@drawable/ic_action_search" android:title="@string/action_search" yourapp:showAsAction="ifRoom" /> ... </menu>
Add the Actions to the Action Bar
为了将menu items放入action bar,在你的action里实现onCreateOptionsMenu()回调方法,该方法用于在相应的Menu对象上渲染menu资源。例如:
@Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu items for use in the action bar MenuInflater inflater = getMenuInflater(); inflater.inflate(R.menu.main_activity_actions, menu); return super.onCreateOptionsMenu(menu); }
Respond to Action Buttons
当用户点击action buttons或者action overflow里的action item,系统调用activity里的onOptionsItemSelected()回调方法。在该方法实现里,在相应的MenuItem上调用getItemId()
确定哪个item被点击 —— 返回ID与声明在相应的<item>元素的android:id属性值相匹配。
@Override public boolean onOptionsItemSelected(MenuItem item) { // Handle presses on the action bar items switch (item.getItemId()) { case R.id.action_search: openSearch(); return true; case R.id.action_settings: openSettings(); return true; default: return super.onOptionsItemSelected(item); } }
Add Up Button for Low-level Activities
并不是所有的页面都是你的app的主入口(不是“home”页面的activities),这些非主activities应该给用户提供导航到它的逻辑activity的方式——通过点击action bar里的Up按钮。
Figure 4. The Up button in Gmail.
当运行在android4.1(API level 16)或者更高的版本,或者使用Support Library的ActionBarActivity时,实现Up导航很简单,只要求你在Manifest文件里声明父Activity,然后enable action bar 里的Up按钮。
例如,下面给出了如何在manifest里声明父activity。
<application ... > ... <!-- The main/home activity (it has no parent activity) --> <activity android:name="com.example.myfirstapp.MainActivity" ...> ... </activity> <!-- A child of the main activity --> <activity android:name="com.example.myfirstapp.DisplayMessageActivity" android:label="@string/title_activity_display_message" android:parentActivityName="com.example.myfirstapp.MainActivity" > <!-- Parent activity meta-data to support 4.0 and lower --> <meta-data android:name="android.support.PARENT_ACTIVITY" android:value="com.example.myfirstapp.MainActivity" /> </activity> </application>
然后通过调用setDisplayHomeAsUpEnabled()方法enable app icon作为Up按钮
@Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_displaymessage); getSupportActionBar().setDisplayHomeAsUpEnabled(true); // If your minSdkVersion is 11 or higher, instead use: // getActionBar().setDisplayHomeAsUpEnabled(true); }
因为系统现在知道MainActivity是DisplayMessageActivity的父activity。当用户点击Up按钮时,系统导航到父activity——你不需要处理Up按钮事件。
更多关于up导航的信息,see Providing Up Navigation
Styling the Action Bar
action bar提供给用户熟悉和可预知的方式执行actions和导航你的app。但是,这并不意味着action bar的样式和风格看起来相同。如果你想要的你的action bar样式更适合你的产品品牌,你能容易通过
Android的 style and theme(http://developer.android.com/guide/topics/ui/themes.html)资源定制你的action bar样式
YOU SHOULD ALSO READ:Android Action Bar Style Generator
Android内置了几个activity themes这些主题包括“dark”或者“light” action bar样式。你也能扩展这些主题更进一步的自定义你的action bar外观。
注:如果你正使用Support Library APIs实现action bar,你必须使用或者重写 Theme.AppCompat系列样式(相比于Theme.Holo系列样式,Theme.Holo在API11或者更高的API才有效)。这样做,你声明的每一个样式属性必须声明两次:一次使用android平台的样式属性(android:属性),一次使用包含在Support Library里的样式属性(appcompat.R.attr属性———这些属性的上下文实际上是你的app)
更多详情参见下面的例子。
Use an Android Theme
Android内置了两个基本的activity主题。这两个主题表明了action bar的颜色
Theme.Holo for a "dark" theme.
Theme.Holo.Light for a "light" theme.
如图:
通过在manifest文件声明,你能在你的整个app范围内使用这些主题样式(在<application>元素上设置android:theme属性),也能将这两个主题样式单独作用于某个activity上(在<activity>元素上设置android:theme)。
例如:
<application android:theme="@android:style/Theme.Holo.Light" ... />
如果你想action bar部分是黑色的样式,而activity的其他部分是亮色的,如图,你可以声明android:theme为Theme.Holo.Light.DarkActionBar主题样式。
当使用Support Library时,你必须使用Theme.AppCompat主题样式:
Theme.AppCompat:"dark"主题
Theme.AppComapt:"light”主题
Theme.AppCompat.Light.DarkActionBar:亮主题,然而action bar是黑色的主题
确保你action bar里icon颜色相比于你的action bar主题颜色是合适的。为了帮助你,action-bar-icon-pack包含了标准的action bar icon。这些icons既适用于Holo light 也适用于Holo dark action bar。
Customize the Background
为了更改action bar的背景,为你的activity产生一个重写了actionBarStyle属性的自定义主题。该属性指向另一个样式,在该样式里你能重写background属性来指定action bar的背景drawable。
如果你的app使用navigation tabs 或者split action bar, 那么你也能使用backgroundStackde和backgroundSplits属性来指定action bar的背景。
注意:你应该给你自定义的主题和样式声明一个合适的父主题。没有父样式,你的action bar将缺少一些样式属性,除非你显示的自己声明它们。
For Android 3.0 and higher only
对应android3.0或者更高的版本,你能定义action bar的背景如下:
res/values/themes.xml <?xml version="1.0" encoding="utf-8"?> <resources> <!-- the theme applied to the application or activity --> <style name="CustomActionBarTheme" parent="@android:style/Theme.Holo.Light.DarkActionBar"> <item name="android:actionBarStyle">@style/MyActionBar</item> </style> <!-- ActionBar styles --> <style name="MyActionBar" parent="@android:style/Widget.Holo.Light.ActionBar.Solid.Inverse"> <item name="android:background">@drawable/actionbar_background</item> </style> </resources>
单个activity或者整个app使用该主题如下:
<application android:theme="@style/CustomActionBarTheme" ... />
For Android 2.1 and higher
当使用Support Library,上面的主题应该定义成如下:
res/values/themes.xml <?xml version="1.0" encoding="utf-8"?> <resources> <!-- the theme applied to the application or activity --> <style name="CustomActionBarTheme" parent="@style/Theme.AppCompat.Light.DarkActionBar"> <item name="android:actionBarStyle">@style/MyActionBar</item> <!-- Support library compatibility --> <item name="actionBarStyle">@style/MyActionBar</item> </style> <!-- ActionBar styles --> <style name="MyActionBar" parent="@style/Widget.AppCompat.Light.ActionBar.Solid.Inverse"> <item name="android:background">@drawable/actionbar_background</item> <!-- Support library compatibility --> <item name="background">@drawable/actionbar_background</item> </style> </resources>
单个activity或者整个app使用该主题如下:
<application android:theme="@style/CustomActionBarTheme" ... />
Customize the Text Color
为了修改action bar里文本的颜色,你需要重写每个文本元素的各自的属性。
Action bar title: Create a custom style that specifies the textColor property and specify that style for the titleTextStyle property in your custom actionBarStyle.
Note: The custom style applied to titleTextStyle should use TextAppearance.Holo.Widget.ActionBar.Title as the parent style.
Action bar tabs: Override actionBarTabTextStyle in your activity theme.
Action buttons: Override actionMenuTextColor in your activity theme.
For Android 3.0 and higher only
当android3.0或者更高的版本,你的样式XML文件看上去如下:
res/values/themes.xml <?xml version="1.0" encoding="utf-8"?> <resources> <!-- the theme applied to the application or activity --> <style name="CustomActionBarTheme" parent="@style/Theme.Holo"> <item name="android:actionBarStyle">@style/MyActionBar</item> <item name="android:actionBarTabTextStyle">@style/MyActionBarTabText</item> <item name="android:actionMenuTextColor">@color/actionbar_text</item> </style> <!-- ActionBar styles --> <style name="MyActionBar" parent="@style/Widget.Holo.ActionBar"> <item name="android:titleTextStyle">@style/MyActionBarTitleText</item> </style> <!-- ActionBar title text --> <style name="MyActionBarTitleText" parent="@style/TextAppearance.Holo.Widget.ActionBar.Title"> <item name="android:textColor">@color/actionbar_text</item> </style> <!-- ActionBar tabs text styles --> <style name="MyActionBarTabText" parent="@style/Widget.Holo.ActionBar.TabText"> <item name="android:textColor">@color/actionbar_text</item> </style> </resources>
For Android 2.1 and higher
使用Support Library时,样式XML文件看上去如下:
res/values/themes.xml <?xml version="1.0" encoding="utf-8"?> <resources> <!-- the theme applied to the application or activity --> <style name="CustomActionBarTheme" parent="@style/Theme.AppCompat"> <item name="android:actionBarStyle">@style/MyActionBar</item> <item name="android:actionBarTabTextStyle">@style/MyActionBarTabText</item> <item name="android:actionMenuTextColor">@color/actionbar_text</item> <!-- Support library compatibility --> <item name="actionBarStyle">@style/MyActionBar</item> <item name="actionBarTabTextStyle">@style/MyActionBarTabText</item> <item name="actionMenuTextColor">@color/actionbar_text</item> </style> <!-- ActionBar styles --> <style name="MyActionBar" parent="@style/Widget.AppCompat.ActionBar"> <item name="android:titleTextStyle">@style/MyActionBarTitleText</item> <!-- Support library compatibility --> <item name="titleTextStyle">@style/MyActionBarTitleText</item> </style> <!-- ActionBar title text --> <style name="MyActionBarTitleText" parent="@style/TextAppearance.AppCompat.Widget.ActionBar.Title"> <item name="android:textColor">@color/actionbar_text</item> <!-- The textColor property is backward compatible with the Support Library --> </style> <!-- ActionBar tabs text --> <style name="MyActionBarTabText" parent="@style/Widget.AppCompat.ActionBar.TabText"> <item name="android:textColor">@color/actionbar_text</item> <!-- The textColor property is backward compatible with the Support Library --> </style> </resources>
Customize the Tab Indicator
为了更改用于导航选项卡的指示器,创建一个覆盖actionBarTabStyle属性的activity主题。该属性指向另一个样式资源,在该样式资源里你能重写background属性来指定一个state-list drawable。
注:state-list drawable用于表示当前那个tab被选中,当前被选中的tab同其他tabs相比,背景不同。更多关于怎么产生处理多个button状态的drawable 资源的信息请阅读State List文档。
例如,下面是一个state-list drawable。该selector针对action bar的tab的不同状态声明了特定的background image。
res/drawable/actionbar_tab_indicator.xml <?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <!-- STATES WHEN BUTTON IS NOT PRESSED --> <!-- Non focused states --> <item android:state_focused="false" android:state_selected="false" android:state_pressed="false" android:drawable="@drawable/tab_unselected" /> <item android:state_focused="false" android:state_selected="true" android:state_pressed="false" android:drawable="@drawable/tab_selected" /> <!-- Focused states (such as when focused with a d-pad or mouse hover) --> <item android:state_focused="true" android:state_selected="false" android:state_pressed="false" android:drawable="@drawable/tab_unselected_focused" /> <item android:state_focused="true" android:state_selected="true" android:state_pressed="false" android:drawable="@drawable/tab_selected_focused" /> <!-- STATES WHEN BUTTON IS PRESSED --> <!-- Non focused states --> <item android:state_focused="false" android:state_selected="false" android:state_pressed="true" android:drawable="@drawable/tab_unselected_pressed" /> <item android:state_focused="false" android:state_selected="true" android:state_pressed="true" android:drawable="@drawable/tab_selected_pressed" /> <!-- Focused states (such as when focused with a d-pad or mouse hover) --> <item android:state_focused="true" android:state_selected="false" android:state_pressed="true" android:drawable="@drawable/tab_unselected_pressed" /> <item android:state_focused="true" android:state_selected="true" android:state_pressed="true" android:drawable="@drawable/tab_selected_pressed" /> </selector> For Android 3.0 and higher only 当android3.0或者更高版本时,你的样式XML如下: res/values/themes.xml <?xml version="1.0" encoding="utf-8"?> <resources> <!-- the theme applied to the application or activity --> <style name="CustomActionBarTheme" parent="@style/Theme.Holo"> <item name="android:actionBarTabStyle">@style/MyActionBarTabs</item> </style> <!-- ActionBar tabs styles --> <style name="MyActionBarTabs" parent="@style/Widget.Holo.ActionBar.TabView"> <!-- tab indicator --> <item name="android:background">@drawable/actionbar_tab_indicator</item> </style> </resources>
For Android 2.1 and higher
当使用Support Library时,你的样式XML看上去如下:
res/values/themes.xml <?xml version="1.0" encoding="utf-8"?> <resources> <!-- the theme applied to the application or activity --> <style name="CustomActionBarTheme" parent="@style/Theme.AppCompat"> <item name="android:actionBarTabStyle">@style/MyActionBarTabs</item> <!-- Support library compatibility --> <item name="actionBarTabStyle">@style/MyActionBarTabs</item> </style> <!-- ActionBar tabs styles --> <style name="MyActionBarTabs" parent="@style/Widget.AppCompat.ActionBar.TabView"> <!-- tab indicator --> <item name="android:background">@drawable/actionbar_tab_indicator</item> <!-- Support library compatibility --> <item name="background">@drawable/actionbar_tab_indicator</item> </style> </resources>
更多学习资源:
See more style properties for the action bar are listed in the Action Bar guide.
Learn more about how themes work in the Styles and Themes guide.
For even more complete styling for the action bar, try the Android Action Bar Style Generator.
Overlaying the Action Bar
一般地,action bar出现在你的activity窗口的顶部,这样,对于你的activity的剩余的布局,稍微的减少了有效空间。如果你想显示和隐藏action bar,你能在Action Bar上调用show()和hide()实现。然而,这引起你的activity基于新的size重新计算和绘制布局。
当action bar隐藏和显示时,为了避免重新计算和绘制,你可以对action bar enable overlay模式。当在overlay模式下,如果action bar是hide的,你的activity布局使用所有的空间。系统绘制action bar在你的布局之上。这使得layout顶部部分变得模糊。但是现在当action bar显示或者隐藏时,系统并不需要resize布局。并且转换是无缝的。
提示:如果你想要你的layout在action bar后的部分是可见的,产生action bar的自定义style。设置其透明度,如图所示。更多定义action bar背景的信息,请参阅 Styling the Action Bar。
Enable Overlay Mode
enable overlay 模式,你需要产生一个自定义主题,该主题继承自一个存在的action bar主题。设置android:windowActionBarOverlay属性为true。
For Android 3.0 and higher only
如果你的minSdkVersion设置为11或者更高,你的自定义主题应该使用Theme.Holo主题(或者其子类之一)作为你的父主题。例如:
<resources> <!-- the theme applied to the application or activity --> <style name="CustomActionBarTheme" parent="@android:style/Theme.Holo"> <item name="android:windowActionBarOverlay">true</item> </style> </resources>
For Android 2.1 and higher
如果你的app是正使用Support Library以兼容运行低于3.0版本的设备,你的自定义主题应该使用Theme.AppCompat(或者其子类)作为你的父主题。例如:
<resources> <!-- the theme applied to the application or activity --> <style name="CustomActionBarTheme" parent="@android:style/Theme.AppCompat"> <item name="android:windowActionBarOverlay">true</item> <!-- Support library compatibility --> <item name="windowActionBarOverlay">true</item> </style> </resources>
也主要该主题包含了windowActionBarOverlay样式的两种定义:一个使用android:为前缀,一个没有前缀。使用android:前缀的windowActionBarOverlay是针对包含了android平台样式的版本。另一个没有前缀的是为旧的版本(3.0及以下至2.1的版本)。这些版本从Support Library里读响应的样式。
Specify Layout Top-margin
当action bar是overlay模式,可能使layout里的部分view模糊。 To ensure that such items remain below the action bar at all times, add either margin or padding to the top of the view(s) using the height specified by actionBarSize
. For example:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingTop="?android:attr/actionBarSize"> ... </RelativeLayout>如果你正使用Support Library,你需要移除android前缀,例如:
相关推荐
Adding an Action Bar to the Earthquake Monitor Creating and Using Menus and Action Bar Action Items Refreshing the Earthquake Monitor Going Full Screen Introducing Dialogs Let's Make a Toast ...
内容概要:本文详细介绍了8轴插补运动控制系统的实现,重点探讨了双DMA技术的应用,实现了高频率脉冲输出(最高可达500kHz)。文中首先解释了双DMA的工作原理及其相对于传统脉冲输出方式的优势,即减少CPU负载并提高数据传输速率。接着阐述了8轴插补算法的设计思想,包括基于时间分割的方法来确定各轴在特定时间段内的脉冲数。此外,还讨论了加减速控制策略,尤其是S型加减速算法的应用,以确保运动的平顺性。最后,文章展示了具体的代码实现细节,涵盖DMA配置、插补算法、加减速控制等方面。 适合人群:从事运动控制系统开发的技术人员,尤其是对嵌入式系统有一定了解的研发人员。 使用场景及目标:适用于需要高精度、高频脉冲输出的工业应用场景,如工业机器人、3D打印、激光切割等。目标是帮助开发者理解和掌握8轴插补运动控制的关键技术和实现方法,从而应用于实际项目中。 其他说明:文中提供的代码示例主要基于STM32系列单片机,但相关概念和技术可以迁移至其他平台。同时,强调了硬件细节处理的重要性,如RC滤波电路的应用,以应对实际工程中的常见问题。
2303040222橡胶232熊文栋(苯乙烯悬浮聚合)副本.pdf
内容概要:本文详细介绍了音乐喷泉的设计与制作过程,涵盖了从原理图绘制到具体代码实现的各个方面。首先介绍了Altium Designer这款强大的电子设计软件,接着展示了如何利用现有文件进行设计,包括水泵控制、灯光效果和音乐解析三大核心模块的具体实现方法。文中提供了多个代码片段,如单片机控制喷头升降、PWM调速控制水泵以及灯光效果同步音乐节奏等。同时,强调了在实际制作过程中需要注意的问题,如焊接温度、布线规划、元件选择等。此外,还分享了一些实用技巧和经验教训,帮助读者更好地理解和应用相关知识。 适合人群:对电子设计感兴趣的爱好者、初学者以及有一定基础的电子工程师。 使用场景及目标:适用于希望深入了解音乐喷泉工作原理和技术实现的人群,目标是掌握如何使用Altium Designer完成音乐喷泉的电路设计,并能够编写相应的控制代码。 其他说明:文章不仅提供了详细的理论讲解,还包括了许多实战经验和技巧,有助于读者在实践中少走弯路。
内容概要:本文详细介绍了汽车主动悬架系统的工作原理及其参数仿真的方法。首先解释了主动悬架的基本概念,即它可以根据车辆行驶状态和路面情况进行实时调整,提高行车安全性和舒适度。接着展示了如何利用简化的单自由度模型进行参数设置并进行仿真,具体涉及到了动力学方程、状态空间模型以及PID控制器的设计。此外还提到了更高级别的LQR控制器的应用,并强调了实际应用中需要注意的问题,如执行器响应延迟、物理限制等。文中通过实例演示了被动悬架与主动悬架在面对相同路面输入时的不同表现,突出了主动控制系统的优势。同时,针对传感器噪声处理、卡尔曼滤波器的使用、PWM信号生成等方面进行了深入探讨,揭示了主动悬架背后的复杂技术和工程挑战。 适用人群:对汽车工程特别是悬架系统感兴趣的研究人员和技术爱好者。 使用场景及目标:帮助读者理解主动悬架的工作机制,掌握基本的建模和仿真技能,为进一步开展相关领域的研究提供理论支持和技术指导。 其他说明:文中不仅提供了详细的数学推导和代码片段,还分享了许多实践经验,使读者能够全面地了解主动悬架系统的各个方面。
(3)请修改代码,解决临界区问题。解决后,无论如何运行,counter值均输出0
少儿编程scratch项目源代码文件案例素材-Mc v2.zip
内容概要:本文详细介绍了将Carsim与Simulink联合用于十四自由度车辆动力学模型的构建与验证过程。文中首先概述了整车架构的模块化分解方法,接着深入探讨了各个子系统的具体实现细节,如转向系统、轮胎模型、悬架子系统以及PI驾驶员控制器的设计与调优。针对联合仿真过程中遇到的关键问题,如采样率同步、参数调优、模型验证等进行了详细的讨论,并提供了具体的解决方案和技术技巧。通过对多种典型工况(如阶跃转向、正弦油门、双移线等)的仿真测试,验证了所建立模型的有效性和准确性。 适合人群:从事车辆动力学研究、汽车仿真领域的工程师和技术人员,尤其是那些希望深入了解Carsim与Simulink联合仿真的从业者。 使用场景及目标:适用于需要进行复杂车辆动力学仿真和模型验证的研究机构或企业。主要目标是提高仿真精度,缩短开发周期,确保模型能够准确反映实际车辆行为。此外,还可以作为教学材料帮助学生掌握先进的车辆建模技术和仿真工具。 其他说明:文中不仅分享了大量的实战经验和技巧,还附带了完整的源代码和详细的调试记录,对于想要深入理解和应用这一技术的人来说非常有价值。
内容概要:本文探讨了基于雨流计数法的源-荷-储双层协同优化配置,旨在提高能源系统的效率和经济性。文中介绍了双层优化架构,即外层优化储能系统的功率和容量,内层优化储能系统的充放电曲线并评估其寿命。通过Python代码示例展示了具体的实现过程,包括外层和内层优化的具体步骤以及雨流计数法的应用。此外,文章还讨论了常见的调试问题及解决方案,强调了内外层变量之间的相互影响。 适合人群:从事能源系统优化的研究人员和技术人员,尤其是对储能系统优化感兴趣的读者。 使用场景及目标:适用于需要进行源-荷-储系统优化的实际工程项目,如光伏电站、风力发电站等。目标是通过合理的储能配置,延长储能系统的使用寿命,降低成本,提高经济效益。 其他说明:文章提供了详细的代码示例和理论解释,帮助读者更好地理解和应用这一优化方法。同时提醒读者,在实际应用中需要注意数据的准确性以及参数的选择。
很多盗版PCI卡都在用的雕刻机控制程序
内容概要:本文详细介绍了三机并联的风光储混合系统在Matlab中的仿真方法及其关键技术。首先,针对光伏阵列模型,讨论了其核心二极管方程以及MPPT(最大功率点跟踪)算法的应用,强调了环境参数对输出特性的影响。接着,探讨了永磁同步风机的矢量控制,尤其是转速追踪和MPPT控制策略。对于混合储能系统,则深入讲解了超级电容和蓄电池的充放电策略,以及它们之间的协调机制。此外,还涉及了PQ控制的具体实现,包括双闭环结构的设计和锁相环的优化。最后,提供了仿真过程中常见的问题及解决方案,如求解器选择、参数敏感性和系统稳定性等。 适合人群:从事电力电子、新能源系统设计与仿真的工程师和技术人员,以及相关专业的研究生。 使用场景及目标:适用于希望深入了解风光储混合系统工作原理的研究人员,旨在帮助他们掌握Matlab仿真技巧,提高系统设计和优化的能力。 其他说明:文中不仅提供了详细的理论推导和代码示例,还分享了许多实践经验,有助于读者更好地理解和应用所学知识。
内容概要:本文详细介绍了基于NGSIM数据对Wiedemann99跟驰模型进行参数标定的过程。作者使用Matlab编写代码,实现了数据读取与预处理、Wiedemann99模型定义、拟合优度函数(RMSPE)计算以及改进粒子群算法(IPSO)。通过这些步骤,成功地对标定了Wiedemann99模型的关键参数,并对其进行了性能评估。文中不仅展示了具体的代码实现细节,还探讨了参数选择、算法改进等方面的经验教训。 适合人群:从事交通工程、智能交通系统研究的专业人士,尤其是那些对车辆跟驰行为建模感兴趣的科研工作者和技术开发者。 使用场景及目标:适用于需要精确模拟车辆跟驰行为的研究项目,如交通流量仿真、自动驾驶测试等。目标是提高模型的准确性和可靠性,以便更好地理解和预测真实的道路交通状况。 其他说明:文章提供了详细的代码片段和理论背景介绍,有助于读者深入理解整个标定流程。同时,作者分享了一些实用的小技巧,如参数敏感度分析、适应度函数设计等,对于相关领域的研究人员具有较高的参考价值。
内容概要:本文为中国信息通信研究院发布的《2024年大模型落地路线图研究报告》,旨在梳理大模型应用落地的共性需求和关键要素,为大模型赋能各行业提供参考。报告重点介绍了大模型应用落地的四个重要阶段——现状诊断、能力建设、应用部署、运营管理,归纳了八个关键步骤,包括能力分析、需求挖掘、方案设计、研发测试、应用开发、效能评估、运维监测和运营管理。报告详细分析了大模型在基础设施、数据资源、算法模型、应用服务、安全可信五个层面应重点关注的发展要素和亟待解决的问题。此外,报告还探讨了大模型在金融、工业、教育、医疗、政务等行业的具体应用场景及其带来的降本增效、提质增效等优势。最后,报告展望了大模型的发展趋势,强调了架构优化、行业数字化转型和可信发展的必要性。 适合人群:具备一定技术背景,特别是从事人工智能、大数据、云计算等领域工作的研发人员、管理人员和技术决策者。 使用场景及目标:①帮助企业和机构评估自身大模型应用的基础条件,明确业务转型需求;②指导大模型建设方案的设计和实施,确保技术选型的科学性和合理性;③提供应用部署和效能评估的具体方法,确保大模型在实际应用中的稳定性和高效性;④建立健全大模型的运营管理体系,保障业务的高效稳定开展。 其他说明:报告强调了大模型在推动各行业数字化转型中的重要作用,提出了未来大模型发展的重点方向,如架构优化、技术应用和可信发展。报告还呼吁社会各界共同关注大模型的安全可信问题,确保其与人类价值观的对齐,推动大模型的健康发展。
少儿编程scratch项目源代码文件案例素材-Scratch泡泡龙.zip
软考初级程序员是中国计算机技术与软件专业技术资格(水平)考试中的一个重要级别,主要面向打算进入IT行业的初学者或初级程序员。这个级别的考试旨在测试考生的基础编程能力、计算机基础知识以及解决问题的能力。历年真题是备考的重要参考资料,可以帮助考生了解考试的题型、难度以及考点。 在"软考初级程序员09-18年真题及答案解析"的压缩包中,包含了从2009年至2018年上半年的所有程序员考试真题。这些真题涵盖了多个方面,包括但不限于: 1. **基础编程语言**:如C语言、Java、Python等,主要考察基本语法、数据类型、控制结构、函数使用等方面。 2. **数据结构与算法**:如数组、链表、栈、队列、树、图等,以及排序算法(冒泡、选择、插入、快速、归并等)和查找算法(线性查找、二分查找等)。 3. **计算机系统知识**:包括计算机组成原理、操作系统、网络基础知识,例如CPU结构、内存管理、进程与线程、网络协议等。 4. **数据库基础**:SQL语言的基本操作,如增删改查、子查询、联接操作、索引等。 5. **软件工程与项目管理**:软件生命周期、需求分析、设计原则、测试方法、版本控制等。 6. **法律法规与职业道德**:涉及知识产权、合同法、信息安全与隐私保护等。 每份真题后的答案解析部分,是对题目答案的详细解释,通常包括解题思路、关键步骤以及知识点的扩展。通过阅读解析,考生不仅能知道自己答案的正确与否,还能深入理解相关知识点,提高自己的分析和解决问题的能力。 在准备软考初级程序员考试时,考生应充分利用这些真题资源,进行模拟练习,掌握各类题目的解答技巧。同时,考生还需要广泛阅读教材,补充相关知识,提高对理论的理解。此外,多做编程实践,提高实际编程能力,也是非常重要的。 总结来说,这个压缩包是备考软考初级程序员的宝贵资料,它能帮助考生熟悉考试形式,了解重
内容概要:本文详细介绍了如何在Zynq扩展口上使用FPGA和W5500实现稳定的TCP网络通信。作者通过一系列实验和技术手段,解决了多个实际问题,最终实现了零丢包的数据回环处理。主要内容包括:硬件搭建(SPI接口配置)、数据回环处理(双时钟域流水线)、压力测试(信号抓波形和防抖处理)、多路复用扩展以及上位机测试脚本的编写。文中提供了大量Verilog代码片段,展示了具体实现细节。 适合人群:具备一定FPGA开发经验的工程师,尤其是对TCP/IP协议栈感兴趣的嵌入式系统开发者。 使用场景及目标:适用于需要高性能、低延迟网络通信的应用场景,如工业控制系统、实时数据采集等。目标是帮助读者掌握在FPGA上实现高效TCP通信的方法和技术。 其他说明:文章不仅提供了详细的代码实现,还分享了许多实践经验,如SPI时钟优化、CS信号防抖、FIFO深度选择等。此外,作者还讨论了未来可能的改进方向,如UDP组播和QoS优先级控制。
内容概要:本文探讨了在汽车动力学研究和自动驾驶领域中,使用无迹扩展卡尔曼滤波(UKF/EKF)在Matlab/Simulink环境中对路面附着系数进行估计的方法。文中介绍了选择Matlab/Simulink的原因及其强大功能,详细解析了7自由度整车模型的构建,以及UKF和EKF的具体实现方式。UKF通过非线性处理和sigma点传播概率分布,适用于复杂工况;EKF则通过线性化处理,更适合计算资源有限的场景。两者在不同路面条件下表现出各自的优劣,如UKF在突变路面下表现更好,而EKF在不变路面上效率更高。此外,还讨论了调参技巧、工程实现细节及实际测试结果。 适用人群:从事汽车动力学研究、自动驾驶技术研发的专业人士,尤其是对非线性滤波算法感兴趣的研究人员和技术开发者。 使用场景及目标:①用于车辆稳定性控制系统中,提高行驶安全性;②优化滤波算法性能,平衡精度与实时性;③为复杂工况下的路面附着系数估计提供解决方案。 其他说明:文章不仅提供了理论分析,还包括大量代码示例和实践经验分享,有助于读者深入理解和实际应用。
内容概要:本文详细介绍了如何使用三菱PLC(以FX3U为例)和显控触摸屏实现定长送料系统的三种核心功能:点动、相对定位和绝对定位。文章从硬件连接开始,逐步讲解了每种功能的具体实现方法,包括梯形图编程、参数设置以及触摸屏交互设计。特别强调了伺服和步进电机的应用,并提供了调试技巧和注意事项,确保系统稳定可靠。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是那些需要掌握PLC编程和伺服/步进电机控制的人群。 使用场景及目标:适用于各类需要精确控制物料输送的生产设备,如包装机、裁切设备等。目标是帮助工程师快速搭建稳定的定长送料系统,提高生产效率和产品质量。 其他说明:文中还分享了一些实战经验,如软限位设置、急停回路设计、电子齿轮比计算等,有助于解决实际应用中的常见问题。
内容概要:本文详细介绍了一个基于51单片机的音乐盒项目,涵盖从原理到实践的全过程。首先解释了音乐产生的基本原理,即通过控制I/O口输出不同频率的方波驱动蜂鸣器发声。接着介绍了原理图设计,重点描述了51单片机与其他组件如蜂鸣器、按键等的连接方式。然后讲解了Protues仿真工具的应用,强调其在硬件电路搭建前进行验证的重要性。最后深入剖析了程序源码,包括音符频率表、节拍编码、延时函数、播放音符和音乐的函数以及主函数的具体实现。 适合人群:对单片机开发感兴趣的初学者或有一定经验的研发人员。 使用场景及目标:适用于希望深入了解51单片机工作原理及其应用的人群,特别是那些想要亲手制作一个能够播放多首曲目的音乐盒爱好者。通过该项目的学习,不仅可以掌握单片机的基本编程技能,还可以提高解决实际问题的能力。 其他说明:文中提供了详细的代码注释和技术细节,帮助读者更好地理解和实现项目。此外,还分享了一些实用的小贴士,如如何避免常见错误、优化性能等。
子查询练习题,多练习总没有坏处,不知道凑没凑够十一个字