带有可拖动文本的不可播放的Textformfield-扑响
我正在尝试创建一个TextFormField,该fordfield从其他逻辑中获取其值,而不是直接键入文本。如果用户在此TextFormField上点击,则将提示他们进入一个新屏幕,他们可以从列表中选择内容,并且他们的选择将在TextFormField上反映。现在,选择可以是多个多数,因此文本可能比TextFormfield的宽度更长。现在,我想将其内部的文字拖动,以便用户可以看到他们的选择。我的此TextFormfield的代码就是这样。
GestureDetector(
onTap: () => Navigator.pushNamed(context, NamedRoutes.breedScreenRoute),
child: TextFormField(
controller: controller,
enabled: false,
decoration: InputDecoration(
suffixIcon: Padding(
SvgPicture.asset(
"assets/images/forwardArrow.svg",
fit: BoxFit.scaleDown,
)
),
contentPadding:
const EdgeInsets.symmetric(horizontal: 14.0, vertical: 15.0),
focusedBorder: const UnderlineInputBorder(
borderSide: BorderSide(color: Color(0xFFD9E2EC)),
),
enabledBorder: const UnderlineInputBorder(
borderSide: BorderSide(
color: Color(0xFFD9E2EC),
),
),
labelText: "Tell us more about the breed",
labelStyle: TextStyle(
fontSize: 14.0,
color: Color(0xFF6E7191),
fontWeight: FontWeight.w400,
),
),
),
);
如果我想拖动文本,则需要启用TextFormField。但是,然后用户也将能够输入我不想要的。我该如何实现?
I'm trying to create a TextFormField that takes it's value from some other logic instead of directly typing the text. If the user taps on this TextFormField, they'll be prompted to a new screen where they can select things from a list and their choice will be reflected back on the TextFormField. Now, the selection can be multiple hence the text may be longer than the TextFormField's width. Now I want to make the text inside it draggable so that the user can see their selection. My code for this TextFormField is like such.
GestureDetector(
onTap: () => Navigator.pushNamed(context, NamedRoutes.breedScreenRoute),
child: TextFormField(
controller: controller,
enabled: false,
decoration: InputDecoration(
suffixIcon: Padding(
SvgPicture.asset(
"assets/images/forwardArrow.svg",
fit: BoxFit.scaleDown,
)
),
contentPadding:
const EdgeInsets.symmetric(horizontal: 14.0, vertical: 15.0),
focusedBorder: const UnderlineInputBorder(
borderSide: BorderSide(color: Color(0xFFD9E2EC)),
),
enabledBorder: const UnderlineInputBorder(
borderSide: BorderSide(
color: Color(0xFFD9E2EC),
),
),
labelText: "Tell us more about the breed",
labelStyle: TextStyle(
fontSize: 14.0,
color: Color(0xFF6E7191),
fontWeight: FontWeight.w400,
),
),
),
);
If I want to drag the text, I need to enable the TextFormField. But then user will be able to type in it as well which I don't want. How can I achieve this?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
SET
已启用:true
,scrollphysics:lobsyscrollablesscrollphysics()
andreadonly:true
。并使用ontap
内部textformfield
而不是gesturedetector
。用户可以滚动,但不能编辑它。Set
enabled: true
,scrollPhysics: AlwaysScrollableScrollPhysics()
andreadOnly: true
. And useonTap
insideTextFormField
instead ofGestureDetector
. User can scroll but can not edit it.如果您不希望使用用户类型,那么为什么要使用textformfield()?
考虑使用text()或使用dropdownbutton()
If you dont want user type in it, then why using the TextFormField()?
Consider using Text() or use DropdownButton()