我正在研究此链接中的 fragment :http://developer.android.com/guide/components/fragments.html
有一段代码如下:
public static class ExampleFragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
return inflater.inflate(R.layout.example_fragment, container, false);
}
我对 attachToRoot 参数感到困惑,所以我在 Stack Overflow 上查找了一些帮助并找到了类似问题的好答案。所以我的理解是,如果你将它设置为 true, fragment 就会附加到 Activity 的根布局,并从那里派生它的布局参数。如果它为 false,它将简单地返回膨胀布局的根,并像 fragment 的独立 View 一样工作(从传入的容器中派生布局参数)。
现在,我进一步阅读了有关上述示例的 attachToRoot 的文档:
A boolean indicating whether the inflated layout should be attached to the ViewGroup (the second parameter) during inflation. (In this case, this is false because the system is already inserting the inflated layout into the container—passing true would create a redundant view group in the final layout.)
我没有得到最后一个括号语句,它说它应该是错误的,因为我们已经将布局插入到容器中。我们已经在没有 attachToRoot 的情况下插入容器是什么意思?如果参数为真,最终布局将如何具有冗余 View 组。详细说明这部分的示例将有很大帮助。谢谢。
最佳答案
我通常不回答自己的问题,但在对此进行更多研究后,我认为这可能会对其他人有所帮助。虽然 Marcin 的回答是正确的,但我只是回答得更详细一些。
根据代码:
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
return inflater.inflate(R.layout.example_fragment, container, false);
}
第二个参数 container 是一个带有 id fragment_container 的框架布局, Activity 使用它来将 fragment 添加到它的布局中。
现在,如果我们深入研究 LayoutInflater 类的 inflate 方法,这就是代码(我只是突出显示代码的相关部分而不是整个部分):
// The view that would be returned from this method.
View result = root;
// Temp is the root view that was found in the xml.
final View temp = createViewFromTag(root, name, attrs, false);
首先,它从提供的根创建一个临时 View 。
如果attachToRoot 为真,它会这样做:
if (root != null && attachToRoot) {
root.addView(temp, params);
}
它将上面创建的临时 View 添加到 Root View (即容器)。
如果 attachToRoot 为假,它会这样做:
if (root == null || !attachToRoot) {
result = temp;
}
很明显,如果 attachToRoot 为 true,它会在向其添加临时 View ( Root View 在本例中的 example_fragment 中))。
如果 attachToRoot 为 false,它只返回 fragment xml 的根,即容器参数仅用于获取 fragment Root View 的 layoutParams(因为它没有根,所以它需要来自某个地方的参数)。
在上面的例子中出现了 true 的问题,因为返回值是 root (添加了 View 临时的 fragment_container,默认情况下 fragment_container 已经有一个父级。)。现在,如果您尝试执行 fragment 事务,您正在尝试将 subview fragment_container(已经有一个父 View )添加到另一个 xml(您定义的要将 fragment 添加到的框架布局)。
因此,Android 抛出以下异常:
if (child.getParent() != null) {
throw new IllegalStateException("The specified child already has a parent. " +
"You must call removeView() on the child's parent first.");
}
将其设置为 true 并返回时的问题是返回的 View 已经有一个父 View ,因此不能在其他地方使用。其他方式,您可以在 onCreateView(可能是 LinearLayout)中创建一个单独的 View 组,将参数设置为 true,然后返回 View 。然后它将正常工作,因为 View 组将没有现有的父级。
这是我对上述问题的理解,可能我理解有误,请Android高手指正。
关于android - 关于 inflater.inflate Android 文档的混淆,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31854605/
matlab打开matlab,用最简单的imread方法读取一个图像clcclearimg_h=imread('hua.jpg');返回一个数组(矩阵),往往是a*b*cunit8类型解释一下这个三维数组的意思,行数、数和层数,unit8:指数据类型,无符号八位整形,可理解为0~2^8的数三个层数分别代表RGB三个通道图像rgb最常用的是24-位实现方法,即RGB每个通道有256色阶(2^8)。基于这样的24-位RGB模型的色彩空间可以表现256×256×256≈1670万色当imshow传入了一个二维数组,它将以灰度方式绘制;可以把图像拆分为rgb三层,可以以灰度的方式观察它figure(1
最近因为项目需要,需要将Android手机系统自带的某个系统软件反编译并更改里面某个资源,并重新打包,签名生成新的自定义的apk,下面我来介绍一下我的实现过程。APK修改,分为以下几步:反编译解包,修改,重打包,修改签名等步骤。安卓apk修改准备工作1.系统配置好JavaJDK环境变量2.需要root权限的手机(针对系统自带apk,其他软件免root)3.Auto-Sign签名工具4.apktool工具安卓apk修改开始反编译本文拿Android系统里面的Settings.apk做demo,具体如何将apk获取出来在此就不过多介绍了,直接进入主题:按键win+R输入cmd,打开命令窗口,并将路
我在我的rails应用程序中安装了来自github.com的acts_as_versioned插件,但有一段代码我不完全理解,我希望有人能帮我解决这个问题class_eval我知道block内的方法(或任何它是什么)被定义为类内的实例方法,但我在插件的任何地方都找不到定义为常量的CLASS_METHODS,而且我也不确定是什么here,并且有问题的代码从lib/acts_as_versioned.rb的第199行开始。如果有人愿意告诉我这里的内幕,我将不胜感激。谢谢-C 最佳答案 这是一个异端。http://en.wikipedia
Ruby有一些不错的文档生成器,例如Yard、rDoc,甚至Glyph。问题是Sphinx可以做网站、PDF、epub、LaTex等。它在重组文本中完成所有这些事情。在Ruby世界中有替代方案吗?也许是程序的组合?如果我也能使用Markdown就更好了。 最佳答案 自1.0版以来,Sphinx有了“域”的概念,它是从Python和/或C以外的语言标记代码实体(如方法调用、对象、函数等)的方法。有一个rubydomain,所以你可以只使用Sphinx本身。您唯一会缺少的(我认为)是Sphinx使用autodoc从源代码自动创建文档
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我最近开始学习Ruby,这是我的第一门编程语言。我对语法感到满意,并且我已经完成了许多只教授相同基础知识的教程。我已经写了一些小程序(包括我自己的数组排序方法,在有人告诉我谷歌“冒泡排序”之前我认为它非常聪明),但我觉得我需要尝试更大更难的东西来理解更多关于Ruby.关于如何执行此操作的任何想法?
我怀念ipython的一件事是它有一个?为特定功能挖掘文档的运算符。我知道ruby有一个类似的命令行工具,但是我在irb中调用它非常不方便。ruby/irb有类似的东西吗? 最佳答案 Pry是IPython的Ruby版本,它支持?命令来查找有关方法的文档,但语法略有不同:pry(main)>?File.dirnameFrom:file.cinRubyCore(CMethod):Numberoflines:6visibility:publicsignature:dirname()Returnsallcomponentsofthef
我在Ruby中遇到了一个关于Dir[]和File.join()的简单程序,blobs_dir='/path/to/dir'Dir[File.join(blobs_dir,"**","*")].eachdo|file|FileUtils.rm_rf(file)ifFile.symlink?(file)我有两个困惑:首先,File.join(@blobs_dir,"**","*")中的第二个和第三个参数是什么意思?其次,Dir[]在Ruby中有什么用?我只知道它等价于Dir.glob(),但是,我对Dir.glob()确实不是很清楚。 最佳答案
我正在尝试使用nokogirigem提取页面上的所有url及其链接文本,并将链接文本和url存储在散列中。FooBar我想回去{"Foo"=>"#foo","Bar"=>"#bar"} 最佳答案 这是一个单行:Hash[doc.xpath('//a[@href]').map{|link|[link.text.strip,link["href"]]}]#=>{"Foo"=>"#foo","Bar"=>"#bar"}拆分一点可以说更具可读性:h={}doc.xpath('//a[@href]').eachdo|link|h[link.t
这是一些奇怪的例子:#!/usr/bin/rubyrequire'rubygems'require'open-uri'require'nokogiri'print"withoutread:",Nokogiri(open('http://weblog.rubyonrails.org/')).class,"\n"print"withread:",Nokogiri(open('http://weblog.rubyonrails.org/').read).class,"\n"运行此返回:withoutread:Nokogiri::XML::Documentwithread:Nokogiri::
1.回顾.TransportServicepublicclassTransportServiceextendsAbstractLifecycleComponentTransportService:方法:1publicfinalTextendsTransportResponse>voidsendRequest(finalTransport.Connectionconnection,finalStringaction,finalTransportRequestrequest,finalTransportRequestOptionsoptions,TransportResponseHandlerT>