- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下 XML 文件 -
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_product_page_root_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white">
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/activity_product_page_top_product_layout"
android:layout_width="match_parent"
android:layout_height="80dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<ImageView
android:id="@+id/activity_product_page_back_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:contentDescription="@string/marketplace_productvendor_page_back_button"
android:onClick="backButtonPressed"
android:src="@drawable/arrow_left"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<ImageView
android:id="@+id/activity_product_page_vendor_icon_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:contentDescription="@string/marketplace_productvendor_page_vendor_image"
android:scaleType="centerCrop"
android:src="@mipmap/ic_launcher"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.5"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
tools:layout_width="200dp" />
<FrameLayout
android:id="@+id/activity_product_page_shopping_cart_framelayout"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:background="@color/white"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent">
<ImageView
android:id="@+id/activity_checkout_cart_imageView"
android:layout_width="25dp"
android:layout_height="25dp"
android:layout_margin="20dp"
android:layout_marginTop="10dp"
android:layout_marginBottom="10dp"
android:src="@drawable/icons_32_x_32_black_shopping_cart" />
<TextView
android:id="@+id/activity_product_page_shopping_cart_counter"
android:layout_width="25dp"
android:layout_height="25dp"
android:layout_gravity="end"
android:background="@drawable/textview_round_background"
android:elevation="1dp"
android:gravity="center"
android:maxLines="1"
android:textAlignment="center"
android:textColor="@color/white"
android:textSize="10sp"
android:textStyle="bold"
android:visibility="gone"
app:autoSizeMaxTextSize="16sp"
app:autoSizeMinTextSize="10sp"
app:autoSizeStepGranularity="2sp"
app:layout_constraintStart_toEndOf="@+id/activity_checkout_cart_imageView"
app:layout_constraintTop_toTopOf="parent"
tools:ignore="SmallSp"
tools:text="1"
tools:visibility="visible" />
</FrameLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/activity_product_page_top_product_layout">
<com.google.android.material.floatingactionbutton.FloatingActionButton
android:id="@+id/activity_product_page_share_product_action_button"
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_gravity="end"
android:layout_marginTop="30dp"
android:layout_marginEnd="20dp"
android:alpha="0.5"
android:background="@color/grey_text_cart"
android:backgroundTint="@color/grey_text_cart"
android:elevation="1dp"
android:scaleType="center"
android:src="@drawable/share_product"
app:backgroundTint="@color/white"
app:fabCustomSize="50dp"
app:fabSize="auto"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.core.widget.NestedScrollView
android:id="@+id/activity_product_page_nested_scroll_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fillViewport="true">
<LinearLayout
android:id="@+id/activity_product_page_nested_linear_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingBottom="@dimen/marketplace_15dp">
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/very_light_grey" />
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/activity_product_page_brands_breadcrumbs"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="@dimen/marketplace_15dp"
android:fontFamily="@font/noto_sans"
android:text="@string/breadcrumbs_brands"
android:textStyle="bold" />
<TextView
android:id="@+id/activity_product_page_vendor_breadcrumbs"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/marketplace_15dp"
android:layout_toEndOf="@id/activity_product_page_brands_breadcrumbs"
android:fontFamily="@font/noto_sans"
android:text="@string/products_breadcrumbs_unknown_vendor"
android:textStyle="bold" />
<TextView
android:id="@+id/activity_product_page_product_breadcrumbs"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/marketplace_15dp"
android:layout_toEndOf="@id/activity_product_page_vendor_breadcrumbs"
android:ellipsize="end"
android:fontFamily="@font/noto_sans"
android:maxLines="1"
android:text="@string/activity_product_page_unknown_product"
android:textColor="#979797" />
</RelativeLayout>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:layout_marginTop="@dimen/marketplace_15dp"
android:background="@color/very_light_grey" />
<androidx.viewpager.widget.ViewPager
android:id="@+id/activity_product_page_view_pager"
android:layout_width="match_parent"
android:layout_height="300dp"
android:paddingStart="40dp"
android:paddingEnd="40dp"
tools:layout_height="300dp" />
<me.relex.circleindicator.CircleIndicator
android:id="@+id/activity_product_page_image_indicator"
android:layout_width="match_parent"
android:layout_height="10dp"
app:ci_drawable="@drawable/currently_selected_product"
app:ci_drawable_unselected="@drawable/currently_unselected_product"
app:ci_height="5dp"
app:ci_width="5dp" />
<LinearLayout
android:id="@+id/activity_product_page_products_details_viewgroup"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginTop="@dimen/marketplace_15dp"
android:background="@color/very_light_grey"
android:orientation="vertical">
<TextView
android:id="@+id/activity_product_page_product_title_textview"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="@dimen/marketplace_15dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:fontFamily="@font/noto_sans"
android:textSize="20sp"
android:textStyle="bold"
tools:text="Products long title" />
<TextView
android:id="@+id/activity_product_page_product_short_description_textview"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="@dimen/marketplace_15dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:fontFamily="@font/noto_sans"
tools:text="Product short description" />
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="30dp"
android:layout_marginEnd="@dimen/marketplace_14dp">
<TextView
android:id="@+id/activity_product_page_sold_by"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_sold_by" />
<TextView
android:id="@+id/activity_product_page_vendors_name_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignTop="@id/activity_product_page_sold_by"
android:layout_marginStart="5dp"
android:layout_toEndOf="@+id/activity_product_page_sold_by"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_unknown"
android:textStyle="bold"
tools:text="Vendors name, " />
<TextView
android:id="@+id/activity_product_page_fulfilled_by_hard_coded_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/activity_product_page_vendors_name_textview"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_fulfilled_by" />
<TextView
android:id="@+id/activity_product_page_fulfilled_by_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignTop="@+id/activity_product_page_fulfilled_by_hard_coded_text"
android:layout_marginStart="5dp"
android:layout_toEndOf="@+id/activity_product_page_fulfilled_by_hard_coded_text"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_unknown"
android:textStyle="bold"
tools:text="Project Verte." />
<TextView
android:id="@+id/activity_product_page_sku_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentEnd="true"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_sku_unknown"
tools:text="SKU: K004" />
</RelativeLayout>
<TextView
android:id="@+id/activity_product_page_product_price_textview"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="30dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_fetching_price"
android:textSize="20sp"
android:textStyle="bold"
tools:text="$35.00" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_additional_tax_may_apply_on_checkout" />
<RelativeLayout
android:id="@+id/activity_product_page_availability_view_group"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/marketplace_15dp">
<TextView
android:id="@+id/activity_product_page_availability_hardcoded"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_availability" />
<TextView
android:id="@+id/activity_product_page_availability_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignTop="@+id/activity_product_page_availability_hardcoded"
android:layout_toEndOf="@+id/activity_product_page_availability_hardcoded"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_unknown"
android:textColor="@color/red_delete"
tools:text="In Stock"
tools:textColor="@color/product_available" />
</RelativeLayout>
<RelativeLayout
android:id="@+id/activity_product_page_quantity_picker_viewgroup"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/marketplace_15dp"
android:visibility="gone"
tools:visibility="visible">
<TextView
android:id="@+id/activity_product_page_quantity_hardcoded"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_quantity" />
<NumberPicker
android:id="@+id/activity_product_page_quantity_number_picker"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignStart="@+id/activity_product_page_quantity_hardcoded"
android:layout_marginStart="90dp"
android:layout_marginEnd="90dp" />
</RelativeLayout>
<!-- At this point starts the dynamic product attributes (if any exists)
Check ProductPageActivity.java 'setProductPurchaseAttributes()'
for the code -->
<ProgressBar
android:id="@+id/activity_product_page_add_to_cart_progress_bar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="@dimen/marketplace_15dp"
android:visibility="gone"
tools:visibility="visible" />
<Button
android:id="@+id/activity_product_page_add_to_cart_button"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="@dimen/marketplace_15dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:background="@color/color_black"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_add_to_cart"
android:textColor="@color/white" />
<ProgressBar
android:id="@+id/activity_product_page_buy_now_progress_bar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="@dimen/marketplace_15dp"
android:visibility="gone"
tools:visibility="visible" />
<Button
android:id="@+id/activity_product_page_buy_now_button"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="@dimen/marketplace_15dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:background="@color/color_black"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_buy_now"
android:textColor="@color/white" />
<TextView
android:id="@+id/activity_product_page_share_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="30dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_share" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/marketplace_14dp"
android:layout_marginTop="30dp"
android:layout_marginEnd="@dimen/marketplace_14dp"
android:fontFamily="@font/noto_sans"
android:text="@string/activity_product_page_related_products"
android:textSize="22sp"
android:textStyle="bold" />
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/activity_product_page_related_recycleview"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center"
android:layout_marginTop="@dimen/marketplace_15dp"
app:layoutManager="androidx.recyclerview.widget.GridLayoutManager"
tools:listitem="@layout/fragment_marketplace_products_row_item" />
<View
android:id="@+id/activity_product_page_bottom_view"
android:layout_width="match_parent"
android:layout_height="70dp"
android:layout_marginTop="@dimen/marketplace_15dp"
android:layout_marginBottom="60dp"
android:background="@color/light_black"
android:visibility="gone"
tools:visibility="visible" />
</LinearLayout>
</LinearLayout>
</androidx.core.widget.NestedScrollView>
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
看起来像这样 -
我正在尝试实现一种逻辑,该逻辑将使 float 栏在到达名为 - activity_product_page_share_textview
的 TextView 时消失。 。我尝试实现 new NestedScrollView.OnScrollChangeListener()
在我的 NestedScrollView 上,但我从scrollX和scrollY获得的值完全不相关 - 似乎它根据当前可用的屏幕空间计算值,并且(也许)还根据我的滚动速度 - 绝对不是根据 NestedScrollView ViewGroup。
另外,我希望 float 栏在 TextView 的 Y 位置下方时返回。两者都通过一些简单的淡入/淡出动画出现和消失。
我该如何实现它?
最佳答案
也许是这样的?需要一些优化(例如 float 按钮不需要位于每个滚动条上),但这与想法有关。
activity_product_page_nested_scroll_view.setOnScrollChangeListener(NestedScrollView.OnScrollChangeListener { _, _, _, _, _ ->
val locationOfTextView = IntArray(2)
val locationOfFloatingButton = IntArray(2)
activity_product_page_share_textview.getLocationInSurface(locationOfTextView)
activity_product_page_share_product_action_button.getLocationInSurface(
locationOfFloatingButton
)
if (locationOfTextView[1] >= locationOfFloatingButton[1] &&
locationOfTextView[1] + activity_product_page_share_textview.height <= locationOfFloatingButton[1] + activity_product_page_share_product_action_button.height
) {
if (activity_product_page_share_textview.alpha == 1F)
activity_product_page_share_textview.animate().alpha(0F).setDuration(200L).start()
} else {
if (activity_product_page_share_textview.alpha < 1F)
activity_product_page_share_textview.animate().alpha(1F).setDuration(200L).start()
}
})
关于android - 当 float 按钮到达 NestedScrollView 内 TextView 的相同高度位置时,如何将 float 按钮可见性设置为 GONE?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60360327/
我知道问题的标题听起来很奇怪,但我不知道该怎么调用它。 首先,我有一个网格布局,我希望我的 .search-wrapper 宽度为 50% 并向右浮动。在我的演示中 jsfiddle整个 .searc
我们正在使用 QA-C 来实现 MISRA C++ 一致性,但是该工具会为这样的代码喷出错误: float a = foo(); float b = bar(); float c = a - b; 据
考虑 float a[] = { 0.1, 0.2, 0.3}; 我很困惑a稍后传递给函数 foo(float* A) .不应该是 float* 类型的变量指向单个浮点数,对吗?就像这里提到的tu
这可能是我一段时间以来收到的最好的错误消息,我很好奇出了什么问题。 原代码 float currElbowAngle = LeftArm ? Elbow.transform.localRotation
刚开始学习 F#,我正在尝试为 e 生成和评估泰勒级数的前 10 项。我最初编写了这段代码来计算它: let fact n = function | 0 -> 1 | _ -> [1
我已经使用 Erlang 读取二进制文件中的 4 个字节(小端)。 在尝试将二进制转换为浮点时,我一直遇到以下错误: ** exception error: bad argument in
假设我有: float a = 3 // (gdb) p/f a = 3 float b = 299792458 // (gdb) p/f b = 29979244
我每次都想在浏览器顶部修复这个框。但是右边有一些问题我不知道如何解决所以我寻求帮助。 #StickyBar #RightSideOfStickyBar { float : right ; }
我正在研究 C# 编译器并试图理解数学运算规则。 我发现在两种不同的原始类型之间使用 == 运算符时会出现难以理解的行为。 int a = 1; float b = 1.0f; Cons
假设我有: float a = 3 // (gdb) p/f a = 3 float b = 299792458 // (gdb) p/f b = 29979244
Denormals众所周知,与正常情况相比,表现严重不佳,大约是 100 倍。这经常导致 unexpected软件 problems . 我很好奇,从 CPU 架构的角度来看,为什么非规范化必须是 那
我有一个由两个 float 组成的区间,并且需要生成 20 个随机数,看起来介于两个 float 定义的区间之间。 比方说: float a = 12.49953f float b = 39.1123
我正在构建如下矩阵: QMatrix4x3 floatPos4x3 = QMatrix4x3( floatPos0.at(0), floatPos1.at(0), floatPos2.at(0),
给定归一化的浮点数f,在f之前/之后的下一个归一化浮点数是多少。 通过微动,提取尾数和指数,我得到了: next_normalized(double&){ if mantissa is n
关于 CSS“float”属性的某些东西一直让我感到困惑。为什么将“float”属性应用到您希望 float 的元素之前的元素? 为了帮助可视化我的问题,我创建了以下 jsFiddle http://
关于 CSS“float”属性的某些东西一直让我感到困惑。为什么将“float”属性应用到您希望 float 的元素之前的元素? 为了帮助可视化我的问题,我创建了以下 jsFiddle http://
我有一个新闻源/聊天框。每个条目包含两个跨度:#user 和#message。我希望#user 向左浮动,而#message 向左浮动。如果#message 导致行超过容器宽度,#message 应该
我想创建一个“记分卡”网格来输出一些数据。如果每个 div.item 中的数据都具有相同的高度,那么在每个 div.item 上留下一个简单的 float 会提供一个漂亮的均匀布局,它可以根据浏览器大
我正在学习使用 CSS float 属性。我想了解此属性的特定效果。 考虑以下简单的 HTML 元素: div1 div2 This is a paragraph 以及以下 CSS 规则: div {
我正在尝试从可以是 int 或 float 的文件中提取数据。我发现这个正则表达式将从文件 (\d+(\.\d+)?) 中提取这两种类型,但我遇到的问题是它将 float 拆分为两个。 >>> imp
我是一名优秀的程序员,十分优秀!